/**
 * Query Block Layouts - Unified Styles
 * Styles for Grid, Carousel, and Side-by-Side query block layouts
 *
 * @package Sierra_At_Tahoe
 */

/* ==========================================================================
   Base Query Block Styles
   ========================================================================== */

.wp-block-query {
	position: relative;
}

/* ==========================================================================
   Grid Layout
   ========================================================================== */

.wp-block-query.sierra-layout-grid .wp-block-post-template {
	display: grid;
	grid-template-columns: repeat(var(--grid-columns, 3), 1fr);
	gap: var(--wp--preset--spacing--40, 1.5rem);
}

.wp-block-query.sierra-layout-grid .wp-block-post-template > * {
	margin: 0;
}

/* Responsive grid */
@media (max-width: 1024px) {
	.wp-block-query.sierra-layout-grid .wp-block-post-template {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 768px) {
	.wp-block-query.sierra-layout-grid .wp-block-post-template {
		grid-template-columns: 1fr;
	}
}

/* ==========================================================================
   Carousel Layout
   ========================================================================== */

.wp-block-query.sierra-layout-carousel {
	position: relative;
}

.wp-block-query.sierra-layout-carousel .sierra-carousel-wrapper {
	width: 100%;
	overflow: hidden;
	position: relative;
}

.wp-block-query.sierra-layout-carousel .carousel-slides {
	display: flex;
	transition: transform 0.3s ease-in-out;
	will-change: transform;
}

.wp-block-query.sierra-layout-carousel .carousel-slide {
	flex: 0 0 auto;
	width: calc(100% / var(--slides-to-show, 3) - var(--wp--preset--spacing--30, 1rem));
	margin-right: var(--wp--preset--spacing--30, 1rem);
}

.wp-block-query.sierra-layout-carousel .carousel-slide:last-child {
	margin-right: 0;
}

/* Carousel filtered state */
.wp-block-query.sierra-layout-carousel .carousel-slide .filtered-out {
	display: none !important;
}

.wp-block-query.sierra-layout-carousel .carousel-no-results {
	min-height: 200px;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* Carousel navigation */
.wp-block-query.sierra-layout-carousel .carousel-prev,
.wp-block-query.sierra-layout-carousel .carousel-next {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 10;
	background-color: var(--wp--preset--color--white, #fff);
	border: 2px solid var(--wp--preset--color--sugar-pine-green, #2d5a3d);
	border-radius: 50%;
	width: 48px;
	height: 48px;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: all 0.2s ease;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.wp-block-query.sierra-layout-carousel .carousel-prev {
	left: -24px;
}

.wp-block-query.sierra-layout-carousel .carousel-next {
	right: -24px;
}

.wp-block-query.sierra-layout-carousel .carousel-prev:hover,
.wp-block-query.sierra-layout-carousel .carousel-next:hover {
	background-color: var(--wp--preset--color--sugar-pine-green, #2d5a3d);
	color: var(--wp--preset--color--white, #fff);
}

.wp-block-query.sierra-layout-carousel .carousel-prev:disabled,
.wp-block-query.sierra-layout-carousel .carousel-next:disabled {
	opacity: 0.3;
	cursor: not-allowed;
}

/* Carousel dots */
.wp-block-query.sierra-layout-carousel .carousel-dots {
	display: flex;
	justify-content: center;
	gap: var(--wp--preset--spacing--x-small, 0.5rem);
	margin-top: var(--wp--preset--spacing--40, 1.5rem);
}

.wp-block-query.sierra-layout-carousel .carousel-dot {
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background-color: var(--wp--preset--color--sugar-pine-green-30, #e0e0e0);
	border: none;
	cursor: pointer;
	transition: all 0.2s ease;
	padding: 0;
}

.wp-block-query.sierra-layout-carousel .carousel-dot:hover {
	background-color: var(--wp--preset--color--sugar-pine-green-50, #888);
}

.wp-block-query.sierra-layout-carousel .carousel-dot.active {
	background-color: var(--wp--preset--color--sugar-pine-green, #2d5a3d);
	width: 32px;
	border-radius: 6px;
}

/* Responsive carousel */
@media (max-width: 1024px) {
	.wp-block-query.sierra-layout-carousel .carousel-slide {
		width: calc(100% / 2 - var(--wp--preset--spacing--30, 1rem));
	}
}

@media (max-width: 768px) {
	.wp-block-query.sierra-layout-carousel .carousel-slide {
		width: 100%;
		margin-right: 0;
	}

	.wp-block-query.sierra-layout-carousel .carousel-prev,
	.wp-block-query.sierra-layout-carousel .carousel-next {
		width: 40px;
		height: 40px;
	}

	.wp-block-query.sierra-layout-carousel .carousel-prev {
		left: 0;
	}

	.wp-block-query.sierra-layout-carousel .carousel-next {
		right: 0;
	}
}

/* ==========================================================================
   Side-by-Side Layout
   ========================================================================== */

.wp-block-query.sierra-layout-side-by-side .wp-block-post-template {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--50, 2rem);
}

.wp-block-query.sierra-layout-side-by-side .side-by-side-post {
	display: block;
}

.wp-block-query.sierra-layout-side-by-side .side-by-side-wrapper {
	display: flex;
	gap: var(--wp--preset--spacing--40, 1.5rem);
	align-items: stretch;
	background-color: var(--wp--preset--color--module-background, #f9f9f9);
	border-radius: 24px;
	overflow: hidden;
}

.wp-block-query.sierra-layout-side-by-side .side-by-side-image {
	flex: 0 0 var(--image-width, 50%);
	position: relative;
}

.wp-block-query.sierra-layout-side-by-side .side-by-side-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.wp-block-query.sierra-layout-side-by-side .side-by-side-content {
	flex: 1;
	padding: var(--wp--preset--spacing--x-large, 2.5rem);
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--medium, 1rem);
	justify-content: center;
}

/* Image position variations */
.wp-block-query.sierra-layout-side-by-side .sierra-side-by-side-layout.image-left .side-by-side-wrapper {
	flex-direction: row;
}

.wp-block-query.sierra-layout-side-by-side .sierra-side-by-side-layout.image-right .side-by-side-wrapper {
	flex-direction: row-reverse;
}

/* Side-by-side filtered state */
.wp-block-query.sierra-layout-side-by-side .side-by-side-post.filtered-out {
	display: none;
}

/* Responsive side-by-side */
@media (max-width: 1024px) {
	.wp-block-query.sierra-layout-side-by-side .side-by-side-wrapper {
		flex-direction: column !important;
	}

	.wp-block-query.sierra-layout-side-by-side .side-by-side-image {
		flex: 0 0 auto;
		width: 100%;
		min-height: 300px;
	}

	.wp-block-query.sierra-layout-side-by-side .side-by-side-content {
		padding: var(--wp--preset--spacing--large, 2rem);
	}
}

@media (max-width: 768px) {
	.wp-block-query.sierra-layout-side-by-side .side-by-side-image {
		min-height: 250px;
	}

	.wp-block-query.sierra-layout-side-by-side .side-by-side-content {
		padding: var(--wp--preset--spacing--medium, 1.5rem);
	}
}

/* ==========================================================================
   Filtered States (Common)
   ========================================================================== */

.wp-block-query .filtered-out {
	display: none !important;
}

/* No results message */
.wp-block-query .wp-block-query-no-results {
	display: none;
	padding: var(--wp--preset--spacing--70, 3rem);
	text-align: center;
	color: var(--wp--preset--color--deep-alpine-70, #666);
	font-style: italic;
}

/* ==========================================================================
   Loading States
   ========================================================================== */

.wp-block-query.is-loading {
	opacity: 0.6;
	pointer-events: none;
}

.wp-block-query.is-loading::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 40px;
	height: 40px;
	border: 4px solid var(--wp--preset--color--sugar-pine-green-30, #e0e0e0);
	border-top-color: var(--wp--preset--color--sugar-pine-green, #2d5a3d);
	border-radius: 50%;
	animation: query-spinner 0.8s linear infinite;
}

@keyframes query-spinner {
	to {
		transform: translate(-50%, -50%) rotate(360deg);
	}
}

/* ==========================================================================
   Accessibility
   ========================================================================== */

@media (prefers-reduced-motion: reduce) {
	.wp-block-query.sierra-layout-carousel .carousel-slides,
	.wp-block-query.sierra-layout-carousel .carousel-prev,
	.wp-block-query.sierra-layout-carousel .carousel-next,
	.wp-block-query.sierra-layout-carousel .carousel-dot {
		transition: none;
	}

	.wp-block-query.is-loading::after {
		animation: none;
	}
}

/* Focus states */
.wp-block-query.sierra-layout-carousel .carousel-prev:focus-visible,
.wp-block-query.sierra-layout-carousel .carousel-next:focus-visible,
.wp-block-query.sierra-layout-carousel .carousel-dot:focus-visible {
	outline: 3px solid var(--wp--preset--color--sugar-pine-green, #2d5a3d);
	outline-offset: 2px;
}

/* Screen reader only content */
.wp-block-query .screen-reader-text {
	position: absolute;
	left: -10000px;
	top: auto;
	width: 1px;
	height: 1px;
	overflow: hidden;
}
