/*
 * css/blocks/single-team.css — Layer 3 layout for the Team bio template.
 *
 * Used by single-team.php. Enqueued by inc/cpt-team.php on `is_singular('team')`.
 * Page archetype: dev-wp-developer/references/pages-types/team-member-bio/.
 *
 * Layout decisions:
 *   - Bio page uses a narrower inner wrap (`--bio-wrap`, default 880px) so the
 *     content reads like an article, not stretched across the 1240px container.
 *   - Hero is the only 2-col section (photo | name/role). Everything below is a
 *     single centered column at the same wrap width.
 *   - Contact CTA escapes the wrap to full-bleed dark band.
 *
 * LAYOUT ONLY. Colors / fonts / accordions / buttons come from Layer 1 tokens
 * (--header-color-*, --norml-*) and Layer 2 components (.norml-container,
 * .norml-display, .norml-accordion, .et_pb_button).
 */

/* ===========================================================================
 * Page wrapper + bio-page max-width token (Layer-3 scoped — not promoted to root)
 * ========================================================================= */

.single-team__page {
	background: var(--header-color-white);
	color: var(--header-color-dark);
	font-family: var(--norml-font-body);
	--bio-wrap: 880px;
}

.single-team__wrap {
	max-width: var(--bio-wrap);
	margin: 0 auto;
	padding: 0 24px;
}

/* ===========================================================================
 * BREADCRUMB
 * ========================================================================= */

.single-team__breadcrumb-wrap {
	padding: 32px 0 0;
}

.single-team__breadcrumb {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 6px 8px;
	font-size: 14px;
	color: var(--norml-muted);
}

.single-team__breadcrumb li + li::before {
	content: '/';
	margin-right: 8px;
	color: var(--norml-gray);
}

.single-team__breadcrumb a {
	color: var(--norml-muted);
	text-decoration: none;
}

.single-team__breadcrumb a:hover { color: var(--header-color-dark); }

.single-team__breadcrumb [aria-current="page"] {
	color: var(--header-color-dark);
	font-weight: 500;
}

/* ===========================================================================
 * HERO — photo (left) + name/role (right). Only 2-col section.
 * ========================================================================= */

.single-team__hero {
	padding: 24px 0 56px;
}

.single-team__hero-grid {
	display: grid;
	grid-template-columns: minmax(240px, 320px) 1fr;
	gap: 40px;
	align-items: center;
}

.single-team__hero-photo {
	position: relative;
	background: var(--norml-light);
	aspect-ratio: 4 / 5;
	overflow: hidden;
	border-radius: 4px;
}

.single-team__hero-photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center top;
	display: block;
}

.single-team__name {
	font-size: clamp(40px, 5vw, 64px);
	line-height: 1;
	margin: 0 0 12px;
	color: var(--header-color-dark);
}

.single-team__role {
	font-family: var(--norml-font-body);
	font-size: 16px;
	font-weight: 500;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--norml-accent-dark);
	margin: 0;
}

/* ===========================================================================
 * CONTENT — single centered column, comfortable reading width
 * ========================================================================= */

.single-team__content {
	padding: 8px 0 80px;
}

.single-team__block {
	margin-bottom: 48px;
}

.single-team__block:last-child {
	margin-bottom: 0;
}

.single-team__h2 {
	font-size: clamp(28px, 3vw, 40px);
	line-height: 1.05;
	margin: 0 0 16px;
	color: var(--header-color-dark);
}

.single-team__body {
	font-size: 17px;
	line-height: 1.7;
	color: var(--header-color-dark);
}

.single-team__body p { margin: 0 0 1em; }
.single-team__body p:last-child { margin-bottom: 0; }
.single-team__body strong { color: var(--header-color-dark); }
.single-team__body a {
	color: var(--header-color-dark);
	text-decoration: underline;
	text-decoration-color: var(--header-color-accent);
	text-underline-offset: 3px;
}
.single-team__body a:hover { color: var(--norml-accent-dark); }

/* ===========================================================================
 * Inline media (action photo between bio and expertise)
 * ========================================================================= */

.single-team__inline-media {
	margin: 0 0 48px;
	border-radius: 4px;
	overflow: hidden;
}

.single-team__inline-media img {
	width: 100%;
	height: auto;
	display: block;
}

