/* ============================================================
   site-v27.css — v1.6.3
   Client logos: crisper rendering, tighter dimensions, balanced sizes
   ============================================================ */

.logo-wall { padding: clamp(24px, 3vw, 40px) 0 !important; }
.logo-marquee { padding: 6px 0 !important; }
.logo-marquee .track { gap: 22px !important; }

/* Tile sizing — fixed pixel widths for visual balance */
.logo-marquee .logo-tile,
.logo-marquee .logo-tile.tile-img,
.logo-marquee .logo-tile.tile-stacked {
  width: 156px !important;
  min-width: 156px !important;
  max-width: 156px !important;
  height: 72px !important;
  padding: 10px 16px !important;
  background: #ffffff !important;
  border: 1px solid rgba(20,33,61,0.08) !important;
  border-radius: 12px !important;
  box-shadow: 0 1px 3px rgba(20,33,61,0.05) !important;
  position: relative !important;
  overflow: hidden !important;
  transition: transform .35s cubic-bezier(.2,.7,.2,1),
              box-shadow .35s,
              border-color .35s !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.logo-marquee .logo-tile.tile-img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(79,142,220,0.0) 0%, rgba(102,179,255,0.08) 100%);
  opacity: 0;
  transition: opacity .35s ease;
  pointer-events: none;
}
.logo-marquee .logo-tile:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 10px 22px -8px rgba(20,33,61,0.18),
              0 0 0 1px rgba(79,142,220,0.20) !important;
  border-color: rgba(79,142,220,0.25) !important;
}
.logo-marquee .logo-tile:hover::before { opacity: 1; }

/* Image rendering — keep crisp without over-stretching */
.logo-marquee .logo-tile img {
  max-height: 44px !important;
  max-width: 124px !important;
  width: auto !important;
  height: auto !important;
  object-fit: contain !important;
  display: block !important;
  filter: none !important;
  /* Better resampling for raster logos */
  image-rendering: auto;
  image-rendering: -webkit-optimize-contrast;
  -ms-interpolation-mode: bicubic;
  /* Anti-aliasing improvement */
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  transform: translateZ(0);
  transition: transform .35s ease !important;
  position: relative;
  z-index: 1;
}
.logo-marquee .logo-tile:hover img {
  transform: translateZ(0) scale(1.04) !important;
}

/* SVG logos render perfectly — give them a little extra room */
.logo-marquee .logo-tile img[src$=".svg"] {
  max-height: 46px !important;
  max-width: 130px !important;
}

/* Wide/horizontal logos that need a bit more width */
.logo-marquee .logo-tile img[alt*="Burlington"],
.logo-marquee .logo-tile img[alt*="Tata"],
.logo-marquee .logo-tile img[alt*="Chandigarh"],
.logo-marquee .logo-tile img[alt*="UNO Minda"],
.logo-marquee .logo-tile img[alt*="Next Education"] {
  max-height: 38px !important;
}

/* Dark-tile (white logo) variant */
.logo-marquee .logo-tile.tile-img.tile-dark {
  background: linear-gradient(135deg, #14213D 0%, #06101c 100%) !important;
  border-color: #14213D !important;
}
.logo-marquee .logo-tile.tile-img.tile-dark img { filter: brightness(1.05) !important; }

/* Stacked text fallback (if any) */
.logo-marquee .logo-tile.tile-stacked {
  flex-direction: column !important;
  gap: 2px !important;
  color: #14213D !important;
}
.logo-marquee .logo-tile.tile-stacked .sub-line {
  color: #4F8EDC !important;
  font-size: 9px !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
}

@media (max-width: 880px) {
  .logo-marquee .logo-tile,
  .logo-marquee .logo-tile.tile-img,
  .logo-marquee .logo-tile.tile-stacked {
    width: 132px !important;
    min-width: 132px !important;
    max-width: 132px !important;
    height: 62px !important;
    padding: 8px 12px !important;
  }
  .logo-marquee .logo-tile img { max-height: 36px !important; max-width: 104px !important; }
  .logo-marquee .logo-tile img[src$=".svg"] { max-height: 38px !important; max-width: 108px !important; }
}
