/**
 * Prospero Theme Shortcode Styles
 *
 * @package Prospero
 * @since 1.0.0
 */

/* ==========================================================================
   Testimonials
   ========================================================================== */

.prospero-testimonials {
	display: grid;
	gap: var(--spacing-lg);
	margin: var(--spacing-lg) 0;
}

/* Slider Wrapper - contains the slider within content bounds */
.prospero-slider-wrapper {
	width: 100%;
	max-width: 100%;
	overflow: hidden;
	margin: var(--spacing-lg) 0;
	padding: 0; /* No padding by default (non-slider) */
}

/* Only add side/bottom padding when containing an active slider (space for arrows and dots) */
.prospero-slider-wrapper:has(.prospero-slider) {
	padding: 0 50px var(--spacing-lg) 50px;
}

/* Clearfix for slider wrapper */
.prospero-slider-wrapper::after {
	content: '';
	display: table;
	clear: both;
}

/* Prospero Slider Containers (initialized by Flickity) */
.prospero-testimonials.prospero-slider,
.prospero-partners.prospero-slider,
.prospero-team.prospero-slider,
.prospero-projects.prospero-slider {
	display: block;
	margin: 0;
}

/* Slider cell sizing - widths are set dynamically via JavaScript based on columns */
/* These are fallback values that will be overridden by JS */
.prospero-testimonials.prospero-slider .testimonial-item {
	min-width: 280px;
}

/* Multiple items per slide for partners */
.prospero-partners.prospero-slider .partner-item {
	min-width: 120px;
}

/* Multiple items per slide for team */
.prospero-team.prospero-slider .team-item {
	min-width: 200px;
}

/* Projects slider */
.prospero-projects.prospero-slider .project-item {
	min-width: 280px;
}

/* Flickity navigation buttons */
.flickity-button {
	background: var(--color-primary);
	color: #fff;
	transition: background-color 0.3s ease, opacity 0.3s ease;
}

.flickity-button:hover {
	background: var(--color-secondary);
}

.flickity-button:disabled {
	opacity: 0.3;
}

/* Position arrows outside the content area */
.prospero-slider-wrapper .flickity-prev-next-button {
	width: 40px;
	height: 40px;
}

.prospero-slider-wrapper .flickity-prev-next-button.previous {
	left: -50px;
}

.prospero-slider-wrapper .flickity-prev-next-button.next {
	right: -50px;
}

/* Flickity page dots - override absolute positioning */
.prospero-slider-wrapper .flickity-page-dots {
	position: static;
	width: 100%;
	margin-top: var(--spacing-md);
	padding: 0;
	bottom: auto;
}

.flickity-page-dots .dot {
	background: var(--color-secondary);
	opacity: 0.5;
	transition: opacity 0.3s ease, background-color 0.3s ease;
}

.flickity-page-dots .dot.is-selected {
	background: var(--color-primary);
	opacity: 1;
}

.testimonial-item {
	display: flex;
	gap: var(--spacing-md);
	padding: var(--spacing-md);
	background: rgba(0, 0, 0, 0.02);
	border-radius: 8px;
	align-items: flex-start;
}

body.dark-mode .testimonial-item {
	background: rgba(255, 255, 255, 0.05);
}

.testimonial-image {
	flex-shrink: 0;
}

.testimonial-thumbnail {
	border-radius: 50%;
	width: 80px;
	height: 80px;
	object-fit: cover;
}

.testimonial-content {
	flex: 1;
}

.testimonial-text {
	font-style: italic;
	margin: 0 0 var(--spacing-sm);
	font-size: 1.1rem;
	line-height: 1.6;
	position: relative;
}

.testimonial-text::before {
	content: '"';
	font-size: 3rem;
	line-height: 1;
	opacity: 0.2;
	position: absolute;
	top: -10px;
	left: -20px;
}

.testimonial-author {
	display: block;
	font-weight: 600;
	font-style: normal;
	color: var(--color-primary);
}

/* ==========================================================================
   Partners
   ========================================================================== */

