/* Основной контейнер - кирпичная кладка */
.masonry-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	padding: 16px;
	width: 100%;
	box-sizing: border-box;
	justify-content: flex-start;
	align-items: flex-start;
}

/* Базовый стиль для всех блоков */
.masonry-item {
	display: block;
	flex-shrink: 0;
	background: #fff;
	border-radius: 0;
	overflow: hidden;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.masonry-item:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
}

/* Общие стили для изображений */
.masonry-item img {
	display: block;
	width: auto;
	height: auto;
	max-width: 100%;
	max-height: 100%;
	object-fit: contain; /* Сохраняем пропорции */
}

/* Типы баннеров с разными размерами */

/* Квадратные баннеры (фиксированная ширина) */
.masonry-item.square {
	width: 250px;
  /* Высота автоматическая от содержимого */
}

.masonry-item.square img {
	width: 100%;
	height: auto;
}

/* Горизонтальные баннеры (широкие) */
.masonry-item.horizontal {
	min-width: 200px;
}

.masonry-item.horizontal img {
	width: 100%;
	height: auto;
}

/* Вертикальные баннеры (узкие и высокие) */
.masonry-item.vertical {
	min-width: 240px;
}

.masonry-item.vertical img {
	width: 100%;
	height: auto;
}

/* Адаптивность для разных экранов */
@media (max-width: 1200px) {
	.masonry-item.square {
		width: 220px;
	}
	
	.masonry-item.horizontal {
		min-width: 200px;
	}
	
	.masonry-item.vertical {
		min-width: 240px;
	}
	
	.masonry-grid {
		gap: 14px;
		padding: 14px;
	}
}

@media (max-width: 992px) {
	.masonry-item.square {
		width: 200px;
	}

	.masonry-item.horizontal {
		min-width: 220px;
	}
  
	.masonry-item.vertical {
    	width: 160px;
	}
  
	.masonry-grid {
		gap: 12px;
		padding: 12px;
	}
}

@media (max-width: 768px) {
	.masonry-item.square {
		width: 180px;
	}
  
	.masonry-item.horizontal {
		min-width: 200px;
	}
	
	.masonry-item.vertical {
		min-width: 240px;
	}
	
	.masonry-grid {
		gap: 10px;
		padding: 10px;
		justify-content: center; /* На мобильных центрируем */
	}
}

@media (max-width: 640px) {
	.masonry-item.square {
		width: 160px;
	}
	
	.masonry-item.horizontal {
		min-width: 200px;
	}
	
	.masonry-item.vertical {
		min-width: 240px;
	}
}

@media (max-width: 480px) {
	.masonry-grid {
		gap: 8px;
		padding: 8px;
	}
	
	.masonry-item.square {
		width: calc(50% - 8px);
		min-width: 140px;
	}
	
	.masonry-item.horizontal {
		width: min(290px,100%);
	}
	
	.masonry-item.vertical {
		width: calc(50% - 8px);
		min-width: 240px;
	}
	.masonry-item.original {
		width: min(300px,100%);
	}
}

/* Если нужно добавить баннеры с текстом */
.masonry-item.banner-text {
	background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
	color: white;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	font-weight: bold;
	min-height: 200px;
}

.masonry-item.banner-text p {
	margin: 0;
	padding: 20px;
}

/* Опционально: разные отступы для создания более органичной кладки */
.masonry-item {
	margin-bottom: 0; /* Gap уже обеспечивает отступы */
}

/* Для случаев, когда картинки имеют разное соотношение сторон и нужно сохранить их оригинальные размеры */
.preserve-original {
	display: inline-block;
}

.preserve-original img {
	width: auto;
	height: auto;
	max-width: none; /* Отключаем ограничение по ширине контейнера */
	max-height: none; /* Отключаем ограничение по высоте */
}