/* =============================================================================
   GAME ON ENTERTAINMENT
   Broadcast / cinematic dark theme
   ============================================================================= */

/* -----------------------------------------------------------------------------
   1. TOKENS
   --------------------------------------------------------------------------- */
:root {
	/* Color */
	--c-ink:        #0a0a0a;
	--c-ink-2:      #141414;
	--c-ink-3:      #1c1c1c;
	--c-ink-4:      #262626;
	--c-paper:      #f5f1ea;     /* warm off-white */
	--c-paper-2:    #e9e3d6;
	--c-line:       rgba(255,255,255,0.08);
	--c-line-dark:  rgba(0,0,0,0.10);
	--c-mute:       #8a857c;
	--c-mute-light: #a8a39a;
	--c-text:       #1a1a1a;
	--c-text-inv:   #f5f1ea;

	/* Accent: broadcast tally red */
	--c-accent:     #e53935;
	--c-accent-hi:  #ff4842;
	--c-accent-2:   #ffa733;     /* warm signal */

	/* Type */
	--font-display: 'Anton', 'Bebas Neue', 'Impact', sans-serif;
	--font-body:    'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
	--font-mono:    'JetBrains Mono', 'SF Mono', Menlo, monospace;

	/* Layout */
	--container:    1280px;
	--gutter:       clamp(1.25rem, 4vw, 2.5rem);
	--radius:       2px;

	/* Motion */
	--ease:         cubic-bezier(0.2, 0.8, 0.2, 1);
}

/* -----------------------------------------------------------------------------
   2. RESET
   --------------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }

html {
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
}

body {
	margin: 0;
	font-family: var(--font-body);
	font-size: 17px;
	line-height: 1.6;
	color: var(--c-text);
	background: var(--c-paper);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
}

img, svg, video { max-width: 100%; height: auto; display: block; }

button { font: inherit; cursor: pointer; }

a { color: inherit; text-decoration: none; }
a:hover { color: var(--c-accent); }

ul { padding: 0; margin: 0; list-style: none; }

h1, h2, h3, h4 { margin: 0; font-weight: 700; }

.screen-reader-text {
	position: absolute !important;
	width: 1px; height: 1px;
	margin: -1px; padding: 0; border: 0;
	overflow: hidden;
	clip: rect(0,0,0,0);
}
.skip-link:focus {
	position: fixed; top: 1rem; left: 1rem;
	background: var(--c-accent); color: #fff;
	padding: .75rem 1rem; clip: auto; width: auto; height: auto; z-index: 1000;
}

::selection { background: var(--c-accent); color: #fff; }

/* -----------------------------------------------------------------------------
   3. LAYOUT PRIMITIVES
   --------------------------------------------------------------------------- */
.container {
	width: 100%;
	max-width: var(--container);
	margin: 0 auto;
	padding-left: var(--gutter);
	padding-right: var(--gutter);
}

.btn {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .95rem 1.6rem;
	font-family: var(--font-body);
	font-size: 13px;
	font-weight: 600;
	letter-spacing: .12em;
	text-transform: uppercase;
	border: 1.5px solid currentColor;
	background: transparent;
	color: currentColor;
	border-radius: var(--radius);
	transition: all .25s var(--ease);
	cursor: pointer;
}

.btn--accent {
	background: var(--c-accent);
	color: #fff;
	border-color: var(--c-accent);
}
.btn--accent:hover {
	background: var(--c-accent-hi);
	border-color: var(--c-accent-hi);
	color: #fff;
	transform: translateY(-1px);
	box-shadow: 0 8px 30px rgba(229, 57, 53, 0.35);
}

.btn--ghost {
	color: var(--c-text);
}
.btn--ghost:hover {
	background: var(--c-text);
	color: var(--c-text-inv);
	border-color: var(--c-text);
}

.btn--lg { padding: 1.15rem 2rem; font-size: 14px; }

/* On dark backgrounds */
.dark .btn--ghost,
[data-theme="dark"] .btn--ghost,
.hero .btn--ghost,
.cta-banner .btn--ghost,
.services-teaser .btn--ghost,
.service-section--dark .btn--ghost {
	color: var(--c-text-inv);
}
.hero .btn--ghost:hover,
.cta-banner .btn--ghost:hover,
.services-teaser .btn--ghost:hover,
.service-section--dark .btn--ghost:hover {
	background: var(--c-text-inv);
	color: var(--c-ink);
	border-color: var(--c-text-inv);
}

