.elementor-13322 .elementor-element.elementor-element-f98ad83:not(.elementor-motion-effects-element-type-background), .elementor-13322 .elementor-element.elementor-element-f98ad83 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://infrakonsulteuropa.eu/wp-content/uploads/2025/11/hidrhulica-cabecera.jpg");background-position:center center;background-size:cover;}.elementor-13322 .elementor-element.elementor-element-f98ad83 > .elementor-container{min-height:489px;}.elementor-13322 .elementor-element.elementor-element-f98ad83 > .elementor-background-overlay{opacity:1;transition:background 0.3s, border-radius 0.3s, opacity 0.3s;}.elementor-13322 .elementor-element.elementor-element-f98ad83{transition:background 0.3s, border 0.3s, border-radius 0.3s, box-shadow 0.3s;}.elementor-13322 .elementor-element.elementor-element-2f6aeb9 > .elementor-background-overlay{background-image:url("https://infrakonsulteuropa.eu/wp-content/uploads/2025/10/construction01_about_us_background.jpg");background-size:cover;opacity:1;}.elementor-13322 .elementor-element.elementor-element-2f6aeb9 > .elementor-container{min-height:600px;}.elementor-13322 .elementor-element.elementor-element-c40744c{padding:2% 0% 2% 0%;}.elementor-widget-text-editor{color:var( --e-global-color-text );}.elementor-widget-text-editor.elementor-drop-cap-view-stacked .elementor-drop-cap{background-color:var( --e-global-color-primary );}.elementor-widget-text-editor.elementor-drop-cap-view-framed .elementor-drop-cap, .elementor-widget-text-editor.elementor-drop-cap-view-default .elementor-drop-cap{color:var( --e-global-color-primary );border-color:var( --e-global-color-primary );}.elementor-13322 .elementor-element.elementor-element-4665a6c7 > .elementor-widget-container{margin:0% 0% -9% 0%;padding:0px 0px 0px 0px;}.elementor-13322 .elementor-element.elementor-element-4665a6c7{font-size:15px;font-weight:500;text-transform:uppercase;color:var( --e-global-color-9166ebe );}.elementor-widget-heading .elementor-heading-title{color:var( --e-global-color-primary );}.elementor-13322 .elementor-element.elementor-element-5768e66 .elementor-heading-title{font-size:40px;font-weight:700;line-height:45px;color:var( --e-global-color-ad440b5 );}.elementor-widget-divider{--divider-color:var( --e-global-color-secondary );}.elementor-widget-divider .elementor-divider__text{color:var( --e-global-color-secondary );}.elementor-widget-divider.elementor-view-stacked .elementor-icon{background-color:var( --e-global-color-secondary );}.elementor-widget-divider.elementor-view-framed .elementor-icon, .elementor-widget-divider.elementor-view-default .elementor-icon{color:var( --e-global-color-secondary );border-color:var( --e-global-color-secondary );}.elementor-widget-divider.elementor-view-framed .elementor-icon, .elementor-widget-divider.elementor-view-default .elementor-icon svg{fill:var( --e-global-color-secondary );}.elementor-13322 .elementor-element.elementor-element-53ddab4{--divider-border-style:solid;--divider-color:var( --e-global-color-9166ebe );--divider-border-width:4.2px;}.elementor-13322 .elementor-element.elementor-element-53ddab4 .elementor-divider-separator{width:20%;}.elementor-13322 .elementor-element.elementor-element-53ddab4 .elementor-divider{padding-block-start:6px;padding-block-end:6px;}.elementor-13322 .elementor-element.elementor-element-3e4f447 > .elementor-widget-container{margin:0% 35% 0% 0%;}.elementor-13322 .elementor-element.elementor-element-3e4f447{font-size:20px;font-weight:400;text-transform:uppercase;color:var( --e-global-color-ad440b5 );}.elementor-13322 .elementor-element.elementor-element-de02d8b{color:var( --e-global-color-ad440b5 );}.elementor-13322 .elementor-element.elementor-element-88061fe{margin-top:-6%;margin-bottom:5%;}.elementor-widget-gallery{--galleries-title-color-normal:var( --e-global-color-primary );--galleries-title-color-hover:var( --e-global-color-secondary );--galleries-pointer-bg-color-hover:var( --e-global-color-accent );--gallery-title-color-active:var( --e-global-color-secondary );--galleries-pointer-bg-color-active:var( --e-global-color-accent );}.elementor-13322 .elementor-element.elementor-element-03b7a48 .e-gallery-item:hover .elementor-gallery-item__overlay, .elementor-13322 .elementor-element.elementor-element-03b7a48 .e-gallery-item:focus .elementor-gallery-item__overlay{background-color:rgba(0,0,0,0.5);}.elementor-13322 .elementor-element.elementor-element-03b7a48{--image-transition-duration:800ms;--overlay-transition-duration:800ms;--content-text-align:center;--content-padding:20px;--content-transition-duration:800ms;--content-transition-delay:800ms;}.elementor-13322 .elementor-element.elementor-element-1c7b587:not(.elementor-motion-effects-element-type-background), .elementor-13322 .elementor-element.elementor-element-1c7b587 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:var( --e-global-color-ad440b5 );background-image:url("https://infrakonsulteuropa.eu/wp-content/uploads/2025/10/fondo-proyectos.jpg");}.elementor-13322 .elementor-element.elementor-element-1c7b587 > .elementor-container{min-height:326px;}.elementor-13322 .elementor-element.elementor-element-1c7b587{transition:background 0.3s, border 0.3s, border-radius 0.3s, box-shadow 0.3s;}.elementor-13322 .elementor-element.elementor-element-1c7b587 > .elementor-background-overlay{transition:background 0.3s, border-radius 0.3s, opacity 0.3s;}.elementor-13322 .elementor-element.elementor-element-e635ff1{text-align:center;}.elementor-13322 .elementor-element.elementor-element-e635ff1 .elementor-heading-title{font-size:40px;font-weight:700;line-height:45px;color:#FFFFFF;}.elementor-13322 .elementor-element.elementor-element-d4e6e88{--divider-border-style:solid;--divider-color:var( --e-global-color-9166ebe );--divider-border-width:5px;}.elementor-13322 .elementor-element.elementor-element-d4e6e88 .elementor-divider-separator{width:5%;margin:0 auto;margin-center:0;}.elementor-13322 .elementor-element.elementor-element-d4e6e88 .elementor-divider{text-align:center;padding-block-start:6px;padding-block-end:6px;}.elementor-13322 .elementor-element.elementor-element-677c1d65 > .elementor-container{min-height:522px;}.elementor-13322 .elementor-element.elementor-element-677c1d65{margin-top:0px;margin-bottom:0px;padding:0px 0px 0px 0px;}.elementor-widget-portfolio a .elementor-portfolio-item__overlay{background-color:var( --e-global-color-accent );}.elementor-widget-portfolio .elementor-portfolio__filter{color:var( --e-global-color-text );}.elementor-widget-portfolio .elementor-portfolio__filter.elementor-active{color:var( --e-global-color-primary );}.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-post__thumbnail__link{padding-bottom:calc( 1 * 100% );}.elementor-13322 .elementor-element.elementor-element-2fcc15:after{content:"1";position:absolute;color:transparent;}.elementor-13322 .elementor-element.elementor-element-2fcc15 > .elementor-widget-container{padding:0% 0% 0% 0%;}.elementor-13322 .elementor-element.elementor-element-2fcc15 a .elementor-portfolio-item__overlay{background-color:#FF802A00;}.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item__title{font-size:30px;}.elementor-13322 .elementor-element.elementor-element-7d7f918:not(.elementor-motion-effects-element-type-background), .elementor-13322 .elementor-element.elementor-element-7d7f918 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:var( --e-global-color-9166ebe );}.elementor-13322 .elementor-element.elementor-element-7d7f918 > .elementor-container{min-height:185px;}.elementor-13322 .elementor-element.elementor-element-7d7f918{transition:background 0.3s, border 0.3s, border-radius 0.3s, box-shadow 0.3s;padding:1% 15% 1% 5%;}.elementor-13322 .elementor-element.elementor-element-7d7f918 > .elementor-background-overlay{transition:background 0.3s, border-radius 0.3s, opacity 0.3s;}.elementor-13322 .elementor-element.elementor-element-d7f08a9 > .elementor-element-populated{padding:0% 0% 0% 0%;}.elementor-13322 .elementor-element.elementor-element-a4a16e1 > .elementor-widget-container{padding:0% 0% 0% 0%;}.elementor-13322 .elementor-element.elementor-element-a4a16e1{text-align:left;}.elementor-13322 .elementor-element.elementor-element-a4a16e1 .elementor-heading-title{font-size:30px;font-weight:700;text-transform:uppercase;line-height:45px;color:#FFFFFF;}.elementor-13322 .elementor-element.elementor-element-a3b7af4 > .elementor-element-populated{padding:18% 18% 18% 18%;}.elementor-widget-button .elementor-button{background-color:var( --e-global-color-accent );}.elementor-13322 .elementor-element.elementor-element-dc28dc1 .elementor-button{background-color:#E9613100;font-weight:700;text-transform:uppercase;border-style:solid;border-radius:0px 0px 0px 0px;padding:15px 15px 15px 15px;}.elementor-13322 .elementor-element.elementor-element-dc28dc1 .elementor-button:hover, .elementor-13322 .elementor-element.elementor-element-dc28dc1 .elementor-button:focus{background-color:var( --e-global-color-6a8d00f );color:#000000;}.elementor-13322 .elementor-element.elementor-element-dc28dc1 > .elementor-widget-container{margin:0% 0% 0% 0%;}.elementor-13322 .elementor-element.elementor-element-dc28dc1 .elementor-button-content-wrapper{flex-direction:row-reverse;}.elementor-13322 .elementor-element.elementor-element-dc28dc1 .elementor-button:hover svg, .elementor-13322 .elementor-element.elementor-element-dc28dc1 .elementor-button:focus svg{fill:#000000;}@media(max-width:1024px){.elementor-13322 .elementor-element.elementor-element-dc28dc1 > .elementor-widget-container{margin:0% 0% 0% 5%;padding:0px 0px 0px 0px;}.elementor-13322 .elementor-element.elementor-element-dc28dc1{z-index:2;}}@media(max-width:767px){.elementor-13322 .elementor-element.elementor-element-f98ad83:not(.elementor-motion-effects-element-type-background), .elementor-13322 .elementor-element.elementor-element-f98ad83 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-position:-279px 0px;}.elementor-13322 .elementor-element.elementor-element-2f6aeb9 > .elementor-background-overlay{background-position:-800px 0px;}.elementor-13322 .elementor-element.elementor-element-4665a6c7 > .elementor-widget-container{margin:0% 0% -13% 0%;}.elementor-13322 .elementor-element.elementor-element-3e4f447 > .elementor-widget-container{margin:0% 0% 0% 0%;}.elementor-13322 .elementor-element.elementor-element-1c7b587 > .elementor-container{min-height:200px;}.elementor-13322 .elementor-element.elementor-element-d4e6e88 .elementor-divider-separator{width:25%;}.elementor-13322 .elementor-element.elementor-element-7d7f918{padding:10% 10% 10% 10%;}.elementor-13322 .elementor-element.elementor-element-dc28dc1 > .elementor-widget-container{margin:0% 0% 0% 0%;}.elementor-13322 .elementor-element.elementor-element-dc28dc1{z-index:1;}}@media(min-width:768px){.elementor-13322 .elementor-element.elementor-element-d7f08a9{width:75.545%;}.elementor-13322 .elementor-element.elementor-element-a3b7af4{width:24.299%;}}/* Start custom CSS for portfolio, class: .elementor-element-2fcc15 *//* ============================================
   ESTILO AVANZADO PARA PORTFOLIO ELEMENTOR
   ============================================ */

