.gallery-tabs { display: flex; gap: 0.75rem; margin-bottom: 2rem; justify-content: center; }
.tab-btn {
    padding: 0.5rem 1.25rem; background: transparent;
    border: 1px solid var(--border); border-radius: 8px;
    color: var(--text-secondary); font-size: 0.88rem; cursor: pointer; transition: var(--transition);
}
.tab-btn.active, .tab-btn:hover { background: var(--accent); border-color: var(--accent); color: white; }
.gallery-grid {
    display: grid; grid-template-columns: 2fr 1fr 1fr;
    grid-template-rows: 200px 200px; gap: 1rem;
}
.gallery-item { border-radius: var(--radius); overflow: hidden; position: relative; cursor: pointer; }
.gallery-item.large { grid-row: span 2; }
.gallery-img { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; position: relative; transition: var(--transition); }
.gallery-icon { font-size: 3rem; color: rgba(255,255,255,0.15); }
.gallery-overlay {
    position: absolute; inset: 0; background: rgba(0,0,0,0.6);
    display: flex; align-items: flex-end; justify-content: space-between;
    padding: 1rem; opacity: 0; transition: var(--transition);
}
.gallery-item:hover .gallery-overlay { opacity: 1; }
.gallery-item:hover .gallery-img { transform: scale(1.05); }
.gallery-info h4 { font-size: 0.9rem; font-weight: 600; }
.gallery-info p { font-size: 0.78rem; color: var(--text-secondary); }
.gallery-zoom {
    background: var(--accent); color: white; border: none;
    width: 36px; height: 36px; border-radius: 8px; cursor: pointer;
    font-size: 0.9rem; transition: var(--transition); flex-shrink: 0; align-self: flex-end;
}
.gallery-zoom:hover { background: var(--accent-light); transform: scale(1.1); }
@media (max-width: 768px) {
    .gallery-grid { grid-template-columns: 1fr 1fr; grid-template-rows: auto; }
    .gallery-item.large { grid-row: auto; grid-column: span 2; }
}
@media (max-width: 500px) {
    .gallery-grid { grid-template-columns: 1fr; }
    .gallery-item.large { grid-column: auto; }
}