.prospero-partners {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
	gap: var(--spacing-md);
	margin: var(--spacing-lg) 0;
	align-items: center;
	justify-items: center;
}

.partner-item {
	width: 100%;
	text-align: center;
}

.partner-logo {
	padding: var(--spacing-sm);
	background: rgba(0, 0, 0, 0.02);
	border-radius: 8px;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

body.dark-mode .partner-logo {
	background: rgba(255, 255, 255, 0.05);
}

.partner-logo:hover {
	transform: translateY(-5px);
	box-shadow: 0 5px 20px rgba(0, 0, 0, 0.1);
}

body.dark-mode .partner-logo:hover {
	box-shadow: 0 5px 20px rgba(0, 0, 0, 0.3);
}

.partner-logo a {
	display: block;
}

.partner-thumbnail {
	width: 100%;
	height: auto;
	max-width: 200px;
	object-fit: contain;
	mix-blend-mode: multiply;
}

body.dark-mode .partner-thumbnail {
	mix-blend-mode: lighten;
	opacity: 0.9;
}

/* ==========================================================================
   Team
   ========================================================================== */

.prospero-team {
	margin: var(--spacing-lg) 0;
}

/* Grid Layout */
.prospero-team-grid {
	display: grid;
	gap: var(--spacing-lg);
}

.prospero-team-grid[data-columns="1"] { grid-template-columns: 1fr; }
.prospero-team-grid[data-columns="2"] { grid-template-columns: repeat(2, 1fr); }
.prospero-team-grid[data-columns="3"] { grid-template-columns: repeat(3, 1fr); }
.prospero-team-grid[data-columns="4"] { grid-template-columns: repeat(4, 1fr); }
.prospero-team-grid[data-columns="5"] { grid-template-columns: repeat(5, 1fr); }
.prospero-team-grid[data-columns="6"] { grid-template-columns: repeat(6, 1fr); }

/* List Layout */
.prospero-team-list {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-md);
}

.prospero-team-list .team-item {
	display: flex;
	gap: var(--spacing-md);
	align-items: flex-start;
	padding: var(--spacing-md);
	background: rgba(0, 0, 0, 0.02);
	border-radius: 8px;
}

body.dark-mode .prospero-team-list .team-item {
	background: rgba(255, 255, 255, 0.05);
}

.prospero-team-list .team-image {
	flex-shrink: 0;
	width: 120px;
}

/* Simple Layout */
.prospero-team-simple {
	display: grid;
	gap: var(--spacing-md);
}

.prospero-team-simple[data-columns="1"] { grid-template-columns: 1fr; }
.prospero-team-simple[data-columns="2"] { grid-template-columns: repeat(2, 1fr); }
.prospero-team-simple[data-columns="3"] { grid-template-columns: repeat(3, 1fr); }
.prospero-team-simple[data-columns="4"] { grid-template-columns: repeat(4, 1fr); }
.prospero-team-simple[data-columns="5"] { grid-template-columns: repeat(5, 1fr); }
.prospero-team-simple[data-columns="6"] { grid-template-columns: repeat(6, 1fr); }

/* Team Item */
.team-item {
	text-align: center;
}

.team-image {
	margin-bottom: var(--spacing-sm);
	overflow: hidden;
	border-radius: 8px;
}

.team-image a {
	display: block;
	position: relative;
	overflow: hidden;
}

.team-thumbnail {
	width: 100%;
	height: auto;
	transition: transform 0.3s ease;
	display: block;
}

.team-image a:hover .team-thumbnail {
	transform: scale(1.05);
}

.team-content {
	padding: var(--spacing-sm);
}

.team-name {
	margin: 0 0 var(--spacing-xs);
	font-size: 1.25rem;
}

.team-name a {
	color: var(--color-text);
	text-decoration: none;
	transition: color 0.3s ease;
}

body.dark-mode .team-name a {
	color: var(--color-text-dark);
}

.team-name a:hover {
	color: var(--color-primary);
}

.team-excerpt {
	font-size: 0.95rem;
	line-height: 1.5;
	color: var(--color-secondary);
}

body.dark-mode .team-excerpt {
	color: rgba(255, 255, 255, 0.7);
}

