/*
 * Jersey Bulls FC — SiteFooter (editorial / BYQ-style, client 13 Jun)
 *
 * Newsletter band · big-type nav + contact grid · partner strip · "BACK THE BULLS"
 * CSS marquee · slim bottom bar. Fully themeable via --t-* tokens (flips for light
 * mode). The marquee + hover-fill underlines are pure CSS; reduced-motion safe.
 */

.bulls-site-footer {
	background: var(--t-footer);
	color: var(--t-fg-muted);
	font-family: var(--ff-sans);
	font-size: var(--fs-75);
	line-height: var(--lh-base);
	overflow: hidden;   /* contain the marquee track */
}

.bulls-site-footer a { color: inherit; text-decoration: none; }
.bulls-site-footer a:focus-visible {
	outline: 2px solid var(--c-focus-ring);
	outline-offset: 3px;
	border-radius: var(--radius-base);
}

/* ---- Slide-in underline fill (BYQ interaction) ---- */
.bulls-footer-uline {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 2px;
	overflow: hidden;
	pointer-events: none;
}
.bulls-footer-uline__fill {
	display: block;
	width: 100%;
	height: 100%;
	background: currentColor;
	transform: translateX(-101%);
	transition: transform var(--motion-base) var(--ease-out);
}
a:hover > .bulls-footer-uline > .bulls-footer-uline__fill,
a:focus-visible > .bulls-footer-uline > .bulls-footer-uline__fill,
button:hover > .bulls-footer-uline > .bulls-footer-uline__fill,
button:focus-visible > .bulls-footer-uline > .bulls-footer-uline__fill { transform: translateX(0); }

/* ============================================================
 * Newsletter band
 * ============================================================ */

.bulls-newsletter { border-bottom: 1px solid var(--t-border); }
.bulls-newsletter__inner {
	max-width: var(--content-full);
	margin: 0 auto;
	padding: var(--space-8) var(--gutter);
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-5) var(--space-8);
}
.bulls-newsletter__title {
	margin: 0;
	font-family: var(--ff-display);
	font-size: var(--fs-500);
	line-height: var(--lh-snug);
	letter-spacing: var(--ls-snug);
	text-transform: uppercase;
	color: var(--t-fg);
}
.bulls-newsletter__lead { margin: var(--space-2) 0 0; color: var(--t-fg-muted); font-size: var(--fs-100); }
.bulls-newsletter__form { display: flex; flex-wrap: wrap; gap: var(--space-3); align-items: center; }
.bulls-newsletter .bulls-newsletter__form .bulls-newsletter__input--name { flex: 0 1 180px; min-width: 140px; }
.bulls-newsletter__label {
	position: absolute; width: 1px; height: 1px; overflow: hidden;
	clip: rect(0 0 0 0); clip-path: inset(50%); white-space: nowrap;
}
.bulls-newsletter .bulls-newsletter__input {
	min-width: 260px;
	padding: var(--space-3) var(--space-4);
	background: var(--t-panel);
	border: 1px solid var(--t-border-strong);
	border-radius: var(--radius-base);
	color: var(--t-fg);
	font-family: var(--ff-sans);
	font-size: var(--fs-100);
	transition: border-color var(--motion-fast) var(--ease-out);
}
.bulls-newsletter .bulls-newsletter__input::placeholder { color: var(--t-fg-faint); }
.bulls-newsletter .bulls-newsletter__input:focus { outline: none; border-color: var(--c-bulls-red); }
.bulls-newsletter__submit { min-height: 48px; }
.bulls-newsletter__thanks { margin: 0; color: var(--t-fg); font-family: var(--ff-display); text-transform: uppercase; }
.bulls-newsletter__error { margin: var(--space-2) 0 0; color: var(--c-bulls-red); font-size: var(--fs-75); flex-basis: 100%; }

@media (max-width: 600px) {
	.bulls-newsletter__inner { flex-direction: column; align-items: stretch; }
	.bulls-newsletter__form { flex-direction: column; align-items: stretch; width: 100%; }
	.bulls-newsletter .bulls-newsletter__form .bulls-newsletter__input,
	.bulls-newsletter .bulls-newsletter__form .bulls-newsletter__input--name {
		flex: 1 1 auto; width: 100%; min-width: 0; box-sizing: border-box;
	}
	.bulls-newsletter__form .bulls-newsletter__submit { width: 100%; }
}

/* ============================================================
 * Top grid — big nav (left) + contact/info (right)
 * ============================================================ */

