/* CoreCave editorial — featured-teachers section (T3.1 / Wave 3).
 *
 * Owns: section layout, eyebrow, title, sub, featured modifier,
 * strip container, card BEM children (link/photo/initials/name/
 * specialty/stats/cta). Delegates base bg/border/transition/hover
 * for .cc-teacher-card to cards.css (DRY — do not redefine).
 *
 * Tokens: --cc-ed-* only. No !important. Logical properties only.
 */

/* --- Layout: section wrapper + inner container --- */
.cc-teachers-section {
	background: var(--cc-ed-bg);
	padding-block: var(--cc-ed-sp-fluid-section);
}

.cc-teachers-section__inner {
	max-inline-size: var(--cc-ed-w-wide);
	margin-inline: auto;
	padding-inline: var(--cc-ed-sp-card-pad-x);
}

.cc-teachers-section__grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: var(--cc-ed-sp-7);
	margin-block-start: var(--cc-ed-sp-6);
}

/* --- Eyebrow + heading + sub --- */
.cc-teachers-section__eyebrow {
	display: block;
	color: var(--cc-ed-saffron);
	font-size: 0.8125rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	margin-block-end: var(--cc-ed-sp-2);
}

.cc-teachers-section__title {
	color: var(--cc-ed-ink);
	font-size: clamp(1.75rem, 3.5vw, 2.75rem);
	font-weight: 900;
	line-height: 1.1;
	letter-spacing: -0.01em;
	margin-block: 0 var(--cc-ed-sp-3);
}

.cc-teachers-section__sub {
	color: var(--cc-ed-muted);
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.6;
	max-inline-size: var(--cc-ed-w-content);
	margin-block: 0;
}

/* --- Featured card modifier --- */
.cc-teacher-card--featured {
	padding-block: var(--cc-ed-sp-card-pad-y);
	padding-inline: var(--cc-ed-sp-card-pad-x);
	border-radius: var(--cc-ed-radius-lg);
	box-shadow: var(--cc-ed-shadow-card);
	display: flex;
	flex-direction: column;
	gap: var(--cc-ed-sp-4);
}

.cc-teacher-card--featured .cc-teacher-card__photo {
	inline-size: 180px;
	block-size: 180px;
}

.cc-teacher-card--featured .cc-teacher-card__name {
	font-size: clamp(1.5rem, 2.6vw, 2rem);
	font-weight: 800;
	line-height: 1.15;
}

.cc-teacher-card--featured .cc-teacher-card__initials {
	font-size: 4.5rem;
}

/* --- Strip: list container + items --- */
.cc-teacher-strip {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: var(--cc-ed-sp-4);
	margin: 0;
	padding: 0;
	list-style: none;
}

.cc-teacher-strip__item {
	display: block;
}

/* Strip card (non-featured) sizing — base bg/border lives in cards.css. */
.cc-teacher-strip .cc-teacher-card {
	padding-block: var(--cc-ed-sp-5);
	padding-inline: var(--cc-ed-sp-5);
	border-radius: var(--cc-ed-radius-md);
	box-shadow: var(--cc-ed-shadow-paper);
	display: flex;
	flex-direction: column;
	gap: var(--cc-ed-sp-3);
}

/* --- Card link + focus --- */
.cc-teacher-card__link {
	display: block;
	color: inherit;
	text-decoration: none;
}

.cc-teacher-card__link:focus-visible {
	outline: 2px solid var(--cc-ed-saffron);
	outline-offset: 2px;
	border-radius: var(--cc-ed-radius-sm);
}

/* --- Photo + initials fallback --- */
.cc-teacher-card__photo {
	inline-size: 96px;
	block-size: 96px;
	aspect-ratio: 1;
	overflow: hidden;
	border-radius: var(--cc-ed-radius-pill);
	background: var(--cc-ed-paper-rule-soft);
	display: flex;
	align-items: center;
	justify-content: center;
}

.cc-teacher-card__photo img {
	inline-size: 100%;
	block-size: 100%;
	object-fit: cover;
	display: block;
}

