/* ==========================================================================
   Voxel Elementor Extensions - Advanced Post Feed
   ========================================================================== */

/* --- CSS Custom Properties (defaults) --- */
.vxe-feed-wrapper {
	--vxe-columns: 3;
	--vxe-gap: 20px;
	--vxe-masonry-columns: 3;
	--vxe-row-height: 250px;
}

/* ==========================================================================
   Standard Grid
   ========================================================================== */
.vxe-feed-grid {
	display: grid;
	grid-template-columns: repeat(var(--vxe-columns), 1fr);
	gap: var(--vxe-gap);
}

/* Equal height: stretch items */
.vxe-feed-equal-height .vxe-feed-item,
.vxe-feed-equal-height .ts-preview {
	height: 100%;
}

/* ==========================================================================
   Masonry (CSS columns)
   ========================================================================== */
.vxe-feed-masonry {
	column-count: var(--vxe-masonry-columns);
	column-gap: var(--vxe-gap);
}

.vxe-feed-masonry .vxe-feed-item {
	break-inside: avoid;
	margin-bottom: var(--vxe-gap);
}

/* ==========================================================================
   Interactive Grid (dense packing)
   ========================================================================== */
.vxe-feed-interactive {
	grid-auto-flow: dense;
	grid-auto-rows: var(--vxe-row-height);
}

/* Column spans */
.vxe-feed-item[data-vxe-col="2"] {
	grid-column: span 2;
}

.vxe-feed-item[data-vxe-col="3"] {
	grid-column: span 3;
}

/* Row spans */
.vxe-feed-item[data-vxe-row="2"] {
	grid-row: span 2;
}

.vxe-feed-item[data-vxe-row="3"] {
	grid-row: span 3;
}

/* Make card content fill the span */
.vxe-feed-interactive .vxe-feed-item .ts-preview {
	height: 100%;
}

.vxe-feed-interactive .vxe-feed-item .ts-preview img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* ==========================================================================
   Feed Item (wrapper around Voxel .ts-preview)
   ========================================================================== */
.vxe-feed-item {
	position: relative;
	overflow: hidden;
	will-change: transform;
	transition: border-color 0.3s ease;
}

/* Image container for zoom effect */
.vxe-feed-item .ts-preview img {
	will-change: transform;
}

/* Content reveal: hidden content container */
.vxe-feed-item .vxe-reveal-content {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	transform: translateY(100%);
	will-change: transform;
	pointer-events: none;
	z-index: 2;
}

.vxe-feed-item.vxe-hover-active .vxe-reveal-content {
	pointer-events: auto;
}

/* ==========================================================================
   Entrance Animations (initial hidden state, GSAP animates from here)
   ========================================================================== */
.vxe-feed-item[data-vxe-entrance="fade-up"] {
	opacity: 0;
	transform: translateY(40px);
}

.vxe-feed-item[data-vxe-entrance="fade-in"] {
	opacity: 0;
}

.vxe-feed-item[data-vxe-entrance="scale-up"] {
	opacity: 0;
	transform: scale(0.85);
}

.vxe-feed-item[data-vxe-entrance="slide-in"] {
	opacity: 0;
	transform: translateX(-40px);
}

/* After GSAP animation completes */
.vxe-feed-item.vxe-entrance-done {
	opacity: 1 !important;
	transform: none !important;
}

/* ==========================================================================
   Loading States
   ========================================================================== */
.vxe-feed-wrapper.vxe-feed-loading .vxe-feed-grid {
	pointer-events: none;
	transition: opacity 0.3s ease;
}

/* Skeleton pulse */
.vxe-feed-wrapper.vxe-feed-loading--skeleton .vxe-feed-grid {
	opacity: 1;
}

.vxe-feed-wrapper.vxe-feed-loading--skeleton .vxe-feed-item::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.4) 50%, transparent 100%);
	animation: vxe-skeleton-pulse 1.5s ease-in-out infinite;
	z-index: 10;
	pointer-events: none;
}

@keyframes vxe-skeleton-pulse {
	0% {
		transform: translateX(-100%);
	}
	100% {
		transform: translateX(100%);
	}
}

/* ==========================================================================
   No Results
   ========================================================================== */
.vxe-no-results {
	padding: 40px 20px;
	text-align: center;
}

.vxe-no-results.hidden {
	display: none;
}

.vxe-feed-no-results {
	display: none;
}

/* ==========================================================================
   Pagination
   ========================================================================== */
.vxe-pagination {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 10px;
	margin-top: 30px;
}

.vxe-pagination.hidden {
	display: none;
}

.vxe-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 10px 24px;
	border: 1px solid #ddd;
	background: #fff;
	color: #333;
	font-size: 14px;
	font-weight: 500;
	cursor: pointer;
	border-radius: 6px;
	transition: all 0.2s ease;
	line-height: 1.4;
}

.vxe-btn:hover {
	background: #f5f5f5;
}

.vxe-btn:disabled,
.vxe-btn[disabled] {
	opacity: 0.4;
	cursor: not-allowed;
	pointer-events: none;
}

/* ==========================================================================
   Mobile Touch: active state indicator
   ========================================================================== */
.vxe-feed-item.vxe-touch-active {
	outline: 2px solid currentColor;
	outline-offset: -2px;
}

/* ==========================================================================
   Prefers Reduced Motion
   ========================================================================== */
@media (prefers-reduced-motion: reduce) {
	.vxe-feed-item {
		will-change: auto !important;
		transition: none !important;
	}

	.vxe-feed-item .ts-preview img {
		will-change: auto !important;
	}

	/* Remove entrance animation initial states */
	.vxe-feed-item[data-vxe-entrance] {
		opacity: 1 !important;
		transform: none !important;
	}

	.vxe-feed-wrapper.vxe-feed-loading--skeleton .vxe-feed-item::after {
		animation: none;
	}
}

/* ==========================================================================
   Responsive Fallbacks (Masonry single column on very small screens)
   ========================================================================== */
@media (max-width: 480px) {
	.vxe-feed-masonry {
		column-count: 1 !important;
	}

	/* Interactive grid: collapse spans on very small screens */
	.vxe-feed-interactive .vxe-feed-item[data-vxe-col="2"],
	.vxe-feed-interactive .vxe-feed-item[data-vxe-col="3"] {
		grid-column: span 1;
	}

	.vxe-feed-interactive .vxe-feed-item[data-vxe-row="2"],
	.vxe-feed-interactive .vxe-feed-item[data-vxe-row="3"] {
		grid-row: span 1;
	}
}