/* Section heads */
.section-head { margin-bottom: 3rem; }
.section-head__kicker {
	display: inline-block;
	font-family: var(--font-mono);
	font-size: 12px;
	letter-spacing: .15em;
	text-transform: uppercase;
	color: var(--c-accent);
	margin-bottom: 1rem;
}
.section-head__title {
	font-family: var(--font-display);
	font-size: clamp(2.25rem, 5vw, 4rem);
	line-height: 1;
	letter-spacing: -.01em;
	text-transform: uppercase;
	max-width: 22ch;
}
.section-head--dark .section-head__title { color: var(--c-text-inv); }
.section-head--dark .section-head__kicker { color: var(--c-accent-hi); }

/* -----------------------------------------------------------------------------
   4. SITE HEADER
   --------------------------------------------------------------------------- */
.site-header {
	position: sticky;
	top: 0;
	z-index: 50;
	background: rgba(10, 10, 10, 0.92);
	backdrop-filter: saturate(140%) blur(16px);
	-webkit-backdrop-filter: saturate(140%) blur(16px);
	color: var(--c-text-inv);
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-top: 1.1rem;
	padding-bottom: 1.1rem;
	gap: 2rem;
}

.site-header__rule {
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--c-line) 20%, var(--c-line) 80%, transparent);
}

.site-header__brand {
	display: flex;
	align-items: center;
	gap: .85rem;
	color: var(--c-text-inv);
}
.brand__mark {
	width: 32px; height: 32px;
	color: var(--c-accent);
	display: inline-flex;
}
.brand__text { display: flex; flex-direction: column; line-height: 1; }
.brand__name {
	font-family: var(--font-display);
	font-size: 1.4rem;
	letter-spacing: .03em;
	text-transform: uppercase;
}
.brand__tag {
	font-family: var(--font-mono);
	font-size: 9px;
	letter-spacing: .3em;
	color: var(--c-mute-light);
	margin-top: 2px;
}

.site-nav { display: flex; align-items: center; }
.nav__list {
	display: flex;
	gap: 2.25rem;
	align-items: center;
}
.nav__list a {
	font-family: var(--font-body);
	font-size: 13px;
	font-weight: 500;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--c-text-inv);
	position: relative;
	padding: .5rem 0;
}
.nav__list a::after {
	content: "";
	position: absolute;
	left: 0; bottom: 0;
	width: 0; height: 1px;
	background: var(--c-accent);
	transition: width .3s var(--ease);
}
.nav__list a:hover { color: var(--c-text-inv); }
.nav__list a:hover::after { width: 100%; }

.nav__cta { margin-left: 1.5rem; }
.site-nav .nav__cta { padding: .7rem 1.2rem; font-size: 12px; }

.nav-toggle {
	display: none;
	width: 44px; height: 44px;
	background: transparent;
	border: 1px solid var(--c-line);
	color: var(--c-text-inv);
	border-radius: var(--radius);
	padding: 12px 10px;
	flex-direction: column;
	justify-content: space-between;
}
.nav-toggle span {
	display: block; width: 100%; height: 2px;
	background: currentColor;
	transition: transform .3s var(--ease), opacity .2s var(--ease);
}
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 880px) {
	.nav-toggle { display: flex; }
	.site-nav__panel {
		position: fixed;
		inset: 73px 0 0 0;
		background: var(--c-ink);
		flex-direction: column;
		display: flex;
		gap: 0;
		padding: 2rem var(--gutter);
		transform: translateY(-100%);
		opacity: 0;
		pointer-events: none;
		transition: transform .35s var(--ease), opacity .25s var(--ease);
	}
	.site-nav__panel.is-open {
		transform: translateY(0);
		opacity: 1;
		pointer-events: auto;
	}
	.nav__list {
		flex-direction: column;
		align-items: flex-start;
		gap: 0;
		width: 100%;
		border-top: 1px solid var(--c-line);
	}
	.nav__list li {
		width: 100%;
		border-bottom: 1px solid var(--c-line);
	}
	.nav__list a {
		display: block;
		padding: 1.1rem 0;
		font-size: 18px;
	}
	.nav__cta {
		margin-left: 0;
		margin-top: 1.5rem;
		align-self: flex-start;
	}
}

/* -----------------------------------------------------------------------------
   5. HERO
   --------------------------------------------------------------------------- */
