/* ═══════════════════════════════════════════
   GALERÍA
═══════════════════════════════════════════ */
#galeria { background: var(--c-cream); }

.gallery-header {
  display: flex; justify-content: space-between; align-items: flex-end;
  margin-bottom: var(--sp-lg); flex-wrap: wrap; gap: 20px;
}
.gallery-grid {
  display: grid; grid-template-columns: repeat(12, 1fr); gap: 16px;
}
.gallery-item {
  border-radius: var(--radius-md); overflow: hidden;
  position: relative; background: #e8dfd4; cursor: pointer;
}
.gallery-item--1 { grid-column: span 7; aspect-ratio: 1; }
.gallery-item--2 { grid-column: span 5; aspect-ratio: 1; }
.gallery-item--3 { grid-column: span 4; aspect-ratio: 1; }
.gallery-item--4 { grid-column: span 4; aspect-ratio: 1; }
.gallery-item--5 { grid-column: span 4; aspect-ratio: 1; }

@media (max-width: 768px) {
  .gallery-grid           { grid-template-columns: 1fr 1fr; }
  .gallery-item--1        { grid-column: span 2; aspect-ratio: 1; }
  .gallery-item--2        { grid-column: span 2; aspect-ratio: 1; }
  .gallery-item--3,
  .gallery-item--4,
  .gallery-item--5        { grid-column: span 1; aspect-ratio: 1; }
}

.gallery-item-inner {
  width: 100%; height: 100%;
  background: linear-gradient(135deg, #e8dfd4 0%, #d4c8b8 100%);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px;
  position: relative; overflow: hidden;
  transition: transform 0.5s cubic-bezier(0.4,0,0.2,1);
}
.gallery-item:hover .gallery-item-inner { transform: scale(1.03); }
.gallery-item-inner img { width: 100%; height: 100%; object-fit: cover; }
.gallery-item-inner svg { width: 36px; height: 36px; color: var(--c-muted); opacity: 0.4; }
.gallery-placeholder-text { font-size: 10px; letter-spacing: 3px; text-transform: uppercase; color: var(--c-muted); opacity: 0.6; font-family: var(--f-sans); }

.gallery-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(14,14,14,0.7) 100%);
  opacity: 0; transition: opacity var(--transition);
  display: flex; align-items: flex-end; padding: 20px;
}
.gallery-item:hover .gallery-overlay { opacity: 1; }
.gallery-overlay-text { font-family: var(--f-sans); font-size: 11px; font-weight: 500; letter-spacing: 2px; text-transform: uppercase; color: var(--c-white); }