/* ==========================================================================
   Team Members block
   ========================================================================== */

.lc-block-team-members {
	position: relative;
}

.lc-block-team-members__container {
	max-width: var(--wp--style--global--wide-size);
	margin: 0 auto;
}

.lc-block-team-members__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: var(--wp--preset--spacing--large);
	
	@media (min-width: 768px) {
		grid-template-columns: repeat(3, 1fr);
		gap: var(--wp--preset--spacing--large);
	}
}

.lc-block-team-members__member {
	background: transparent;
	position: relative;
}

.lc-block-team-members__member-content {
	padding: 0;
	position: relative;
}

.lc-block-team-members__member-image {
	width: 100%;
	height: 220px;
	margin-bottom: var(--wp--preset--spacing--small);
	border-radius: var(--wp--custom--border-radius--medium);
	overflow: hidden;
	position: relative;
}

.lc-block-team-members__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}

.lc-block-team-members__member-info {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: var(--wp--preset--spacing--small);
}

.lc-block-team-members__member-text {
	flex: 1;
}

.lc-block-team-members__member-name {
	font-family: var(--wp--preset--font-family--inter);
	font-size: var(--wp--preset--font-size--heading-6);
	font-weight: 600;
	color: var(--wp--preset--color--neutral-10);
	margin: 0 0 4px 0 !important;
	line-height: 1.2;
}

.lc-block-team-members__member-role {
	font-size: var(--wp--preset--font-size--body-small);
	color: var(--wp--preset--color--neutral-20);
	margin: 0;
	line-height: 1.4;
}

.lc-block-team-members__toggle-btn {
	background: var(--wp--preset--color--primary-10);
	border: none;
	border-radius: 50%;
	width: 38px;
	height: 38px;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: background-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
	flex-shrink: 0;
}

.lc-block-team-members__toggle-btn:hover {
	background: var(--wp--preset--color--primary-20);
	box-shadow: 0 2px 8px rgba(29, 99, 90, 0.3);
}

.lc-block-team-members__toggle-btn:active {
	background: var(--wp--preset--color--primary-20);
}

.lc-block-team-members__toggle-btn:focus {
	outline: none;
}

.lc-block-team-members__toggle-icon {
	width: 16px;
	height: 16px;
	color: #ffffff;
	transition: transform 0.2s ease;
}

.lc-block-team-members__member-bio {
	background: var(--wp--preset--color--secondary-50);
	border-radius: var(--wp--custom--border-radius--medium);
	padding: var(--wp--preset--spacing--small);
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.3s ease, padding 0.3s ease, opacity 0.3s ease;
	opacity: 0;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1001;
}

/* Dedicated overlay element for expanded bios */
/* Global overlay for team member bios */
.lc-team-overlay-global {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.1);
    z-index: 900; /* Below the expanded bio */
    display: none; /* Hidden by default */
    transition: opacity 0.3s ease;
    pointer-events: none; /* Allow clicks to pass through to team members */
}

.lc-team-overlay-global.is-visible {
    display: block;
}

/* Body class for when overlay is active - allow scrolling */
body.team-overlay-active {
    /* Remove overflow: hidden to allow scrolling when bio is expanded */
}

.lc-block-team-members__member-bio.is-open {
	max-height: 1000px;
	opacity: 1;
	padding: var(--wp--preset--spacing--small);
}

.lc-block-team-members__bio-content {
	margin-bottom: var(--wp--preset--spacing--medium);
}

.lc-block-team-members__bio-content p {
	font-size: var(--wp--preset--font-size--body-small);
	color: var(--wp--preset--color--neutral-10);
	line-height: 1.6;
	margin: 0 0 var(--wp--preset--spacing--small) 0;
}

.lc-block-team-members__bio-content p:last-child {
	margin-bottom: 0;
}

.lc-block-team-members__member-info--bottom {
	margin-top: var(--wp--preset--spacing--small);
	padding-top: var(--wp--preset--spacing--small);
}

/* No images variant */
.lc-block-team-members--no-images .lc-block-team-members__member-image {
	display: none;
}

.lc-block-team-members--no-images .lc-block-team-members__member-content {
    background: var(--wp--preset--color--secondary-50);
    border-radius: var(--wp--custom--border-radius--medium);
    padding: var(--wp--preset--spacing--small);
    height: 100%;
}

.lc-block-team-members--no-images .lc-block-team-members__bio-inline p {
    font-size: var(--wp--preset--font-size--body-small);
    color: var(--wp--preset--color--neutral-10);
    line-height: 1.6;
}

.lc-block-team-members--no-images .lc-block-team-members__toggle-btn {
    display: none;
}

/* Responsive adjustments */
@media (max-width: 767px) {
	.lc-block-team-members__grid {
		grid-template-columns: 1fr;
		gap: var(--wp--preset--spacing--medium);
	}
	
	.lc-block-team-members__member-content {
		/* padding: var(--wp--preset--spacing--medium); */
	}
	
	.lc-block-team-members__member-image {
		height: 180px;
	}
	
	.lc-block-team-members__member-name {
		font-size: var(--wp--preset--font-size--medium);
	}
}

/* Animation for expand/collapse */
.lc-block-team-members__member-bio {
	transition: max-height 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
				opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1),
				padding 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Focus styles for accessibility */
.lc-block-team-members__toggle-btn:focus-visible {
	outline: none;
	box-shadow: 0 0 0 2px var(--wp--preset--color--primary-30);
}

/* High contrast mode support */
@media (prefers-contrast: high) {
	.lc-block-team-members__member {
		border: 1px solid var(--wp--preset--color--neutral-20);
	}
	
	.lc-block-team-members__toggle-btn {
		border: 1px solid var(--wp--preset--color--primary-60);
	}
}
