
.portfolio_nav { display:none; }
.top_bar.fixed
{
	position: fixed;
	animation-name: slideDown;
	-webkit-animation-name: slideDown;	
	animation-duration: 0.5s;	
	-webkit-animation-duration: 0.5s;
	z-index: 999;
	visibility: visible !important;
	top: 0px;
}

.top_bar.fixed #menu_wrapper div .nav
{
	margin-top: 16px;
}

.top_bar.fixed #searchform
{
	margin-top: 8px;
}

.top_bar.fixed .header_cart_wrapper
{
	margin-top: 21px;
}

.top_bar.fixed #menu_wrapper div .nav > li > a
{
	padding-bottom: 24px;
}

.top_bar.fixed .logo_wrapper img
{
	max-height: 40px;
	width: auto;
}
#wrapper
{
	overflow-x: hidden;
}
.mobile_menu_wrapper
{
    overflow: auto;
}
body.js_nav .mobile_menu_wrapper 
{
    display: block;
}
.gallery_type, .portfolio_type
{
	opacity: 1;
}
#searchform input[type=text]
{
	width: 75%;
}
.woocommerce .logo_wrapper img
{
	max-width: 50%;
}



@media only screen and (max-width: 768px) {
	html[data-menu=leftmenu] .mobile_menu_wrapper
	{
		right: 0;
		left: initial;
		
		-webkit-transform: translate(360px, 0px);
		-ms-transform: translate(360px, 0px);
		transform: translate(360px, 0px);
		-o-transform: translate(360px, 0px);
	}
}


.two_cols.gallery .element:hover img, .three_cols.gallery .element:hover img, .four_cols.gallery .element:hover img, .five_cols.gallery .element:hover img, .one_half.gallery2.classic a:hover img, .one_third.gallery3.classic a:hover img, .one_fourth.gallery4.classic a:hover img
{
	-ms-transform: scale(1);
    -moz-transform: scale(1);
    -o-transform: scale(1);
    -webkit-transform: scale(1);
    transform: scale(1);
}



#page_content_wrapper .sidebar .content .sidebar_widget li h2.widgettitle, h2.widgettitle
{
	padding: 0;
	border: 0;
}

#page_caption.hasbg .page_title_wrapper
{
	background: rgba(0,0,0,0);
}

html[data-style=fullscreen] .top_bar.hasbg, .top_bar.hasbg
{
	border: 0;
}

html[data-style=fullscreen] .top_bar.hasbg, .top_bar.hasbg
{
	background: rgba(0,0,0,0);
}



.bg_gradient::after
{
	content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: -1px;
    left: 0;
    background: transparent;
    background-image: -webkit-gradient(linear,left top,left bottom,from(transparent),color-stop(60%,transparent),color-stop(66%,rgba(0,0,0,0.1)),color-stop(93%,rgba(0,0,0,0.95)),to(rgba(0,0,0,1)));
    background-image: -webkit-linear-gradient(transparent 0%,transparent 60%,rgba(0,0,0,0.1) 66%,rgba(0,0,0,0.95) 93%,rgba(0,0,0,1) 100%);
    background-image: linear-gradient(transparent 0%,transparent 60%,rgba(0,0,0,0.1) 66%,rgba(0,0,0,0.95) 93%,rgba(0,0,0,1) 100%)
}


@-webkit-keyframes fadeIn { from { opacity:0; } to { opacity:0.99; } }
@-moz-keyframes fadeIn { from { opacity:0; } to { opacity:0.99; } }
@-ms-keyframes fadeIn { from { opacity:0; } to { opacity:0.99; } }
@keyframes fadeIn { from { opacity:0; } to { opacity:0.99; } }
 
.fade-in {
    animation-name: fadeIn;
	-webkit-animation-name: fadeIn;
	-ms-animation-name: fadeIn;	

	animation-duration: 0.7s;	
	-webkit-animation-duration: 0.7s;
	-ms-animation-duration: 0.7s;	

	-webkit-animation-fill-mode:forwards; 
    -moz-animation-fill-mode:forwards;
    -ms-animation-fill-mode:forwards;
    animation-fill-mode:forwards;
    
    visibility: visible !important;
}


.origen-title {
    font-family: "Montserrat", Sans-serif;
    font-size: 130px;
    font-weight: 800;
    text-align: center;
    line-height: 1.3em;
    letter-spacing: 2px;
    color: #FFFFFF;
}
.fullwidth_comment_wrapper {
    display: none;
}
.post_info_date {
    display: none;
}
.mobx-title {
    display: none !important; 
}

.post-header h5 a, .post-header h6 a {
    color: #FFFFFF!important;
}

