/* ==========================================================================
   Section: About / Team. Ported from about-styles.css.
   ========================================================================== */

.team-intro { max-width: 60ch; }
.team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 52px; }
.bio {
	position: relative; background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg);
	padding: 32px 30px; transition: transform .3s cubic-bezier(.2,.7,.3,1), box-shadow .3s ease, border-color .3s ease;
	overflow: hidden; z-index: 0;
	/* Avatar (col 1) sits beside the name + role (col 2); bio text spans below. */
	display: grid; grid-template-columns: auto 1fr; column-gap: 18px;
}
.bio::before {
	content:''; position: absolute; inset: 0; border-radius: inherit; padding: 1px; background: var(--grad);
	-webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor; mask-composite: exclude;
	opacity: 0; transition: opacity .3s ease; pointer-events: none;
}
.bio:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); border-color: transparent; }
.bio:hover::before { opacity: 1; }
.bio-avatar {
	width: 64px; height: 64px; border-radius: 18px; overflow: hidden;
	display: flex; align-items: center; justify-content: center; background: var(--grad-soft);
	transition: transform .3s ease;
	grid-column: 1; grid-row: 1 / span 2; align-self: center;
}
.bio-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.bio:hover .bio-avatar { transform: scale(1.06) rotate(-3deg); }
.bio h3 { font-size: 22px; margin-bottom: 3px; grid-column: 2; grid-row: 1; align-self: end; }
.bio .role { font-size: 12.5px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--cyan); grid-column: 2; grid-row: 2; align-self: start; }
.bio p { font-size: 14.5px; color: var(--body); line-height: 1.62; grid-column: 1 / -1; grid-row: 3; margin-top: 22px; }

@media (max-width: 1080px) {
	.team-grid { grid-template-columns: 1fr; }
}
@media (max-width: 820px) {
	.team-grid { gap: 28px; }
}