.hero {
	position: relative;
	background: var(--c-ink);
	color: var(--c-text-inv);
	overflow: hidden;
	min-height: 92vh;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 8rem 0 6rem;
}

.hero__media {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.hero__image {
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(135deg, rgba(229,57,53,0.15) 0%, transparent 40%),
		linear-gradient(180deg, rgba(10,10,10,0.4) 0%, rgba(10,10,10,0.85) 100%),
		url('https://images.squarespace-cdn.com/content/v1/663e44500ccd5d2298c477e3/1724954768282-DHWJGT2LWMAQEIKYRJDD/IMG_7001.jpg');
	background-size: cover;
	background-position: center;
	filter: contrast(1.05) saturate(1.1);
}

.hero__gradient {
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse at 20% 100%, rgba(229,57,53,0.18) 0%, transparent 50%),
		radial-gradient(ellipse at 80% 0%, rgba(255,167,51,0.10) 0%, transparent 50%),
		linear-gradient(180deg, transparent 60%, var(--c-ink) 100%);
}

.hero__grain {
	position: absolute;
	inset: 0;
	opacity: .06;
	mix-blend-mode: overlay;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200' viewBox='0 0 200 200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
}

.hero__inner {
	position: relative;
	z-index: 1;
}

.hero__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: .65rem;
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: .2em;
	text-transform: uppercase;
	color: var(--c-paper-2);
	padding: .55rem 1rem;
	border: 1px solid var(--c-line);
	border-radius: 100px;
	margin-bottom: 2.5rem;
	backdrop-filter: blur(8px);
}

.live-dot {
	width: 8px; height: 8px;
	border-radius: 50%;
	background: var(--c-accent);
	box-shadow: 0 0 0 0 rgba(229, 57, 53, 0.7);
	animation: pulse 2s var(--ease) infinite;
}
@keyframes pulse {
	0%   { box-shadow: 0 0 0 0 rgba(229, 57, 53, 0.7); }
	70%  { box-shadow: 0 0 0 12px rgba(229, 57, 53, 0); }
	100% { box-shadow: 0 0 0 0 rgba(229, 57, 53, 0); }
}

.hero__title {
	font-family: var(--font-display);
	font-size: clamp(3.5rem, 11vw, 9rem);
	line-height: 0.92;
	letter-spacing: -.015em;
	text-transform: uppercase;
	margin: 0 0 2rem;
	max-width: 14ch;
}
.hero__title-line {
	display: block;
	opacity: 0;
	transform: translateY(30px);
	animation: heroLine .9s var(--ease) forwards;
}
.hero__title-line:nth-child(1) { animation-delay: .1s; }
.hero__title-line:nth-child(2) { animation-delay: .25s; }
.hero__title-line:nth-child(3) { animation-delay: .4s; }
.hero__title-line--accent { color: var(--c-accent); }
@keyframes heroLine {
	to { opacity: 1; transform: translateY(0); }
}

.hero__lede {
	max-width: 56ch;
	font-size: clamp(1.05rem, 1.3vw, 1.25rem);
	line-height: 1.55;
	color: var(--c-paper-2);
	margin: 0 0 2.75rem;
	opacity: 0;
	animation: heroLine .9s var(--ease) .55s forwards;
}

.hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-bottom: 4.5rem;
	opacity: 0;
	animation: heroLine .9s var(--ease) .7s forwards;
}

.hero__meta {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2rem;
	max-width: 700px;
	padding-top: 2.5rem;
	border-top: 1px solid var(--c-line);
	opacity: 0;
	animation: heroLine .9s var(--ease) .85s forwards;
}
.hero__meta-item { display: flex; flex-direction: column; gap: .35rem; }
.hero__meta-num {
	font-family: var(--font-display);
	font-size: clamp(1.75rem, 3vw, 2.5rem);
	line-height: 1;
	color: var(--c-text-inv);
}
.hero__meta-label {
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: .15em;
	text-transform: uppercase;
	color: var(--c-mute-light);
}

@media (max-width: 600px) {
	.hero__meta { grid-template-columns: 1fr; gap: 1.25rem; }
}