.bulls-footer-top__inner {
	max-width: var(--content-full);
	margin: 0 auto;
	padding: var(--space-16) var(--gutter) var(--space-12);
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-10) var(--space-16);
}

.bulls-footer-nav { display: flex; flex-direction: column; align-items: flex-start; gap: var(--space-1); }
.bulls-footer-nav__link {
	position: relative;
	display: inline-block;
	font-family: var(--ff-display);
	font-size: clamp(2.25rem, 4.6vw, 4rem);
	line-height: 1.04;
	letter-spacing: var(--ls-tight);
	text-transform: uppercase;
	color: var(--t-fg);
	padding-bottom: 0.06em;
}

.bulls-footer-info { display: flex; flex-direction: column; gap: var(--space-10); }
.bulls-footer-cta { display: flex; flex-direction: column; gap: var(--space-2); align-items: flex-start; }
.bulls-footer-cta__eyebrow {
	font-family: var(--ff-display);   /* primary/display font, white on dark (client 13 Jun) */
	font-size: var(--fs-75);
	letter-spacing: var(--ls-wide);
	text-transform: uppercase;
	color: var(--t-fg);
}
.bulls-footer-cta__email {
	position: relative;
	display: inline-block;
	font-family: var(--ff-display);
	font-size: clamp(1.75rem, 3.4vw, 3rem);
	line-height: 1.02;
	letter-spacing: var(--ls-tight);
	color: var(--t-fg);
	padding-bottom: 0.06em;
}

.bulls-footer-cols {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--space-8) var(--space-6);
}
.bulls-footer-col { display: flex; flex-direction: column; gap: var(--space-3); align-items: flex-start; }
.bulls-footer-col__label {
	font-family: var(--ff-display);   /* primary/display font, white on dark (client 13 Jun) */
	font-size: var(--fs-75);
	letter-spacing: var(--ls-wide);
	text-transform: uppercase;
	color: var(--t-fg);
}
.bulls-footer-col__lines { margin: 0; display: flex; flex-direction: column; align-items: flex-start; gap: var(--space-1); }
.bulls-footer-col__link {
	position: relative;
	display: inline-block;
	color: var(--t-fg);
	font-size: var(--fs-200);
	font-weight: var(--fw-medium);
	letter-spacing: var(--ls-snug);
	line-height: 1.4;
	padding-bottom: 2px;
	background: none;
	border: 0;
	cursor: pointer;
	text-align: left;
}
.bulls-footer-col__meta { color: var(--t-fg-muted); font-size: var(--fs-100); line-height: 1.5; }

/* ============================================================
 * Partner band — main tier + official-partner wall (PSG-true monochrome).
 * Reverted to the original above-the-footer layout (client 13 Jun).
 * ============================================================ */

.bulls-site-footer__partners { border-top: 1px solid var(--t-border); }
.bulls-site-footer__partners-inner {
	max-width: var(--content-full);
	margin: 0 auto;
	padding: var(--space-8) var(--gutter);
	display: flex;
	flex-direction: column;
	gap: var(--space-8);
}
.bulls-site-footer__partner-chip {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 44px;
	padding: 0 var(--space-2);
}
.bulls-site-footer__partner-chip img {
	display: block;
	max-height: 28px;
	max-width: 124px;
	width: auto;
	height: auto;
	object-fit: contain;
	filter: brightness(0) invert(1);   /* logos → white on the dark footer */
	opacity: 0.8;
	transition: opacity var(--motion-fast) var(--ease-out);
}
.bulls-site-footer__partner-chip--sm { height: 52px; }
.bulls-site-footer__partner-chip--sm img { max-height: 34px; max-width: 144px; }
/* Light canvas: full-colour logos (consistent with /partners). */
html.theme-light .bulls-site-footer__partner-chip img { filter: none; opacity: 1; }

.bulls-site-footer__partners-list {
	list-style: none; margin: 0; padding: 0;
	display: flex; flex-wrap: wrap; justify-content: center; align-items: flex-end;
	gap: var(--space-10);
}
.bulls-site-footer__partner-link { display: inline-flex; flex-direction: column; align-items: center; gap: var(--space-3); }
.bulls-site-footer__partner-link:hover .bulls-site-footer__partner-chip img,
.bulls-site-footer__partner-link:focus-visible .bulls-site-footer__partner-chip img { opacity: 1; }
.bulls-site-footer__partner-link--main .bulls-site-footer__partner-chip { height: 60px; }
.bulls-site-footer__partner-link--main .bulls-site-footer__partner-chip img { max-height: 42px; max-width: 164px; }