/* 1. CONTENEDOR GENERAL DEL PORTFOLIO */
.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio {
  padding: 0;
  margin: 0;
}

/* 2. ITEM INDIVIDUAL DEL PORTFOLIO */
.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item {
  position: relative;
  overflow: hidden;
  border-radius: 0;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.2);
}

/* 3. IMAGEN DEL PORTFOLIO - SIN EFECTOS */
.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item__img {
  transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: none;
}

/* HOVER: SOLO ZOOM SIN EFECTOS DE COLOR */
.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item:hover .elementor-portfolio-item__img {
  transform: scale(1.15);
  filter: none;
}

/* 4. OVERLAY - TRANSPARENTE EN ESTADO NORMAL */
.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item__overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: transparent; /* ← COMPLETAMENTE TRANSPARENTE */
  opacity: 1;
  transition: all 0.4s ease;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  flex-direction: column;
  padding-bottom: 30px;
}

/* OVERLAY EN HOVER: Aparece el gradiente oscuro */
.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item:hover .elementor-portfolio-item__overlay {
  background: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.8) 100%
  );
}

/* 5. TÍTULO DEL PROYECTO */
.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item__title {
  color: #ffffff;
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 0;
  padding-bottom: 15px;
  transform: translateY(0);
  opacity: 1;
  transition: all 0.4s ease;
  text-align: center;
  padding-left: 20px;
  padding-right: 20px;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
  position: relative;
  text-transform: uppercase;
  letter-spacing: 2px;
}

