/* ========================================================================== */
/* Testimonials Block Styles
/* ========================================================================== */

/**
 * Testimonials block styling for Yak theme
 * Lives in the yak-blocks cascade layer (position 5)
 * 
 * CSS Cascade Layer Loading Order:
 *   1. reset
 *   2. yak-base
 *   3. yak-layout
 *   4. yak-components
 *   5. yak-blocks  ← (this file)
 *   6. yak-utilities
 *   7. yak-overrides
 */

@layer yak-blocks {
	
	/* ========================================================================
	   Testimonials Wrapper
	   ======================================================================== */
	
	.yak-testimonials {
		/* CSS Custom Properties for easy override per site */
		--yak-testimonial-gap: 2rem;
		--yak-testimonial-radius: 8px; /* Default rounded corners */
		--yak-testimonial-photo-size: 80px;
		--yak-testimonial-max-width: none;
		--yak-testimonial-padding: 2rem;
		--yak-testimonial-border-color: color-mix(in srgb, currentColor 15%, transparent);
		--yak-testimonial-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
		
		container-type: inline-size;
		container-name: testimonials;
		
		/* Add margin below entire collection */
		margin-block-end: 2rem;
	}
	
	.yak-testimonials__inner {
		width: 100%;
		max-width: var(--yak-testimonial-max-width);
		margin-inline: auto;
	}
	
	.yak-testimonials__items {
		display: flex;
		gap: var(--yak-testimonial-gap);
	}
	
	/* ========================================================================
	   Layout: List (default/stacked)
	   ======================================================================== */
	
	.yak-testimonials--list .yak-testimonials__items {
		flex-direction: column;
	}
	
	/* ========================================================================
	   Layout: Grid
	   ======================================================================== */
	
	.yak-testimonials--grid .yak-testimonials__items {
		display: grid;
		grid-template-columns: repeat(var(--yak-testimonial-cols, 3), 1fr);
		gap: var(--yak-testimonial-gap);
	}
	
	/* Grid column variations */
	.yak-testimonials--cols-1 {
		--yak-testimonial-cols: 1;
	}
	
	.yak-testimonials--cols-2 {
		--yak-testimonial-cols: 2;
	}
	
	.yak-testimonials--cols-3 {
		--yak-testimonial-cols: 3;
	}
	
	.yak-testimonials--cols-4 {
		--yak-testimonial-cols: 4;
	}
	
	/* Grid responsive behavior */
	@container testimonials (max-width: 768px) {
		.yak-testimonials--grid .yak-testimonials__items {
			grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
		}
	}
	
	/* ========================================================================
	   Layout: Carousel
	   ======================================================================== */
	
	.yak-testimonials--carousel .yak-testimonials__items {
		overflow-x: auto;
		overflow-y: hidden;
		scroll-snap-type: x mandatory;
		scroll-behavior: smooth;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none; /* Firefox */
		-ms-overflow-style: none; /* IE/Edge */
	}
	
	.yak-testimonials--carousel .yak-testimonials__items::-webkit-scrollbar {
		display: none; /* Chrome/Safari */
	}
	
	.yak-testimonials--carousel .yak-testimonial {
		flex: 0 0 100%;
		scroll-snap-align: start;
		scroll-snap-stop: always;
	}
	
	/* Carousel navigation */
	.yak-testimonials--carousel {
		position: relative;
	}
	
	.yak-carousel-nav {
		display: flex;
		gap: 0.5rem;
		justify-content: center;
		align-items: center;
		margin-block-start: 1.5rem;
	}
	
	.yak-carousel-btn {
		appearance: none;
		background: transparent;
		border: 1px solid color-mix(in srgb, currentColor 20%, transparent);
		border-radius: var(--yak-testimonial-radius, 4px);
		padding: 0.375rem 0.875rem;
		cursor: pointer;
		transition: all 0.2s ease;
		color: inherit;
		font-size: 0.875em;
		opacity: 0.6;
	}
	
	.yak-carousel-btn:hover {
		opacity: 1;
		border-color: color-mix(in srgb, currentColor 40%, transparent);
		background: color-mix(in srgb, currentColor 5%, transparent);
	}
	
	.yak-carousel-btn:disabled {
		opacity: 0.3;
		cursor: not-allowed;
	}
	
	.yak-carousel-dots {
		display: flex;
		gap: 0.5rem;
		list-style: none;
		margin: 0;
		padding: 0;
	}
	
	.yak-carousel-dot {
		appearance: none;
		width: 10px !important; /* Override any theme styles */
		height: 10px !important;
		min-width: 10px;
		min-height: 10px;
		max-width: 10px;
		max-height: 10px;
		border-radius: 50% !important; /* Ensure true circles */
		background: currentColor;
		opacity: 0.25;
		border: none !important;
		padding: 0 !important;
		margin: 0;
		cursor: pointer;
		transition: opacity 0.2s ease;
		box-shadow: none !important; /* Reset any theme shadow */
	}
	
	.yak-carousel-dot.is-active {
		opacity: 1;
	}
	
	.yak-carousel-dot:hover {
		opacity: 0.6;
	}
	
	/* ========================================================================
	   Single Testimonial Card
	   ======================================================================== */
	
	.yak-testimonial {
		margin: 0;
		padding: var(--yak-testimonial-padding);
		display: flex;
		flex-direction: column;
		gap: 1.5rem;
		position: relative;
		
		/* Classy card styling */
		border: 1px solid var(--yak-testimonial-border-color);
		border-radius: var(--yak-testimonial-radius);
		box-shadow: var(--yak-testimonial-shadow);
		background: #fff;
	}

	/* Grid mode: increase left-right padding by 50% */
	.yak-testimonials--grid .yak-testimonial {
		padding-inline: calc(var(--yak-testimonial-padding) * 1.5);
	}
	
	/* Quote */
	.yak-testimonial__quote {
		margin: 0;
		padding: 0;
		padding-inline-start: 0; /* Space for hanging quote */
		font-style: italic;
		position: relative;
		
		/* Reset any theme blockquote styles */
		border: none !important;
		border-left: none !important;
		color: inherit !important;
	}
	
	.yak-testimonial__quote::before {
		content: "\201C"; /* LEFT DOUBLE QUOTATION MARK (Unicode) */
		position: absolute;
		left: -16px;
		top: -4px;
		font-size: 2.25em; /* 50% larger than 1.5em */
		line-height: 1;
		opacity: 0.4;
		font-style: normal;
	}
	
	/* Closing quote is now added inline via PHP */
	.yak-testimonial__quote-close {
		opacity: 1;
		font-style: normal;
		margin-left: 0.1em;
	}
	
	.yak-testimonial__quote p {
		margin: 0 !important; /* Reset any theme paragraph margins */
	}
	
	.yak-testimonial__quote p + p {
		margin-block-start: 0.75em !important; /* Only space between multiple paragraphs */
	}
	
	/* Reset any theme paragraph margins that might leak in */
	.yak-testimonial__quote > p:first-child {
		margin-block-start: 0 !important;
	}
	
	.yak-testimonial__quote > p:last-child {
		margin-block-end: 0 !important;
	}
	
	/* Meta section */
	.yak-testimonial__meta {
		display: flex;
		gap: 1rem;
		align-items: center;
	}
	
	/* Photo */
	.yak-testimonial__photo {
		flex-shrink: 0;
	}
	
	.yak-testimonial__photo img {
		display: block;
		width: var(--yak-testimonial-photo-size);
		height: var(--yak-testimonial-photo-size);
		object-fit: cover;
		border-radius: var(--yak-testimonial-radius);
	}
	
	/* Info */
	.yak-testimonial__info {
		display: flex;
		flex-direction: column;
		gap: 0;
	}
	
	.yak-testimonial__name {
		font-weight: 600;
		display: block;
	}
	
	.yak-testimonial__affiliation {
		font-size: 0.875em;
		opacity: 0.7;
		display: block;
	}
	
	/* ========================================================================
	   Optional Card Styling Utilities
	   ======================================================================== */
	
	/* Add these classes via "Additional CSS Classes" field for variations */
	
	/* No card styling (minimal/text-only) */
	.yak-testimonials.is-minimal .yak-testimonial {
		border: none;
		box-shadow: none;
		background: transparent;
		padding: 0;
	}
	
	/* Heavier borders */
	.yak-testimonials.has-heavy-border .yak-testimonial {
		border-width: 2px;
		border-color: color-mix(in srgb, currentColor 25%, transparent);
	}
	
	/* Stronger shadow */
	.yak-testimonials.has-strong-shadow .yak-testimonial {
		box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
	}
	
	/* Colored background */
	.yak-testimonials.has-background .yak-testimonial {
		background: color-mix(in srgb, currentColor 3%, #fff);
	}
	
	/* Compact spacing */
	.yak-testimonials.is-compact {
		--yak-testimonial-gap: 1rem;
	}
	
	.yak-testimonials.is-compact .yak-testimonial {
		gap: 1rem;
	}
	
	/* Large quote marks */
	.yak-testimonials.has-large-quotes .yak-testimonial__quote::before {
		font-size: 2.5em;
		opacity: 0.25;
	}
	
	/* ========================================================================
	   Accessibility & Focus States
	   ======================================================================== */
	
	.yak-carousel-btn:focus-visible,
	.yak-carousel-dot:focus-visible {
		outline: 2px solid currentColor;
		outline-offset: 2px;
	}
	
	/* Reduced motion */
	@media (prefers-reduced-motion: reduce) {
		.yak-testimonials--carousel .yak-testimonials__items {
			scroll-behavior: auto;
		}
		
		.yak-carousel-btn,
		.yak-carousel-dot {
			transition: none;
		}
	}
	
}