.bulls-site-footer__partners-official { border-top: 1px solid var(--t-border); padding-top: var(--space-8); }
.bulls-site-footer__partners-grid {
	list-style: none; margin: 0; padding: 0;
	display: flex; flex-wrap: wrap; justify-content: center; align-items: center;
	gap: var(--space-5) var(--space-6);   /* tighter — bigger logos sit closer (client 13 Jun) */
}
.bulls-site-footer__partners-grid li:hover .bulls-site-footer__partner-chip img { opacity: 1; }
/* Desktop: pin 6 logos per row so the 9-strong wall reads as a balanced 6 + 3
   (the trailing three — Power House / Hacquoil & Cook / EWG — share the second
   row instead of EWG orphaning alone underneath). Last row stays centred via the
   container's justify-content. (client 13 Jun) */
@media (min-width: 1024px) {
	.bulls-site-footer__partners-grid > li {
		flex: 0 0 calc((100% - 5 * var(--space-6)) / 6);
		display: flex;
		justify-content: center;
	}
}

/* ============================================================
 * "BACK THE BULLS" marquee
 * ============================================================ */

.bulls-footer-marquee {
	border-top: 1px solid var(--t-border);
	padding: var(--space-7) 0;
	overflow: hidden;
}
.bulls-footer-marquee__track {
	display: flex;
	align-items: center;
	gap: var(--space-8);
	width: max-content;
	animation: bulls-footer-marquee 38s linear infinite;
	will-change: transform;
}
.bulls-footer-marquee:hover .bulls-footer-marquee__track { animation-play-state: paused; }
.bulls-footer-marquee__item {
	font-family: var(--ff-display);
	font-size: clamp(2.75rem, 8.5vw, 7.5rem);
	line-height: 0.9;
	letter-spacing: var(--ls-tight);
	text-transform: uppercase;
	font-style: italic;            /* client 13 Jun */
	color: var(--c-white);         /* white on the dark footer */
	white-space: nowrap;
}
html.theme-light .bulls-footer-marquee__item { color: var(--c-bulls-red); }   /* red on the light canvas */
.bulls-footer-marquee__crest {
	height: clamp(1.75rem, 4.5vw, 3.5rem);
	width: auto;
	display: block;
	flex: none;
	opacity: 0.9;
	filter: brightness(0) invert(1);   /* white crest on the dark footer */
}
html.theme-light .bulls-footer-marquee__crest { filter: none; }   /* colour crest on light */
@keyframes bulls-footer-marquee {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
	.bulls-footer-marquee__track { animation: none; }
	.bulls-footer-uline__fill { transition: none; }
}

/* ============================================================
 * Bottom bar
 * ============================================================ */

.bulls-footer-bottom { border-top: 1px solid var(--t-border); }
.bulls-footer-bottom__inner {
	max-width: var(--content-full);
	margin: 0 auto;
	padding: var(--space-5) var(--gutter);
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-2) var(--space-5);
	font-size: var(--fs-50);
	letter-spacing: var(--ls-wide);
	color: var(--t-fg-muted);
}
.bulls-footer-bottom__copyright { margin: 0; }
.bulls-footer-bottom__built {
	margin: 0;
	display: inline-flex;
	align-items: center;
	gap: 0.45em;
	color: var(--t-fg-muted);
}
.bulls-footer-bottom__ikigai {
	display: inline-flex;
	align-items: center;
	color: var(--t-fg-muted);
	transition: color var(--motion-fast) var(--ease-out);
}
.bulls-footer-bottom__ikigai svg { height: 15px; width: auto; flex-shrink: 0; transform: translateY(1px); }
.bulls-footer-bottom__ikigai:hover { color: var(--c-bulls-red); }

/* ============================================================
 * Responsive
 * ============================================================ */

@media (max-width: 991px) {
	.bulls-footer-top__inner { grid-template-columns: 1fr; gap: var(--space-10); }
	.bulls-footer-cols { gap: var(--space-7) var(--space-5); }
}
@media (max-width: 767px) {
	.bulls-footer-top__inner { padding: var(--space-10) var(--gutter-sm) var(--space-8); }
	.bulls-footer-cols { grid-template-columns: 1fr 1fr; }
	.bulls-footer-bottom__inner { flex-direction: column; align-items: flex-start; padding: var(--space-4) var(--gutter-sm); }
	.bulls-footer-partners__inner { padding: var(--space-5) var(--gutter-sm); }
}
@media (max-width: 479px) {
	.bulls-footer-cols { grid-template-columns: 1fr; }
}