/* Ticker */
.hero__ticker {
	position: relative;
	z-index: 1;
	margin-top: 4rem;
	padding: 1rem 0;
	border-top: 1px solid var(--c-line);
	border-bottom: 1px solid var(--c-line);
	overflow: hidden;
	font-family: var(--font-display);
	letter-spacing: .1em;
}
.ticker__track {
	display: flex;
	gap: 2.5rem;
	white-space: nowrap;
	animation: ticker 40s linear infinite;
	font-size: 1.5rem;
	color: var(--c-mute-light);
}
.ticker__track span:nth-child(odd) { color: var(--c-text-inv); }
.ticker__track span:nth-child(even) { color: var(--c-accent); font-size: .9em; }
@keyframes ticker {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}

/* -----------------------------------------------------------------------------
   6. PILLARS
   --------------------------------------------------------------------------- */
.pillars {
	background: var(--c-paper);
	padding: 7rem 0;
	border-bottom: 1px solid var(--c-line-dark);
}

.pillars__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2.5rem;
}

.pillar {
	padding: 2.5rem 0 0;
	border-top: 2px solid var(--c-ink);
	position: relative;
}
.pillar__num {
	font-family: var(--font-mono);
	font-size: 13px;
	color: var(--c-mute);
	margin-bottom: 1.5rem;
	display: block;
}
.pillar__title {
	font-family: var(--font-display);
	font-size: 2rem;
	letter-spacing: .01em;
	text-transform: uppercase;
	margin-bottom: 1rem;
}
.pillar p {
	font-size: 1rem;
	line-height: 1.65;
	color: #444;
	margin: 0;
}

@media (max-width: 880px) {
	.pillars__grid { grid-template-columns: 1fr; gap: 2rem; }
	.pillars { padding: 4rem 0; }
}

/* -----------------------------------------------------------------------------
   7. SERVICES TEASER
   --------------------------------------------------------------------------- */
.services-teaser {
	background: var(--c-ink);
	color: var(--c-text-inv);
	padding: 7rem 0;
	position: relative;
}
.services-teaser::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse at 80% 20%, rgba(229,57,53,0.08) 0%, transparent 60%);
	pointer-events: none;
}

.services-teaser__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1.5rem;
	position: relative;
}

.service-card {
	background: var(--c-ink-2);
	border: 1px solid var(--c-line);
	color: var(--c-text-inv);
	overflow: hidden;
	transition: transform .4s var(--ease), border-color .3s var(--ease);
	display: flex;
	flex-direction: column;
}
.service-card:hover {
	transform: translateY(-4px);
	border-color: var(--c-accent);
	color: var(--c-text-inv);
}

.service-card__media {
	height: 280px;
	background-size: cover;
	background-position: center;
	position: relative;
	overflow: hidden;
}
.service-card__media::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 50%, rgba(20,20,20,0.5) 100%);
}
.service-card:hover .service-card__media {
	filter: brightness(1.1);
}

.service-card__media[data-service="sports"] {
	background-image: linear-gradient(135deg, rgba(229,57,53,0.2), rgba(0,0,0,0.4)), url('https://images.squarespace-cdn.com/content/v1/663e44500ccd5d2298c477e3/f498ff57-c216-4183-96b6-8d11c8bad596/IMG_6997.JPG');
}
.service-card__media[data-service="concerts"] {
	background-image: linear-gradient(135deg, rgba(229,57,53,0.2), rgba(0,0,0,0.4)), url('https://images.squarespace-cdn.com/content/v1/663e44500ccd5d2298c477e3/43ac0de7-ffc5-4cb6-985b-21a56002e17c/IMG_7668.JPG');
}
.service-card__media[data-service="events"] {
	background-image: linear-gradient(135deg, rgba(229,57,53,0.2), rgba(0,0,0,0.4)), url('https://images.squarespace-cdn.com/content/v1/663e44500ccd5d2298c477e3/099c64bf-bf3c-4246-a42e-88840aeb4c71/IMG_6998.JPG');
}
.service-card__media[data-service="consultation"] {
	background-image: linear-gradient(135deg, rgba(229,57,53,0.2), rgba(0,0,0,0.4)), url('https://images.squarespace-cdn.com/content/v1/663e44500ccd5d2298c477e3/0a1fbae9-ecf1-47cc-adb8-49221dc008c9/IMG_7202.JPG');
}

