/* Jersey Bulls FC — Club Hub (photo-led, PSG "Around the club" pattern).
 * Image hero + anchor tabs, alternating image/text rows linking deeper.
 * Markup: page-templates/club-hub.php · tokens: css/tokens.css */

.bulls-club-hub__hero {
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	min-height: clamp(380px, 52vh, 560px);
	overflow: hidden;
	isolation: isolate;
}
.bulls-club-hub__hero-media {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: -2;
}
.bulls-club-hub__hero-scrim {
	position: absolute;
	inset: 0;
	z-index: -1;
	background: var(--scrim-bottom);
}
.bulls-club-hub__hero-inner {
	max-width: var(--content-full);
	width: 100%;
	margin: 0 auto;
	padding: 0 var(--gutter) var(--space-8);
	box-sizing: border-box;
}
@media (min-width: 1024px) {
	.bulls-club-hub__hero-inner,
	.bulls-club-hub__tabs { padding-inline: clamp(72px, 7vw, 132px); }
}
.bulls-club-hub__kicker {
	margin: 0 0 var(--space-2);
	font-family: var(--ff-mono);
	font-size: var(--fs-50);
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	color: var(--c-bulls-red-300);
}
.bulls-club-hub__title {
	margin: 0;
	font-family: var(--ff-display);
	font-size: clamp(var(--fs-700), 5vw, var(--fs-900));
	line-height: 0.95;
	text-transform: uppercase;
	font-weight: var(--fw-bold);
	color: var(--c-white);
}

/* Anchor tabs along the hero base (PSG). */
.bulls-club-hub__tabs {
	max-width: var(--content-full);
	width: 100%;
	margin: 0 auto;
	padding: 0 var(--gutter);
	box-sizing: border-box;
	display: flex;
	gap: var(--space-6);
	overflow-x: auto;
	scrollbar-width: none;
	border-top: 1px solid var(--c-white-18);
}
.bulls-club-hub__tabs::-webkit-scrollbar { display: none; }
.bulls-club-hub__tab {
	padding: var(--space-4) 0;
	font-family: var(--ff-display);
	font-size: var(--fs-75);
	font-weight: var(--fw-bold);
	letter-spacing: var(--ls-wide);
	text-transform: uppercase;
	white-space: nowrap;
	color: var(--c-white-82);
	text-decoration: none;
	border-bottom: 2px solid transparent;
	transition: color var(--motion-fast) var(--ease-out), border-color var(--motion-fast) var(--ease-out);
}
.bulls-club-hub__tab:hover,
.bulls-club-hub__tab:focus-visible { color: var(--c-white); border-bottom-color: var(--c-bulls-red); }
.bulls-club-hub__tab:focus-visible { outline: 2px solid var(--c-focus-ring); outline-offset: 2px; }

/* Alternating image + text rows. */
.bulls-club-hub__rows {
	max-width: var(--content-full);
	margin: 0 auto;
	padding: var(--space-12) var(--gutter) var(--space-16);
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	gap: var(--space-12);
}
@media (min-width: 1024px) {
	.bulls-club-hub__rows { padding-inline: clamp(72px, 7vw, 132px); }
}
.bulls-club-hub__row {
	display: grid;
	grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
	gap: clamp(var(--space-6), 4vw, var(--space-12));
	align-items: center;
	scroll-margin-top: 110px;   /* clear the sticky bar on anchor jumps */
}
.bulls-club-hub__row--flip .bulls-club-hub__row-media { order: 2; }
.bulls-club-hub__row-media {
	margin: 0;
	border-radius: var(--radius-lg);
	overflow: hidden;
	aspect-ratio: 16 / 10;
	background: var(--t-panel);
}
.bulls-club-hub__row-media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.bulls-club-hub__row-title {
	margin: 0 0 var(--space-4);
	font-family: var(--ff-display);
	font-size: clamp(var(--fs-500), 2.6vw, var(--fs-700));
	text-transform: uppercase;
	font-weight: var(--fw-bold);
	color: var(--t-fg);
}
.bulls-club-hub__row-link {
	color: inherit;
	text-decoration: none;
	transition: color var(--motion-fast) var(--ease-out);
}
.bulls-club-hub__row-link:hover,
.bulls-club-hub__row-link:focus-visible { color: var(--c-bulls-red); }
.bulls-club-hub__row-blurb {
	margin: 0 0 var(--space-5);
	font-family: var(--ff-sans);
	font-size: var(--fs-200);
	line-height: var(--lh-loose);
	color: var(--t-fg-body);
	max-width: 52ch;
}
@media (max-width: 860px) {
	.bulls-club-hub__row { grid-template-columns: 1fr; }
	.bulls-club-hub__row--flip .bulls-club-hub__row-media { order: 0; }
}