.cc-teacher-card__initials {
	inline-size: 100%;
	block-size: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--cc-ed-saffron);
	color: var(--cc-ed-bg);
	font-size: 2rem;
	font-weight: 800;
	line-height: 1;
	text-transform: uppercase;
}

/* --- Name + specialty --- */
.cc-teacher-card__name {
	color: var(--cc-ed-ink);
	font-size: 1.125rem;
	font-weight: 700;
	line-height: 1.25;
	margin-block: 0;
}

.cc-teacher-card__specialty {
	color: var(--cc-ed-muted);
	font-size: 0.875rem;
	font-weight: 400;
	line-height: 1.4;
	margin-block: 0;
}

.cc-teacher-card__specialty:empty {
	display: none;
}

/* --- Stats: dl reset + tabular numerics --- */
.cc-teacher-card__stats {
	display: flex;
	flex-wrap: wrap;
	gap: var(--cc-ed-sp-3);
	margin-block: var(--cc-ed-sp-2) 0;
	padding: 0;
}

.cc-teacher-card__stat {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.cc-teacher-card__stat dt {
	color: var(--cc-ed-muted);
	font-size: 0.75rem;
	font-weight: 500;
	letter-spacing: 0.04em;
	margin: 0;
}

.cc-teacher-card__stat dd {
	color: var(--cc-ed-ink);
	font-size: 1rem;
	font-weight: 700;
	line-height: 1;
	margin: 0;
	font-feature-settings: 'tnum' 1;
	font-variant-numeric: tabular-nums;
}

.cc-teacher-card--featured .cc-teacher-card__stats {
	gap: var(--cc-ed-sp-5);
}

.cc-teacher-card--featured .cc-teacher-card__stat dd {
	font-size: 1.25rem;
}

/* --- CTA --- */
.cc-teacher-card__cta {
	display: inline-flex;
	align-items: center;
	gap: var(--cc-ed-sp-1);
	color: var(--cc-ed-saffron);
	font-size: 0.875rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-decoration: none;
	margin-block-start: var(--cc-ed-sp-2);
}

.cc-teacher-card__cta::after {
	content: '\2192';
	display: inline-block;
	transition: transform var(--cc-ed-dur-fast) var(--cc-ed-ease);
}

[dir="rtl"] .cc-teacher-card__cta::after {
	transform: scaleX(-1);
}

.cc-teacher-card__cta:hover,
.cc-teacher-card__link:hover .cc-teacher-card__cta {
	text-decoration: underline;
	text-underline-offset: 3px;
}

@media (prefers-reduced-motion: no-preference) {
	.cc-teacher-card__link:hover .cc-teacher-card__cta::after {
		transform: translateX(2px);
	}
	[dir="rtl"] .cc-teacher-card__link:hover .cc-teacher-card__cta::after {
		transform: scaleX(-1) translateX(2px);
	}
}

/* --- Breakpoints: tablet 768–1023 + desktop ≥1024 + mobile ≤767 --- */
@media (min-width: 768px) {
	.cc-teacher-strip {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (min-width: 1024px) {
	.cc-teachers-section__grid {
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
		align-items: start;
	}
	.cc-teacher-strip {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 767px) {
	.cc-teacher-strip {
		display: flex;
		grid-template-columns: none;
		overflow-x: auto;
		scroll-snap-type: x mandatory;
		gap: var(--cc-ed-sp-4);
		padding-block-end: var(--cc-ed-sp-3);
		scrollbar-width: thin;
	}
	.cc-teacher-strip__item {
		flex: 0 0 80%;
		scroll-snap-align: start;
	}
	.cc-teacher-card--featured .cc-teacher-card__photo {
		inline-size: 140px;
		block-size: 140px;
	}
}

/* --- Dark mode overrides --- */
[data-theme="dark"] .cc-teacher-card__photo {
	background: var(--cc-ed-paper-rule);
}

[data-theme="dark"] .cc-teacher-card__initials {
	background: var(--cc-ed-saffron-warm);
	color: var(--cc-ed-bg);
}

[data-theme="dark"] .cc-teacher-card__name {
	color: var(--cc-ed-ink);
}

[data-theme="dark"] .cc-teacher-card__stat dd {
	color: var(--cc-ed-ink);
}