/* Línea debajo del título */
.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item__title::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 60px;
  height: 2px;
  background-color: #ffffff;
  transition: all 0.4s ease;
}

.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item:hover .elementor-portfolio-item__title {
  transform: translateY(-10px);
  opacity: 1;
}

.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item:hover .elementor-portfolio-item__title::after {
  width: 100px;
}

/* 6. DESCRIPCIÓN/CATEGORÍA */
.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item__description,
.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item__meta {
  color: rgba(255, 255, 255, 0.9);
  font-size: 0.95rem;
  transform: translateY(20px);
  opacity: 0;
  transition: all 0.4s ease 0.2s;
  text-align: center;
  padding: 0 20px;
  margin-top: 15px;
}

.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item:hover .elementor-portfolio-item__description,
.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item:hover .elementor-portfolio-item__meta {
  transform: translateY(0);
  opacity: 1;
}

/* 7. BOTÓN/ENLACE DEL PORTFOLIO */
.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item__link {
  position: absolute;
  bottom: 30px;
  left: 50%;
  transform: translateX(-50%) translateY(30px);
  opacity: 0;
  background: #ffffff;
  color: #6366f1;
  padding: 12px 30px;
  border-radius: 50px;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.4s ease 0.3s;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
}

.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item:hover .elementor-portfolio-item__link {
  transform: translateX(-50%) translateY(0);
  opacity: 1;
}

