/* PAE Image Card */
.pae-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.pae-image-card {
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  position: relative;
}
.pae-image-card:hover { transform: translateY(-6px); box-shadow: 0 16px 48px rgba(79,70,229,0.14); }
.pae-card-image-wrap { position: relative; height: 260px; overflow: hidden; }
.pae-card-image-wrap img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.5s ease; }
.pae-image-card:hover .pae-card-image-wrap img { transform: scale(1.05); }
.pae-card-tag { position: absolute; top: 12px; left: 12px; z-index: 3; background: var(--pae-primary); color: #fff; padding: 3px 12px; border-radius: 100px; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; }
.pae-card-overlay { position: absolute; inset: 0; z-index: 2; display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity 0.35s ease; }
.pae-card-style-overlay-reveal .pae-image-card:hover .pae-card-overlay { opacity: 1; }
.pae-card-overlay-content { padding: 24px; text-align: center; color: #fff; display: flex; flex-direction: column; gap: 10px; align-items: center; }
.pae-card-style-hover-slide-up .pae-card-overlay { align-items: flex-end; transform: translateY(100%); opacity: 1; transition: transform 0.38s ease; }
.pae-card-style-hover-slide-up .pae-image-card:hover .pae-card-overlay { transform: translateY(0); }
.pae-card-content { padding: 20px; }
.pae-card-title { font-size: 17px; font-weight: 700; color: #1e1e2e; margin: 0 0 8px; }
.pae-overlay-title { color: #fff; }
.pae-card-desc  { font-size: 14px; line-height: 1.65; color: #64748b; margin: 0 0 12px; }
.pae-overlay-desc { color: rgba(255,255,255,0.9); }
.pae-card-cta   { font-size: 13px; font-weight: 600; color: var(--pae-primary); text-decoration: none; display: inline-flex; align-items: center; gap: 4px; }
.pae-cta-overlay { color: #fff; border: 1.5px solid rgba(255,255,255,0.6); padding: 7px 18px; border-radius: 6px; }
.pae-cta-overlay:hover { background: rgba(255,255,255,0.15); color: #fff; border-color: #fff; }
@media (max-width: 1024px) { .pae-cards-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .pae-cards-grid { grid-template-columns: 1fr; } }