.service-card__body { padding: 2rem 2rem 2.25rem; flex: 1; display: flex; flex-direction: column; }
.service-card__num {
	font-family: var(--font-mono);
	font-size: 11px;
	color: var(--c-accent);
	letter-spacing: .15em;
	margin-bottom: 1rem;
	display: block;
}
.service-card__title {
	font-family: var(--font-display);
	font-size: 2rem;
	letter-spacing: .01em;
	text-transform: uppercase;
	margin-bottom: .75rem;
}
.service-card__body p {
	color: var(--c-mute-light);
	margin: 0 0 1.5rem;
	font-size: .98rem;
	line-height: 1.55;
	flex: 1;
}
.service-card__more {
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: .15em;
	text-transform: uppercase;
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	color: var(--c-text-inv);
}
.service-card:hover .service-card__more { color: var(--c-accent); }
.service-card:hover .service-card__more svg { transform: translateX(4px); }
.service-card__more svg { transition: transform .3s var(--ease); }

@media (max-width: 700px) {
	.services-teaser__grid { grid-template-columns: 1fr; }
	.service-card__media { height: 220px; }
	.services-teaser { padding: 4rem 0; }
}

/* -----------------------------------------------------------------------------
   8. CAPABILITIES STRIP
   --------------------------------------------------------------------------- */
.capabilities {
	background: var(--c-paper);
	padding: 7rem 0;
}
.capabilities__inner {
	display: grid;
	grid-template-columns: 1fr 1.2fr;
	gap: 4rem;
	align-items: start;
}
.capabilities__title {
	font-family: var(--font-display);
	font-size: clamp(2.5rem, 5.5vw, 4.5rem);
	line-height: .95;
	letter-spacing: -.01em;
	text-transform: uppercase;
}
.capabilities__list {
	columns: 2;
	column-gap: 2rem;
}
.capabilities__list li {
	font-size: 1.05rem;
	padding: 1rem 0;
	border-bottom: 1px solid var(--c-line-dark);
	break-inside: avoid;
	position: relative;
	padding-left: 1.5rem;
}
.capabilities__list li::before {
	content: "+";
	position: absolute;
	left: 0;
	color: var(--c-accent);
	font-weight: 600;
}

@media (max-width: 880px) {
	.capabilities__inner { grid-template-columns: 1fr; gap: 2rem; }
	.capabilities__list { columns: 1; }
	.capabilities { padding: 4rem 0; }
}

/* -----------------------------------------------------------------------------
   9. CTA BANNER
   --------------------------------------------------------------------------- */
.cta-banner {
	background: var(--c-ink);
	color: var(--c-text-inv);
	padding: 5rem 0;
	border-top: 1px solid var(--c-line);
	position: relative;
	overflow: hidden;
}
.cta-banner::before {
	content: "";
	position: absolute;
	top: -50%; right: -20%;
	width: 800px; height: 800px;
	background: radial-gradient(circle, rgba(229,57,53,0.15) 0%, transparent 60%);
	pointer-events: none;
}
.cta-banner__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 3rem;
	position: relative;
}
.cta-banner__kicker {
	font-family: var(--font-mono);
	font-size: 12px;
	letter-spacing: .15em;
	text-transform: uppercase;
	color: var(--c-accent-hi);
	display: block;
	margin-bottom: .75rem;
}
.cta-banner__title {
	font-family: var(--font-display);
	font-size: clamp(1.75rem, 3.5vw, 2.75rem);
	letter-spacing: -.01em;
	text-transform: uppercase;
	max-width: 22ch;
	line-height: 1.05;
}

@media (max-width: 800px) {
	.cta-banner__inner { flex-direction: column; align-items: flex-start; }
}

/* -----------------------------------------------------------------------------
   10. PAGE HERO (interior pages)
   --------------------------------------------------------------------------- */
.page-hero {
	background: var(--c-ink);
	color: var(--c-text-inv);
	padding: 8rem 0 5rem;
	position: relative;
	overflow: hidden;
}
.page-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse at 20% 100%, rgba(229,57,53,0.10) 0%, transparent 50%),
		linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.4) 100%);
	pointer-events: none;
}

.page-hero__kicker {
	font-family: var(--font-mono);
	font-size: 12px;
	letter-spacing: .15em;
	text-transform: uppercase;
	color: var(--c-accent-hi);
	margin-bottom: 1.5rem;
	display: block;
}
.page-hero__title {
	font-family: var(--font-display);
	font-size: clamp(3rem, 9vw, 7rem);
	line-height: .9;
	letter-spacing: -.015em;
	text-transform: uppercase;
	margin-bottom: 2rem;
}
.page-hero__lede {
	max-width: 60ch;
	font-size: clamp(1.05rem, 1.2vw, 1.2rem);
	line-height: 1.6;
	color: var(--c-paper-2);
}