/* Hace que el enlace invisible cubra todo el bloque y sea clicable */
.blog-posts-grid_no_space {
  position: relative;
}
.blog-posts-grid_no_space .post-block-link {
  position: absolute;
  inset: 0;              /* ocupa todo el bloque */
  z-index: 5;            /* encima del fondo */
  display: block;
  text-indent: -9999px;  /* oculta el texto si lo hubiera */
  cursor: pointer;
}
#blog_grid_fullwidth .blog-posts-grid_no_space {
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  display: block !important;
height: 600px;
}

/* Efecto de zoom en imagen*/

.blog-posts-grid_no_space {
  position: relative;
  overflow: hidden;
}

.blog-posts-grid_no_space::before {
  content: "";
  position: absolute;
  inset: 0;
  background: inherit; /* usa la misma imagen del bloque */
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  transition: transform 1.2s ease, filter 0.6s ease;
  z-index: 0;
}

.blog-posts-grid_no_space:hover::before {
  transform: scale(1.08);
  filter: brightness(0.9);
}

.blog-posts-grid_no_space .post-content-wrapper {
  position: relative;
  z-index: 1;
}

/*Newsletter/ 

/* Corrige alineación y elimina espacio excesivo entre checkbox y texto */
p label {
  display: inline-flex !important;
  align-items: center;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.3;
  gap: 2px !important; /* espacio controlado, ajusta entre 2–4px si lo prefieres */
font-family: "Montserrat", Sans-serif;
    color: #4D4D4D;
    font-weight: 400;
    font-size: 14px;
}

p label input[type="checkbox"] {
  display: inline-block !important;
  vertical-align: middle !important;
  margin: 0 !important;
  padding: 0 !important;
  width: auto !important;
  position: relative;
  top: 0;
}

/* Estilo del botón "Ver más" */
#loadMoreGallery.elementor-button-content-wrapper {
  background-color: #000;
  color: #fff;
  border: none;
  border-radius: 10px;
  padding: 12px 40px;
  font-size: 15px;
  cursor: pointer;
  transition: all 0.3s ease-in-out;
  display: inline-block;
  font-family: inherit;
}
#loadMoreGallery.elementor-button-content-wrapper {
  margin-top: 20px;
}

/*padding over button*/
@media (max-width: 767px) {
  .boton-guion {
    margin-top: 20px !important;
    margin-bottom: 20px !important;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
.origen-title {
    font-family: "Montserrat", Sans-serif;
    font-size: 72px !important;
    font-weight: 800;
    text-align: center;
    line-height: 1.3em;
    letter-spacing: 2px;
    color: #FFFFFF;
}
h1 {
    font-size: 40px !important;
}
.fullwidth_comment_wrapper {
    display: none;
}
.post_info_date {
    display: none;
}
.mobx-title {
    display: none !important; 
}

.post-header h5 a, .post-header h6 a {
    color: #FFFFFF!important;
}

/* Hace que el enlace invisible cubra todo el bloque y sea clicable */
.blog-posts-grid_no_space {
  position: relative;
}
.blog-posts-grid_no_space .post-block-link {
  position: absolute;
  inset: 0;              /* ocupa todo el bloque */
  z-index: 5;            /* encima del fondo */
  display: block;
  text-indent: -9999px;  /* oculta el texto si lo hubiera */
  cursor: pointer;
}
#blog_grid_fullwidth .blog-posts-grid_no_space {
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  display: block !important;
height: 600px;
}

/* Quita efecto de zoom en imagen*/

.blog-posts-grid_no_space::before {
  content: none !important;
}
.blog-posts-grid_no_space {
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: cover !important;
}

/*Newsletter/ 

/* Corrige alineación y elimina espacio excesivo entre checkbox y texto */
p label {
display: flex !important;
  align-items: flex-start;
  flex-wrap: wrap;
  white-space: normal !important;
  line-height: 1.4;
  margin: 0;
  padding: 0;
  text-align: left !important;
  word-break: normal;
  word-wrap: break-word;
 line-height: 1.3;
 font-family: "Montserrat", Sans-serif;
 color: #4D4D4D;
 font-weight: 400;
 font-size: 14px;
}

p label input[type="checkbox"] {
  margin-top: 2px;
  margin-right: 6px;
  flex-shrink: 0;
}

/* Estilo del botón "Ver más" */
#loadMoreGallery.elementor-button-content-wrapper {
  background-color: #000;
  color: #fff;
  border: none;
  border-radius: 10px;
  padding: 12px 40px;
  font-size: 15px;
  cursor: pointer;
  transition: all 0.3s ease-in-out;
  display: inline-block;
  font-family: inherit;
}
#loadMoreGallery.elementor-button-content-wrapper {
  margin-top: 20px;
}}

