/* =========================
   GALERÍA - LOGOS
========================= */

.galeria-logos {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 12% 18%, rgba(79, 111, 255, 0.07), transparent 34%),
    radial-gradient(circle at 88% 26%, rgba(216, 95, 255, 0.07), transparent 36%),
    linear-gradient(180deg, #f8fbff 0%, #fffaf0 52%, #f8fbff 100%);
}

.galeria-logos-bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 0;
}

.galeria-logos-glow {
  position: absolute;
  display: block;
  border-radius: 999px;
  filter: blur(46px);
  opacity: 0.72;
}

.galeria-logos-glow-one {
  width: 340px;
  height: 340px;
  left: -120px;
  top: 14%;
  background: rgba(79, 111, 255, 0.13);
}

.galeria-logos-glow-two {
  width: 380px;
  height: 380px;
  right: -150px;
  bottom: 6%;
  background: rgba(216, 95, 255, 0.12);
}

.galeria-logos .container {
  position: relative;
  z-index: 1;
}

/* =========================
   LOGOS WALL
========================= */

.galeria-logos-board {
  position: relative;
  display: grid;
  align-items: center;
  overflow: hidden;
  min-height: 430px;
  padding: clamp(42px, 5vw, 72px) clamp(28px, 5vw, 70px);
  border-radius: 36px;
  background:
    radial-gradient(circle at 12% 20%, rgba(79, 111, 255, 0.055), transparent 32%),
    radial-gradient(circle at 88% 78%, rgba(216, 95, 255, 0.055), transparent 34%),
    linear-gradient(135deg, rgba(255, 250, 235, 0.92), rgba(255, 255, 255, 0.70)),
    rgba(255, 250, 235, 0.78);
  border: 1px solid rgba(99, 102, 241, 0.08);
  box-shadow:
    0 30px 90px rgba(15, 23, 42, 0.07),
    inset 0 1px 0 rgba(255, 255, 255, 0.82);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.galeria-logos-board::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(115deg, rgba(255, 255, 255, 0.40), transparent 32%),
    radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.30), transparent 52%);
  opacity: 0.75;
}

.galeria-logos-board.is-balanced {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(58px, 7vw, 104px) clamp(42px, 7vw, 100px);
}

.galeria-logos-board.is-dense {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(44px, 5vw, 78px) clamp(34px, 5vw, 72px);
}

.galeria-logo-item {
  position: relative;
  z-index: 1;
  min-height: 98px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px;
  border-radius: 24px;
  transition:
    transform 0.28s ease,
    filter 0.28s ease,
    opacity 0.28s ease;
}

.galeria-logo-item::before {
  content: "";
  position: absolute;
  inset: -14px;
  border-radius: 28px;
  background:
    radial-gradient(circle at 50% 50%, rgba(79, 111, 255, 0.10), transparent 64%),
    radial-gradient(circle at 64% 62%, rgba(216, 95, 255, 0.08), transparent 58%);
  opacity: 0;
  transform: scale(0.92);
  transition:
    opacity 0.28s ease,
    transform 0.28s ease;
}

.galeria-logo-item:hover {
  transform: translateY(-4px) scale(1.055);
  filter:
    drop-shadow(0 18px 24px rgba(15, 23, 42, 0.10))
    drop-shadow(0 0 22px rgba(124, 58, 237, 0.10));
}

.galeria-logo-item:hover::before {
  opacity: 1;
  transform: scale(1);
}

.galeria-logo-item img {
  position: relative;
  z-index: 2;
  display: block;
  width: auto;
  max-width: 100%;
  max-height: 82px;
  object-fit: contain;
  filter: drop-shadow(0 10px 14px rgba(15, 23, 42, 0.06));
  transition:
    transform 0.28s ease,
    filter 0.28s ease,
    opacity 0.28s ease;
}

.galeria-logo-item:hover img {
  filter: drop-shadow(0 16px 22px rgba(15, 23, 42, 0.10));
}

.galeria-logo-item span {
  position: relative;
  z-index: 2;
  display: inline-block;
  color: transparent;
  text-align: center;
  font-size: clamp(20px, 2vw, 28px);
  line-height: 1.05;
  font-weight: 900;
  letter-spacing: -0.8px;
  background: linear-gradient(115deg, #3158ff 0%, #7c3aed 48%, #d946ef 100%);
  -webkit-background-clip: text;
  background-clip: text;
}

/* =========================
   RESPONSIVE
========================= */

@media (max-width: 1100px) {
  .galeria-logos-board.is-balanced,
  .galeria-logos-board.is-dense {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .galeria-logos-board {
    min-height: 390px;
  }
}

@media (max-width: 760px) {
  .galeria-logos-board.is-balanced,
  .galeria-logos-board.is-dense {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 44px 32px;
  }

  .galeria-logos-board {
    min-height: auto;
    padding: 40px 24px;
    border-radius: 30px;
  }

  .galeria-logo-item {
    min-height: 86px;
  }

  .galeria-logo-item img {
    max-height: 68px;
  }
}

@media (max-width: 520px) {
  .galeria-logos-board.is-balanced,
  .galeria-logos-board.is-dense {
    grid-template-columns: 1fr;
    gap: 38px;
  }

  .galeria-logos-board {
    padding: 38px 24px;
  }

  .galeria-logo-item {
    min-height: 78px;
  }

  .galeria-logo-item img {
    max-width: 82%;
    max-height: 62px;
  }
}