/* -----------------------------------------------------------------------------
   11. SERVICES PAGE - DETAIL SECTIONS
   --------------------------------------------------------------------------- */
.service-section {
	padding: 7rem 0;
	background: var(--c-paper);
}
.service-section--dark {
	background: var(--c-ink-2);
	color: var(--c-text-inv);
}

.service-section__inner {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: 4rem;
	align-items: center;
}
.service-section__inner--reverse .service-section__media { order: 2; }

.service-section__media {
	aspect-ratio: 4 / 5;
	background-size: cover;
	background-position: center;
	position: relative;
	overflow: hidden;
}
.service-section__media::after {
	content: "";
	position: absolute;
	inset: 0;
	border: 1px solid rgba(255,255,255,0.06);
	pointer-events: none;
}

.service-section__media[data-service="sports"] {
	background-image: linear-gradient(135deg, rgba(229,57,53,0.15), rgba(0,0,0,0.25)), url('https://images.squarespace-cdn.com/content/v1/663e44500ccd5d2298c477e3/f498ff57-c216-4183-96b6-8d11c8bad596/IMG_6997.JPG');
}
.service-section__media[data-service="concerts"] {
	background-image: linear-gradient(135deg, rgba(229,57,53,0.15), rgba(0,0,0,0.25)), url('https://images.squarespace-cdn.com/content/v1/663e44500ccd5d2298c477e3/43ac0de7-ffc5-4cb6-985b-21a56002e17c/IMG_7668.JPG');
}
.service-section__media[data-service="events"] {
	background-image: linear-gradient(135deg, rgba(229,57,53,0.15), rgba(0,0,0,0.25)), url('https://images.squarespace-cdn.com/content/v1/663e44500ccd5d2298c477e3/099c64bf-bf3c-4246-a42e-88840aeb4c71/IMG_6998.JPG');
}
.service-section__media[data-service="consultation"] {
	background-image: linear-gradient(135deg, rgba(229,57,53,0.15), rgba(0,0,0,0.25)), url('https://images.squarespace-cdn.com/content/v1/663e44500ccd5d2298c477e3/0a1fbae9-ecf1-47cc-adb8-49221dc008c9/IMG_7202.JPG');
}

.service-section__num {
	font-family: var(--font-mono);
	font-size: 12px;
	letter-spacing: .15em;
	text-transform: uppercase;
	color: var(--c-accent);
	display: block;
	margin-bottom: 1.25rem;
}
.service-section__title {
	font-family: var(--font-display);
	font-size: clamp(2.5rem, 5vw, 3.75rem);
	line-height: 1;
	letter-spacing: -.01em;
	text-transform: uppercase;
	margin-bottom: 1.5rem;
}
.service-section__lede {
	font-size: 1.1rem;
	line-height: 1.6;
	margin-bottom: 2rem;
	color: inherit;
	opacity: .9;
}
.service-section__list {
	margin-bottom: 2.5rem;
	border-top: 1px solid var(--c-line-dark);
}
.service-section--dark .service-section__list { border-top-color: var(--c-line); }
.service-section__list li {
	padding: .9rem 0 .9rem 1.5rem;
	border-bottom: 1px solid var(--c-line-dark);
	position: relative;
	font-size: 1rem;
}
.service-section--dark .service-section__list li { border-bottom-color: var(--c-line); }
.service-section__list li::before {
	content: "›";
	position: absolute;
	left: 0;
	color: var(--c-accent);
	font-weight: 700;
}

@media (max-width: 880px) {
	.service-section { padding: 4rem 0; }
	.service-section__inner,
	.service-section__inner--reverse {
		grid-template-columns: 1fr;
		gap: 2rem;
	}
	.service-section__inner--reverse .service-section__media { order: 0; }
	.service-section__media { aspect-ratio: 4 / 3; }
}

/* -----------------------------------------------------------------------------
   12. TEAM PAGE
   --------------------------------------------------------------------------- */
.team-grid {
	background: var(--c-paper);
	padding: 5rem 0 6rem;
}

.team-grid__layout {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	grid-auto-rows: 250px;
	gap: 1rem;
}

.team-photo {
	margin: 0;
	background-size: cover;
	background-position: center;
	background-color: var(--c-ink-3);
	position: relative;
	overflow: hidden;
	transition: transform .5s var(--ease);
}
.team-photo:hover { transform: scale(1.01); }
.team-photo::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.6));
}

