/* ==========================================================================
   Northfield Theatre — Take Part page
   ========================================================================== */

.takepart-page { background: var(--color-bg); }

/* Hero */
.takepart-hero {
	background: var(--color-dark);
	color: var(--color-bg);
	padding: var(--space-3xl) 0;
	position: relative;
	overflow: hidden;
}
.takepart-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at 20% 40%, rgba(232, 163, 61, 0.14), transparent 55%);
	pointer-events: none;
}
.takepart-hero__inner { position: relative; max-width: 920px; }
.takepart-hero__eyebrow {
	font-size: var(--text-sm);
	font-weight: var(--weight-semibold);
	letter-spacing: 0.25em;
	text-transform: uppercase;
	color: var(--color-accent);
	margin-bottom: var(--space-lg);
}
.takepart-hero__title {
	color: var(--color-bg);
	font-size: clamp(2.5rem, 6vw, 4.75rem);
	font-weight: var(--weight-black);
	line-height: 1;
	letter-spacing: -0.02em;
	margin-bottom: var(--space-lg);
}
.takepart-hero__lead {
	font-size: var(--text-xl);
	line-height: 1.4;
	color: rgba(255, 255, 255, 0.85);
	max-width: 62ch;
	font-family: var(--font-heading);
	font-style: italic;
	font-weight: var(--weight-medium);
}

/* Stats band */
.takepart-stats { padding: var(--space-2xl) 0; }
.takepart-stats__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-xl);
}
@media (min-width: 768px) {
	.takepart-stats__grid { grid-template-columns: repeat(4, 1fr); }
}
.takepart-stats__item {
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
	border-left: 2px solid var(--color-accent);
	padding-left: var(--space-md);
}
.takepart-stats__value {
	font-family: var(--font-heading);
	font-size: clamp(2rem, 5vw, 3.5rem);
	font-weight: var(--weight-black);
	color: var(--color-dark);
	line-height: 1;
	letter-spacing: -0.02em;
}
.takepart-stats__label {
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	font-weight: var(--weight-medium);
	line-height: var(--leading-snug);
}

/* Programmes grid */
.takepart-programmes__header { margin-bottom: var(--space-2xl); max-width: 600px; }
.takepart-programmes__eyebrow {
	font-size: var(--text-sm);
	font-weight: var(--weight-semibold);
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--color-text-muted);
	margin-bottom: var(--space-md);
}
.takepart-programmes__heading {
	font-family: var(--font-heading);
	font-size: clamp(1.75rem, 4vw, 3rem);
	font-weight: var(--weight-extrabold);
	letter-spacing: -0.02em;
}
.takepart-programmes__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-xl);
}
@media (min-width: 720px) {
	.takepart-programmes__grid { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 1100px) {
	.takepart-programmes__grid { grid-template-columns: repeat(3, 1fr); }
}
.takepart-card {
	display: flex;
	flex-direction: column;
	padding: var(--space-xl);
	background: var(--color-bg);
	border-top: 3px solid var(--color-accent);
	border: 1px solid var(--color-border);
	border-top: 3px solid var(--color-accent);
	transition: box-shadow var(--transition-base), transform var(--transition-base);
}
.takepart-card:hover {
	box-shadow: var(--shadow-lg);
	transform: translateY(-2px);
}
.takepart-card__eyebrow {
	font-size: var(--text-xs);
	font-weight: var(--weight-bold);
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--color-primary);
	margin-bottom: var(--space-sm);
}
.takepart-card__title {
	font-family: var(--font-heading);
	font-size: var(--text-2xl);
	font-weight: var(--weight-extrabold);
	line-height: 1.1;
	letter-spacing: -0.01em;
	margin-bottom: var(--space-md);
	color: var(--color-dark);
}
.takepart-card__body {
	color: var(--color-text);
	font-size: var(--text-base);
	line-height: var(--leading-normal);
	margin-bottom: var(--space-md);
	flex: 1;
}
.takepart-card__meta {
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	font-weight: var(--weight-semibold);
	padding-top: var(--space-md);
	border-top: 1px solid var(--color-border);
	margin-bottom: var(--space-md);
}
.takepart-card__cta {
	color: var(--color-primary);
	font-weight: var(--weight-bold);
	text-decoration: none;
	align-self: flex-start;
	letter-spacing: 0.01em;
}
.takepart-card__cta:hover {
	color: var(--color-primary-dark);
}

/* Bursary */
.takepart-bursary__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-xl);
}
@media (min-width: 900px) {
	.takepart-bursary__grid {
		grid-template-columns: 1fr 1.3fr;
		gap: var(--space-3xl);
	}
}
.takepart-bursary__eyebrow {
	font-size: var(--text-sm);
	font-weight: var(--weight-semibold);
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--color-text-muted);
	margin-bottom: var(--space-md);
}
.takepart-bursary__heading {
	font-family: var(--font-heading);
	font-size: clamp(1.75rem, 4vw, 2.75rem);
	font-weight: var(--weight-extrabold);
	letter-spacing: -0.02em;
	line-height: 1.1;
	color: var(--color-dark);
}
.takepart-bursary__body {
	font-size: var(--text-lg);
	line-height: var(--leading-normal);
	color: var(--color-text);
}
.takepart-bursary__body p { margin-bottom: var(--space-md); }

/* CTA */
.takepart-cta {
	background: var(--color-primary);
	color: var(--color-bg);
	padding: var(--space-3xl) 0;
	position: relative;
	overflow: hidden;
}
.takepart-cta::before {
	content: '';
	position: absolute;
	top: -60%;
	right: -20%;
	width: 600px;
	height: 600px;
	background: radial-gradient(circle, rgba(232, 163, 61, 0.2) 0%, transparent 70%);
	pointer-events: none;
}
.takepart-cta__inner { max-width: 720px; position: relative; }
.takepart-cta__heading {
	font-family: var(--font-heading);
	font-size: clamp(2rem, 4.5vw, 3rem);
	font-weight: var(--weight-black);
	letter-spacing: -0.02em;
	color: var(--color-bg);
	line-height: 1.1;
	margin-bottom: var(--space-lg);
}
.takepart-cta__body {
	font-size: var(--text-lg);
	line-height: var(--leading-normal);
	color: rgba(255, 255, 255, 0.9);
	margin-bottom: var(--space-xl);
	max-width: 56ch;
}
.takepart-cta__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-md);
}