.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item__link:hover {
  background: #4f46e5;
  color: #ffffff;
  transform: translateX(-50%) translateY(-3px);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.3);
}

/* 8. EFECTO DE BRILLO EN HOVER */
.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.3),
    transparent
  );
  transition: left 0.6s ease;
  z-index: 1;
  pointer-events: none;
}

.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item:hover::before {
  left: 100%;
}

/* 9. CATEGORÍAS/TAGS */
.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item__tags {
  position: absolute;
  top: 15px;
  right: 15px;
  display: flex;
  gap: 8px;
  z-index: 2;
}

.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item__tag {
  background: rgba(255, 255, 255, 0.95);
  color: #1f2937;
  padding: 6px 12px;
  border-radius: 20px;
  font-size: 0.75rem;
  font-weight: 600;
  backdrop-filter: blur(10px);
  transition: all 0.3s ease;
}

.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item__tag:hover {
  background: #6366f1;
  color: #ffffff;
  transform: scale(1.05);
}

/* 10. RESPONSIVE - TABLET */
@media (max-width: 1024px) {
  .elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item__title {
    font-size: 1.3rem;
  }
  
  .elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item__link {
    padding: 10px 24px;
    font-size: 0.9rem;
  }
}

/* 11. RESPONSIVE - MÓVIL */
@media (max-width: 768px) {
  .elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item:hover {
    transform: translateY(-4px);
  }
  
  .elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item__title {
    font-size: 1.1rem;
    transform: translateY(0);
    opacity: 1;
  }
  
  .elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item__link {
    bottom: 20px;
    padding: 8px 20px;
    font-size: 0.85rem;
  }
}

/* 12. ANIMACIÓN DE ENTRADA (opcional) */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item {
  animation: fadeInUp 0.6s ease forwards;
}

/* Retraso secuencial para múltiples items */
.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item:nth-child(1) { animation-delay: 0.1s; }
.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item:nth-child(2) { animation-delay: 0.2s; }
.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item:nth-child(3) { animation-delay: 0.3s; }
.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item:nth-child(4) { animation-delay: 0.4s; }
.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item:nth-child(5) { animation-delay: 0.5s; }
.elementor-13322 .elementor-element.elementor-element-2fcc15 .elementor-portfolio-item:nth-child(6) { animation-delay: 0.6s; }/* End custom CSS */