.team-photo figcaption {
	position: absolute;
	bottom: 1rem; left: 1.25rem;
	z-index: 1;
	color: var(--c-text-inv);
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: .15em;
	text-transform: uppercase;
	opacity: 0;
	transform: translateY(8px);
	transition: opacity .3s var(--ease), transform .3s var(--ease);
}
.team-photo:hover figcaption { opacity: 1; transform: translateY(0); }

.team-photo--tall { grid-row: span 2; }
.team-photo--wide { grid-column: span 2; }

.team-photo[data-team="1"] { background-image: url('https://images.squarespace-cdn.com/content/v1/663e44500ccd5d2298c477e3/0ce276f2-f636-4b2e-bb8c-b94686ea5f14/IMG_7010.JPG'); }
.team-photo[data-team="2"] { background-image: url('https://images.squarespace-cdn.com/content/v1/663e44500ccd5d2298c477e3/f69a5ca6-92ab-49a9-a6a2-84b5e969b164/IMG_7006.JPG'); }
.team-photo[data-team="3"] { background-image: url('https://images.squarespace-cdn.com/content/v1/663e44500ccd5d2298c477e3/e105be3a-f3ca-4fad-97cd-422a34d88bc8/51A6BF2D-E547-4787-AEDD-41BA3A162F82.JPG'); }
.team-photo[data-team="4"] { background-image: url('https://images.squarespace-cdn.com/content/v1/663e44500ccd5d2298c477e3/e601a0c7-6b57-482e-88eb-a1a90b2a333e/IMG_7016.JPG'); }
.team-photo[data-team="5"] { background-image: url('https://images.squarespace-cdn.com/content/v1/663e44500ccd5d2298c477e3/a8e39dfb-00ab-4393-beb4-530c06caae17/IMG_6990.JPG'); }
.team-photo[data-team="6"] { background-image: url('https://images.squarespace-cdn.com/content/v1/663e44500ccd5d2298c477e3/5361b0a1-7579-497a-993b-375f7ac794df/Copy+of+66728445701__4F84ED1F-F358-4382-AFC5-6EE698953DE3+%281%29.JPG'); }

@media (max-width: 880px) {
	.team-grid__layout { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 200px; }
	.team-photo--wide { grid-column: span 2; }
	.team-photo--tall { grid-row: span 1; }
}

.team-values {
	background: var(--c-ink);
	color: var(--c-text-inv);
	padding: 7rem 0;
}
.team-values .section-head__title { color: var(--c-text-inv); }
.team-values__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2.5rem;
}
.value {
	padding: 2rem 0 0;
	border-top: 2px solid var(--c-accent);
}
.value__title {
	font-family: var(--font-display);
	font-size: 1.75rem;
	letter-spacing: .01em;
	text-transform: uppercase;
	margin-bottom: 1rem;
}
.value p { color: var(--c-mute-light); line-height: 1.65; margin: 0; }

@media (max-width: 880px) {
	.team-values__grid { grid-template-columns: 1fr; gap: 2rem; }
	.team-values { padding: 4rem 0; }
}

/* -----------------------------------------------------------------------------
   13. CONNECT PAGE
   --------------------------------------------------------------------------- */
.connect {
	background: var(--c-paper);
	padding: 6rem 0 7rem;
}

.connect__grid {
	display: grid;
	grid-template-columns: 1fr 1.4fr;
	gap: 5rem;
	align-items: start;
}

.connect__info { display: flex; flex-direction: column; gap: 2.5rem; }
.connect__info-block {}
.connect__heading {
	font-family: var(--font-display);
	font-size: clamp(1.75rem, 3vw, 2.25rem);
	letter-spacing: -.01em;
	text-transform: uppercase;
	margin-bottom: 1rem;
}
.connect__sub {
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: .15em;
	text-transform: uppercase;
	color: var(--c-mute);
	margin-bottom: .65rem;
}
.connect__link {
	font-size: 1.05rem;
	font-weight: 500;
	color: var(--c-ink);
	border-bottom: 1px solid var(--c-ink);
	padding-bottom: 2px;
	display: inline-block;
}
.connect__link:hover { color: var(--c-accent); border-bottom-color: var(--c-accent); }

.connect__social { display: flex; gap: 1.5rem; }
.connect__social a {
	font-family: var(--font-mono);
	font-size: 12px;
	letter-spacing: .12em;
	text-transform: uppercase;
}

