.gallery-tabs { display: flex; justify-content: center; gap: 8px; margin-bottom: 50px; flex-wrap: wrap; }
.gallery-tabs .tab {
  padding: 10px 24px; border-radius: 50px; border: 1px solid var(--line);
  color: var(--muted); font-weight: 500; cursor: pointer;
  transition: all var(--transition);
  font-size: 12px; letter-spacing: 1.4px; text-transform: uppercase;
}
.gallery-tabs .tab:hover, .gallery-tabs .tab.active {
  background: var(--primary); color: #fff; border-color: var(--primary);
}

.gallery-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.gallery-item {
  border-radius: var(--radius); overflow: hidden; background: #fff;
  transition: all var(--transition);
  position: relative; cursor: pointer;
  aspect-ratio: 4/3;
}
.gallery-item img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.9s var(--ease-out);
}
.gallery-item:hover img { transform: scale(1.08); }
.gallery-item figcaption {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(6,28,41,0.92) 100%);
  color: #fff; display: flex; align-items: flex-end;
  padding: 24px; opacity: 0; transition: opacity var(--transition);
}
.gallery-item:hover figcaption { opacity: 1; }
.gallery-item figcaption small {
  color: var(--copper-light); font-size: 11px; letter-spacing: 2.5px;
  text-transform: uppercase; display: block; margin-bottom: 6px;
}
.gallery-item figcaption strong {
  display: block; color: #fff; font-family: 'Playfair Display', serif;
  font-size: 22px; font-weight: 500; letter-spacing: -0.01em;
}

@media (max-width: 900px) { .gallery-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px) { .gallery-grid { grid-template-columns: 1fr; } }
