/* GALLERY (cards with image + bottom overlay text) */

.gallery-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.gallery-card{
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  border: 1px solid var(--border);
  background: var(--card);
  box-shadow: var(--shadow);
  min-height: 280px;
}

.gallery-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
  transform: scale(1.02);
}

.gallery-overlay{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding: 18px 18px 16px;
  background: linear-gradient(
    to top,
    rgba(0,0,0,.72) 0%,
    rgba(0,0,0,.22) 55%,
    rgba(0,0,0,0) 100%
  );
}

.gallery-overlay h3{
  margin:0 0 6px;
  font-size: 22px;
  font-weight: 1000;
  color: #fff;
  text-shadow: 0 8px 30px rgba(0,0,0,.45);
}

.gallery-overlay p{
  margin:0;
  color: rgba(255,255,255,.82);
  line-height: 1.55;
}

/* hover (opsiyonel, güzel durur) */
.gallery-card:hover .gallery-img{
  transform: scale(1.06);
  transition: transform .35s ease;
}

/* responsive */
@media (max-width: 900px){
  .gallery-grid{ grid-template-columns: 1fr; }
  .gallery-card{ min-height: 240px; }
}