/* Form */
.connect__form {
	background: #fff;
	border: 1px solid var(--c-line-dark);
	padding: 2.5rem;
}
.form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1.25rem;
	margin-bottom: 1.25rem;
}
.connect__form label {
	display: block;
	margin-bottom: 1.25rem;
}
.connect__form .form-row label { margin-bottom: 0; }
.form-label {
	display: block;
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: .15em;
	text-transform: uppercase;
	color: var(--c-mute);
	margin-bottom: .5rem;
}
.req { color: var(--c-accent); }

.connect__form input,
.connect__form select,
.connect__form textarea {
	width: 100%;
	font: inherit;
	font-size: 1rem;
	color: var(--c-text);
	background: transparent;
	border: 0;
	border-bottom: 1.5px solid var(--c-ink);
	padding: .75rem 0;
	transition: border-color .25s var(--ease);
}
.connect__form input:focus,
.connect__form select:focus,
.connect__form textarea:focus {
	outline: 0;
	border-bottom-color: var(--c-accent);
}
.connect__form textarea { resize: vertical; min-height: 140px; }

.hp { position: absolute; left: -10000px; }

.form-actions {
	margin-top: 2rem;
	display: flex;
	align-items: center;
	gap: 1.5rem;
	flex-wrap: wrap;
}
.form-status {
	font-family: var(--font-mono);
	font-size: 12px;
	letter-spacing: .1em;
	text-transform: uppercase;
}
.form-status.is-success { color: #2e7d32; }
.form-status.is-error { color: var(--c-accent); }

@media (max-width: 880px) {
	.connect__grid { grid-template-columns: 1fr; gap: 3rem; }
	.form-row { grid-template-columns: 1fr; }
	.connect__form { padding: 1.5rem; }
}

/* -----------------------------------------------------------------------------
   14. SITE FOOTER
   --------------------------------------------------------------------------- */
.site-footer {
	background: var(--c-ink);
	color: var(--c-text-inv);
	padding: 5rem 0 2rem;
}

.site-footer__grid {
	display: grid;
	grid-template-columns: 2fr 1fr 1.2fr;
	gap: 3rem;
	margin-bottom: 4rem;
}

.site-footer__logo { display: flex; flex-direction: column; line-height: 1; margin-bottom: 1.25rem; }
.site-footer__logo .brand__name { color: var(--c-text-inv); font-size: 1.6rem; }
.site-footer__logo .brand__tag { color: var(--c-mute-light); }

.site-footer__tagline {
	color: var(--c-mute-light);
	max-width: 40ch;
	font-size: .95rem;
	line-height: 1.55;
	margin: 0;
}

.site-footer__heading {
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: .2em;
	text-transform: uppercase;
	color: var(--c-mute-light);
	margin-bottom: 1.25rem;
}
.site-footer__col ul li { margin-bottom: .65rem; }
.site-footer__col a { color: var(--c-text-inv); font-size: .95rem; }
.site-footer__col a:hover { color: var(--c-accent); }

.site-footer__social { display: flex; gap: 1rem; margin-top: 1.25rem; }
.site-footer__social a {
	width: 38px; height: 38px;
	display: inline-flex; align-items: center; justify-content: center;
	border: 1px solid var(--c-line);
	color: var(--c-text-inv);
	transition: all .2s var(--ease);
}
.site-footer__social a:hover { border-color: var(--c-accent); color: var(--c-accent); }

.site-footer__rule {
	height: 1px;
	background: var(--c-line);
	margin-bottom: 2rem;
}

.site-footer__bottom {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 1rem;
}
.site-footer__copy,
.site-footer__credit {
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: .1em;
	color: var(--c-mute-light);
	margin: 0;
}
.site-footer__credit a { color: var(--c-text-inv); }
.site-footer__credit a:hover { color: var(--c-accent); }

@media (max-width: 880px) {
	.site-footer__grid { grid-template-columns: 1fr; gap: 2.5rem; }
	.site-footer { padding: 3.5rem 0 1.5rem; }
}

/* -----------------------------------------------------------------------------
   15. UTILITY / MOTION
   --------------------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: .001ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: .001ms !important;
	}
}

/* Reveal on scroll */
.reveal {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity .8s var(--ease), transform .8s var(--ease);
}
.reveal.is-visible {
	opacity: 1;
	transform: translateY(0);
}