@media only screen and (max-width: 767px) {
.origen-title {
    font-family: "Montserrat", Sans-serif;
    font-size: 72px !important;
    font-weight: 800;
    text-align: center;
    line-height: 1.3em;
    letter-spacing: 2px;
    color: #FFFFFF;
}
h1 {
    font-size: 40px !important;
}
.fullwidth_comment_wrapper {
    display: none;
}
.post_info_date {
    display: none;
}
.mobx-title {
    display: none !important; 
}

.post-header h5 a, .post-header h6 a {
    color: #FFFFFF!important;
}

/* Hace que el enlace invisible cubra todo el bloque y sea clicable */
.blog-posts-grid_no_space {
  position: relative;
}
.blog-posts-grid_no_space .post-block-link {
  position: absolute;
  inset: 0;              /* ocupa todo el bloque */
  z-index: 5;            /* encima del fondo */
  display: block;
  text-indent: -9999px;  /* oculta el texto si lo hubiera */
  cursor: pointer;
}
#blog_grid_fullwidth .blog-posts-grid_no_space {
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  display: block !important;
height: 600px;
}

/* Quita efecto de zoom en imagen*/

.blog-posts-grid_no_space::before {
  content: none !important;
}
.blog-posts-grid_no_space {
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: cover !important;
}

/*Newsletter/ 

/* Corrige alineación y elimina espacio excesivo entre checkbox y texto */
p label {
display: flex !important;
  align-items: flex-start;
  flex-wrap: wrap;
  white-space: normal !important;
  line-height: 1.4;
  margin: 0;
  padding: 0;
  text-align: left !important;
  word-break: normal;
  word-wrap: break-word;
 line-height: 1.3;
 font-family: "Montserrat", Sans-serif;
 color: #4D4D4D;
 font-weight: 400;
 font-size: 14px;
}

p label input[type="checkbox"] {
  margin-top: 2px;
  margin-right: 6px;
  flex-shrink: 0;
}

/* Estilo del botón "Ver más" */
#loadMoreGallery.elementor-button-content-wrapper {
  background-color: #000;
  color: #fff;
  border: none;
  border-radius: 10px;
  padding: 12px 40px;
  font-size: 15px;
  cursor: pointer;
  transition: all 0.3s ease-in-out;
  display: inline-block;
  font-family: inherit;
}
#loadMoreGallery.elementor-button-content-wrapper {
  margin-top: 20px;
}}

@media only screen and (min-width: 480px) and (max-width: 767px) {
.origen-title {
    font-family: "Montserrat", Sans-serif;
    font-size: 72px !important;
    font-weight: 800;
    text-align: center;
    line-height: 1.3em;
    letter-spacing: 2px;
    color: #FFFFFF;
}
h1 {
    font-size: 40px !important;
}
.fullwidth_comment_wrapper {
    display: none;
}
.post_info_date {
    display: none;
}
.mobx-title {
    display: none !important; 
}

.post-header h5 a, .post-header h6 a {
    color: #FFFFFF!important;
}

/* Hace que el enlace invisible cubra todo el bloque y sea clicable */
.blog-posts-grid_no_space {
  position: relative;
}
.blog-posts-grid_no_space .post-block-link {
  position: absolute;
  inset: 0;              /* ocupa todo el bloque */
  z-index: 5;            /* encima del fondo */
  display: block;
  text-indent: -9999px;  /* oculta el texto si lo hubiera */
  cursor: pointer;
}
#blog_grid_fullwidth .blog-posts-grid_no_space {
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  display: block !important;
height: 600px;
}

/* Quita efecto de zoom en imagen*/

.blog-posts-grid_no_space::before {
  content: none !important;
}
.blog-posts-grid_no_space {
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: cover !important;
}

/*Newsletter/ 

/* Corrige alineación y elimina espacio excesivo entre checkbox y texto */
p label {
display: flex !important;
  align-items: flex-start;
  flex-wrap: wrap;
  white-space: normal !important;
  line-height: 1.4;
  margin: 0;
  padding: 0;
  text-align: left !important;
  word-break: normal;
  word-wrap: break-word;
 line-height: 1.3;
 font-family: "Montserrat", Sans-serif;
 color: #4D4D4D;
 font-weight: 400;
 font-size: 14px;
}

p label input[type="checkbox"] {
  margin-top: 2px;
  margin-right: 6px;
  flex-shrink: 0;
}

/* Estilo del botón "Ver más" */
#loadMoreGallery.elementor-button-content-wrapper {
  background-color: #000;
  color: #fff;
  border: none;
  border-radius: 10px;
  padding: 12px 40px;
  font-size: 15px;
  cursor: pointer;
  transition: all 0.3s ease-in-out;
  display: inline-block;
  font-family: inherit;
}
#loadMoreGallery.elementor-button-content-wrapper {
  margin-top: 20px;
}}

