/**
 * recommendations.css — Recommendations index page styles.
 *
 * Loaded by src/recommendations.njk via its `styles:` frontmatter array.
 *
 * Single section: RECOMMENDATIONS INDEX — distinct from the home page's
 * `recommendations-featured` partial (which is home-only and lives with
 * the home-page CSS in PR 3). This file styles the dedicated index page
 * at `/recommendations/` that lists all LinkedIn recommendations in full.
 *
 * Extracted from src/assets/css/app.css RECOMMENDATIONS INDEX section
 * as part of #147 PR 2 — CSS file split: static pages. Content byte-
 * for-byte preserved.
 */

/* ─────────────────────────────────────────────────────────────────────
	RECOMMENDATIONS INDEX
	─────────────────────────────────────────────────────────────────────
	The /recommendations/ page — full set of LinkedIn recs, grouped by
	category, full verbatim quotes. Markup in `src/recommendations.njk`
	+ `partials/_recommendation-card.njk`.

	Companion to the home-page `recommendations-featured.njk` partial
	(`.innov8-rec-*`) which curates to 4 pull-quote cards. This page
	uses the full quote text, so cards are taller; grid stays 2-col
	wide (not 4) so the prose has breathing room.

	Class prefix: `innov8-rl-` (recommendations-list).
	───────────────────────────────────────────────────────────────────── */

@layer components {
	.innov8-rl {
		position: relative;
		color: var(--fg-primary);
	}

	/* Hero header CSS lives in the PAGE HEADER PARTIAL block (in shared.css
		the ABOUT PAGE section) — `.innov8-page-header-*` rules serve
		about / services / recs / contact uniformly. */

	.innov8-rl-source-link {
		display: inline-flex;
		align-items: center;
		gap: 8px;
		font-family: var(--font-mono);
		font-size: var(--text-body-sm);
		letter-spacing: 0.04em;
		color: var(--accent-spark);
		text-decoration: none;
		transition: gap var(--duration-base) var(--ease-out);
	}

	.innov8-rl-source-link:hover,
	.innov8-rl-source-link:focus-visible {
		gap: 12px;
		outline: none;
	}

	/* ─── Category section ──────────────────────────────────────────── */
	.innov8-rl-section {
		padding: clamp(56px, 7vw, 96px) 0;
		background: var(--color-ink-1000);
	}

	.innov8-rl-section-alt {
		background: var(--color-ink-950);
		border-top: 1px solid var(--border-subtle);
		border-bottom: 1px solid var(--border-subtle);
	}

	.innov8-rl-section-header {
		margin-bottom: clamp(28px, 3.6vw, 48px);
		max-width: 720px;
	}

	.innov8-rl-section-eyebrow {
		margin-bottom: 14px;
	}

	.innov8-rl-section-title {
		margin: 0;
		max-width: 24ch;
		font-family: var(--font-display);
		font-weight: 700;
		font-size: clamp(28px, 3.2vw, 40px);
		line-height: var(--leading-snug);
		letter-spacing: var(--tracking-snug);
		color: var(--fg-primary);
		text-transform: uppercase;
		text-wrap: balance;
	}

	/* ─── 2-col grid → 1-col on narrow viewports ────────────────────── */
	.innov8-rl-grid {
		display: grid;
		gap: clamp(16px, 2vw, 24px);
		grid-template-columns: 1fr;
		margin: 0;
		padding: 0;
		list-style: none;
	}

	@media (min-width: 880px) {
		.innov8-rl-grid {
			grid-template-columns: repeat(2, 1fr);
		}
	}

	/* ─── Full-quote recommendation card ────────────────────────────── */
	.innov8-rl-card {
		display: flex;
		flex-direction: column;
		justify-content: space-between;
		gap: 24px;
		padding: clamp(28px, 3.2vw, 36px);
		background: var(--bg-card);
		border: 1px solid var(--border-default);
		border-radius: var(--radius-lg);
		transition:
			border-color var(--duration-base) var(--ease-out),
			transform var(--duration-base) var(--ease-out);
	}

	.innov8-rl-card:hover {
		border-color: var(--border-brand);
		transform: translateY(-2px);
	}

	/* Anchor-target highlight — when a visitor arrives via a #rec-<slug>
		anchor from the home-page featured cards, the matching card lights
		up briefly so the eye lands on the right one. Pure CSS (no JS), uses
		the :target pseudo-class on the card's id="rec-<slug>". The cyan
		glow shadow + accent-spark border fade out 2s after navigation.
		#132. */
	.innov8-rl-card:target {
		border-color: var(--accent-spark);
		box-shadow:
			0 0 0 2px var(--accent-spark),
			var(--shadow-glow-cyan);
		animation: innov8-rl-target-fade 2.4s ease-out forwards;
	}

	@keyframes innov8-rl-target-fade {
		0%,
		40% {
			border-color: var(--accent-spark);
			box-shadow:
				0 0 0 2px var(--accent-spark),
				var(--shadow-glow-cyan);
		}
		100% {
			border-color: var(--border-default);
			box-shadow:
				0 0 0 0 transparent,
				0 0 0 0 transparent;
		}
	}

	@media (prefers-reduced-motion: reduce) {
		.innov8-rl-card:target {
			animation: none;
			border-color: var(--accent-spark);
			box-shadow: 0 0 0 2px var(--accent-spark);
		}
	}

	.innov8-rl-blockquote {
		margin: 0;
		padding: 0;
		border: none;
		display: flex;
		flex-direction: column;
		gap: 16px;
	}

	.innov8-rl-mark {
		color: var(--accent-spark);
		opacity: 0.6;
	}

	.innov8-rl-quote {
		margin: 0;
		font-family: var(--font-sans);
		font-size: var(--text-body);
		font-weight: 400;
		line-height: var(--leading-loose);
		color: var(--fg-primary);
		text-wrap: pretty;
	}

	.innov8-rl-attribution {
		display: flex;
		flex-direction: column;
		gap: 4px;
		padding-top: 20px;
		border-top: 1px solid var(--border-subtle);
	}

	.innov8-rl-author {
		font-family: var(--font-display);
		font-weight: 700;
		font-size: var(--text-body-sm);
		letter-spacing: var(--tracking-snug);
		color: var(--accent-spark);
		text-transform: uppercase;
	}

	.innov8-rl-role {
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		gap: 6px;
		font-family: var(--font-mono);
		font-size: var(--text-overline);
		letter-spacing: 0.08em;
		text-transform: uppercase;
		color: var(--fg-tertiary);
	}

	.innov8-rl-relationship {
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		gap: 6px;
		margin-top: 4px;
		font-family: var(--font-sans);
		font-size: var(--text-caption);
		color: var(--fg-muted);
		font-style: italic;
	}

	.innov8-rl-sep {
		color: var(--fg-muted);
	}

	@media (prefers-reduced-motion: reduce) {
		.innov8-rl-card,
		.innov8-rl-card:hover,
		.innov8-rl-source-link,
		.innov8-rl-source-link:hover,
		.innov8-rl-source-link:focus-visible {
			transition: none;
			transform: none;
			gap: 8px;
		}
	}
}