/* ===========================================================================
 * Bullet list — practice areas / education
 * ========================================================================= */

.single-team__bullets {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: 10px;
	font-size: 16px;
	line-height: 1.5;
	color: var(--header-color-dark);
}

.single-team__bullets li {
	padding-left: 22px;
	position: relative;
}

.single-team__bullets li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.55em;
	width: 8px;
	height: 8px;
	background: var(--header-color-accent);
	border-radius: 50%;
}

@media (min-width: 600px) {
	.single-team__block > .single-team__bullets {
		grid-template-columns: repeat(2, 1fr);
		gap: 10px 32px;
	}
}

/* ===========================================================================
 * Credentials — accordion (uses .norml-accordion from components.css)
 * ========================================================================= */

.single-team__creds .norml-accordion {
	margin-bottom: 12px;
}

.single-team__creds .norml-accordion__q {
	font-family: var(--norml-font-body);
	font-size: 16px;
	font-weight: 600;
	padding: 16px 20px;
}

.single-team__creds .norml-accordion__a {
	padding: 0 20px 16px;
}

/* ===========================================================================
 * Split row — Languages + Education side by side
 * ========================================================================= */

.single-team__split {
	display: grid;
	grid-template-columns: 1fr;
	gap: 32px;
}

@media (min-width: 600px) {
	.single-team__split {
		grid-template-columns: 1fr 1fr;
	}
}

.single-team__split > div { min-width: 0; }

/* ===========================================================================
 * Pill row — Languages
 * ========================================================================= */

.single-team__pills {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.single-team__pills li {
	font-size: 14px;
	font-weight: 500;
	color: var(--header-color-dark);
	background: var(--norml-light);
	border: 1px solid var(--norml-border);
	border-radius: 999px;
	padding: 6px 14px;
}

/* ===========================================================================
 * Connect — inline links row
 * ========================================================================= */

.single-team__connect {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 8px 16px;
	font-size: 16px;
}

.single-team__connect li {
	border-right: 1px solid var(--norml-border);
	padding-right: 16px;
}

.single-team__connect li:last-child {
	border-right: none;
	padding-right: 0;
}

.single-team__connect a {
	color: var(--header-color-dark);
	text-decoration: none;
	border-bottom: 2px solid var(--header-color-accent);
	padding-bottom: 2px;
	transition: color 0.2s ease, border-color 0.2s ease;
}

.single-team__connect a:hover {
	color: var(--norml-accent-dark);
	border-bottom-color: var(--norml-accent-dark);
}

/* ===========================================================================
 * CONTACT CTA — full-bleed dark band at the bottom
 * ========================================================================= */

.single-team__contact {
	background: var(--header-color-dark);
	color: var(--header-color-white);
	padding: 80px 0;
}

.single-team__contact .single-team__h2 {
	color: var(--header-color-white);
	margin-bottom: 16px;
}

.single-team__contact-inner {
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 24px;
}

.single-team__contact-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 40px;
	align-items: start;
}

@media (min-width: 900px) {
	.single-team__contact-grid {
		grid-template-columns: minmax(280px, 360px) 1fr;
		gap: 56px;
	}
}

.single-team__contact-text p {
	font-size: 17px;
	line-height: 1.5;
	color: rgba(255, 255, 255, 0.8);
	margin: 0;
}

.single-team__contact-form {
	background: var(--header-color-white);
	color: var(--header-color-dark);
	border-radius: 6px;
	padding: 28px;
}

.single-team__contact-form .gform_wrapper {
	margin: 0;
}

/* ===========================================================================
 * Tablet & mobile collapse
 * ========================================================================= */

@media (max-width: 880px) {
	.single-team__hero {
		padding: 16px 0 32px;
	}
	.single-team__hero-grid {
		grid-template-columns: 1fr;
		gap: 24px;
	}
	.single-team__hero-photo {
		max-width: 320px;
		margin: 0 auto;
	}
	.single-team__content {
		padding: 0 0 56px;
	}
	.single-team__contact {
		padding: 56px 0;
	}
}

@media (max-width: 600px) {
	.single-team__name { font-size: 40px; }
	.single-team__body { font-size: 16px; }
	.single-team__hero-photo { max-width: 100%; }
}
