/* Animaciones y estilos modernos para la página de inicio */

.hero-animate {
  animation: heroFadeIn 1.2s cubic-bezier(.4,0,.2,1) both;
}
@keyframes heroFadeIn {
  0% { opacity: 0; transform: translateY(40px) scale(0.98); }
  100% { opacity: 1; transform: none; }
}

.cta-pulse {
  animation: ctaPulse 1.5s infinite alternate;
}
@keyframes ctaPulse {
  0% { box-shadow: 0 0 0 0 rgba(13,110,253,0.3); }
  100% { box-shadow: 0 0 0 16px rgba(13,110,253,0); }
}

.card-animate {
  opacity: 0;
  transform: translateY(30px) scale(0.98);
  transition: all 0.7s cubic-bezier(.4,0,.2,1);
}
.card-animate.visible {
  opacity: 1;
  transform: none;
}

.carousel-fade .carousel-item {
  opacity: 0;
  transition: opacity 0.7s ease-in-out;
}
.carousel-fade .carousel-item.active {
  opacity: 1;
  z-index: 2;
}

/* Overlay para carousel */
.carousel-caption {
  background: rgba(0,0,0,0.45);
  border-radius: 1rem;
  padding: 1.5rem 2rem;
  backdrop-filter: blur(2px);
}

/* Sección about asimétrica */
@media (min-width: 992px) {
  .about-section .row {
    flex-direction: row-reverse;
  }
}

/* Botón CTA animado */
.cta-section .btn-lg {
  font-size: 1.3rem;
  padding: 0.9rem 2.5rem;
  border-radius: 2rem;
}

/* Tarjetas de servicios */
.services-section .card {
  border: none;
  border-radius: 1.5rem;
  box-shadow: 0 4px 32px 0 rgba(13,110,253,0.08);
  transition: transform 0.3s, box-shadow 0.3s;
}
.services-section .card:hover {
  transform: translateY(-8px) scale(1.03);
  box-shadow: 0 8px 40px 0 rgba(13,110,253,0.18);
}

/* General */
section {
  scroll-margin-top: 80px;
}

/* Icon strip redesigned (fix horizontal layout) */
.icon-strip { padding:80px 0; }
@media (max-width:1200px){ .icon-strip { padding:70px 0; } }
@media (max-width:992px){ .icon-strip { padding:64px 0; } }
@media (max-width:768px){ .icon-strip { padding:56px 0; } }
@media (max-width:576px){ .icon-strip { padding:48px 0; } }
.icon-strip-row { display:flex; flex-wrap:wrap; justify-content:space-between; align-items:flex-start; gap:2rem; }
.icon-strip-row .icon-item { flex:0 0 18%; max-width:18%; display:flex; flex-direction:column; align-items:center; text-align:center; }
.icon-strip-row .icon-item .icon-svg { max-height:48px; width:auto; margin-bottom:18px; display:block; }
.icon-strip-row .icon-item .icon-text { margin:0; font-size:14px; line-height:1.3; font-weight:500; }
@media (max-width:1200px){ .icon-strip-row .icon-item { flex:0 0 19%; max-width:19%; } }
@media (max-width:992px){ .icon-strip-row .icon-item { flex:0 0 33.33%; max-width:33.33%; } }
@media (max-width:576px){ .icon-strip-row .icon-item { flex:0 0 50%; max-width:50%; } }

/* Masonry grid section for home page */
.masonry-section {
  margin-top: 2rem;
  margin-bottom: 2rem;
}
.masonry-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
}
.masonry-item {
  position: relative;
  min-height: 140px;
  height: 180px;
  flex: 1 1 220px;
  max-width: 100%;
  overflow: hidden;
  border-radius: 12px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.10);
}
.masonry-link {
  display: block;
  width: 100%;
  height: 100%;
  text-decoration: none;
  position: relative;
}
.masonry-img {
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  filter: brightness(0.75);
  transition: filter 0.3s;
}
.masonry-link:hover .masonry-img {
  filter: brightness(0.95);
}
.masonry-title {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: #fff;
  font-size: 1.25rem;
  font-weight: 700;
  text-align: center;
  text-shadow: 0 2px 8px rgba(0,0,0,0.35);
  letter-spacing: 0.5px;
  padding: 0.5rem 1rem;
  background: rgba(0,0,0,0.18);
  border-radius: 8px;
}
@media (min-width: 768px) {
  .masonry-item { height: 180px; }
  .masonry-title { font-size: 1.35rem; }
}
@media (min-width: 1200px) {
  .masonry-item { height: 210px; }
  .masonry-title { font-size: 1.5rem; }
}