/* ==========================================================================
   Projects
   ========================================================================== */

.prospero-projects {
	display: grid;
	gap: var(--spacing-lg);
	margin: var(--spacing-lg) 0;
}

.prospero-projects[data-columns="1"] { grid-template-columns: 1fr; }
.prospero-projects[data-columns="2"] { grid-template-columns: repeat(2, 1fr); }
.prospero-projects[data-columns="3"] { grid-template-columns: repeat(3, 1fr); }
.prospero-projects[data-columns="4"] { grid-template-columns: repeat(4, 1fr); }
.prospero-projects[data-columns="5"] { grid-template-columns: repeat(5, 1fr); }
.prospero-projects[data-columns="6"] { grid-template-columns: repeat(6, 1fr); }

.project-item {
	background: rgba(0, 0, 0, 0.02);
	border-radius: 8px;
	overflow: hidden;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

body.dark-mode .project-item {
	background: rgba(255, 255, 255, 0.05);
}

.project-item:hover {
	transform: translateY(-5px);
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
}

body.dark-mode .project-item:hover {
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
}

.project-image {
	position: relative;
	overflow: hidden;
	aspect-ratio: 16 / 9;
	background: var(--color-background);
}

body.dark-mode .project-image {
	background: var(--color-background-dark);
}

.project-image a {
	display: block;
	height: 100%;
}

.project-thumbnail {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.3s ease;
}

.project-image a:hover .project-thumbnail {
	transform: scale(1.05);
}

.project-content {
	padding: var(--spacing-md);
}

.project-title {
	margin: 0 0 var(--spacing-sm);
	font-size: 1.5rem;
}

.project-title a {
	color: var(--color-text);
	text-decoration: none;
	transition: color 0.3s ease;
}

body.dark-mode .project-title a {
	color: var(--color-text-dark);
}

.project-title a:hover {
	color: var(--color-primary);
}

.project-excerpt {
	margin-bottom: var(--spacing-md);
	color: var(--color-secondary);
	line-height: 1.6;
}

body.dark-mode .project-excerpt {
	color: rgba(255, 255, 255, 0.7);
}

.project-link {
	display: inline-block;
}

/* ==========================================================================
   Responsive Adjustments
   ========================================================================== */

@media (max-width: 768px) {
	/* Testimonials */
	.testimonial-item {
		flex-direction: column;
		text-align: center;
	}
	
	.testimonial-image {
		margin: 0 auto;
	}
	
	.testimonial-text::before {
		left: 50%;
		transform: translateX(-50%);
	}
	
	/* Partners */
	.prospero-partners {
		grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
	}
	
	/* Team Grid - Force 2 columns on tablet */
	.prospero-team-grid[data-columns="3"],
	.prospero-team-grid[data-columns="4"],
	.prospero-team-grid[data-columns="5"],
	.prospero-team-grid[data-columns="6"] {
		grid-template-columns: repeat(2, 1fr);
	}
	
	/* Team Simple - Force 2 columns on tablet */
	.prospero-team-simple[data-columns="3"],
	.prospero-team-simple[data-columns="4"],
	.prospero-team-simple[data-columns="5"],
	.prospero-team-simple[data-columns="6"] {
		grid-template-columns: repeat(2, 1fr);
	}
	
	/* Team List */
	.prospero-team-list .team-item {
		flex-direction: column;
		text-align: center;
	}
	
	.prospero-team-list .team-image {
		width: 100%;
		max-width: 200px;
		margin: 0 auto;
	}
	
	/* Projects - Force 2 columns on tablet */
	.prospero-projects[data-columns="3"],
	.prospero-projects[data-columns="4"],
	.prospero-projects[data-columns="5"],
	.prospero-projects[data-columns="6"] {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 480px) {
	/* All grids collapse to single column on mobile */
	.prospero-team-grid,
	.prospero-team-simple,
	.prospero-projects {
		grid-template-columns: 1fr !important;
	}
	
	.prospero-partners {
		grid-template-columns: repeat(2, 1fr);
	}
}
