.sponsors-page {
	position: relative;
}

.sponsors-hero-panel,
.sponsors-main-panel,
.sponsors-feature-photo {
	border: 1px solid var(--tone-line);
	border-radius: 1rem;
	background: var(--tone-panel);
	box-shadow: var(--tone-shadow-soft);
}

.sponsors-hero-panel,
.sponsors-main-panel {
	padding: 1.25rem;
}

.sponsors-hero-panel {
	padding: 1.45rem 1.5rem;
}

.sponsors-hero-layout {
	display: grid;
	grid-template-columns: minmax(180px, 240px) minmax(0, 1fr);
	align-items: center;
	gap: 1.6rem;
}

.sponsors-hero-media {
	display: flex;
	align-items: center;
	justify-content: center;
}

.sponsors-hero-copy {
	text-align: left;
	display: grid;
	gap: 0.3rem;
	align-content: center;
}

.sponsors-feature-photo {
	padding: 0.75rem;
}

.sponsors-kicker {
	margin: 0 0 0.4rem;
	font-size: 0.76rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(0, 0, 103, 0.65);
}

.sponsors-page h1 {
	margin-bottom: 0.2rem;
	padding: 0;
	font-size: clamp(1.2rem, 1.04rem + 0.5vw, 1.6rem);
	line-height: 1.08;
	text-align: left;
}

.sponsors-hero-logo {
	max-width: 200px;
	height: auto;
	margin-bottom: 0;
}

.sponsors-subtitle {
	margin: 0.1rem 0 0;
	max-width: 31rem;
	font-size: clamp(0.98rem, 0.94rem + 0.2vw, 1.1rem);
	line-height: 1.45;
	color: var(--color-blue);
}

.sponsors-subtitle--hero {
	margin: 0.35rem 0 0;
	max-width: none;
	font-family: "Kalam", "Segoe Print", "Comic Sans MS", cursive;
	font-size: clamp(1.2rem, 1.02rem + 0.6vw, 1.7rem);
	line-height: 1.3;
	text-align: left;
	color: rgba(0, 0, 103, 0.82);
}

.sponsors-logo-grid {
	row-gap: 0.85rem;
}

.sponsors-logo-grid__item {
	width: 50%;
}

.sponsors-page .sponsor-card {
	margin-bottom: 0;
	padding: 0 0.35rem;
}

.sponsors-page .sponsor-card p {
	margin-bottom: 0;
}

.sponsors-page .sponsor-card img {
	width: 100%;
}

.sponsors-page .sponsor-card__link {
	font-size: 0.9rem;
}

.sponsors-page h2 {
	margin-bottom: 0.65rem;
	padding: 0;
	font-size: clamp(1.35rem, 1.1rem + 0.7vw, 1.9rem);
	text-align: left;
}

.sponsors-page h3 {
	margin-bottom: 0.45rem;
	color: var(--color-blue);
	font-size: clamp(1.02rem, 0.96rem + 0.25vw, 1.2rem);
}

.sponsors-page h4 {
	margin-bottom: 0.4rem;
	font-size: 0.95rem;
	color: rgba(0, 0, 103, 0.75);
}

.sponsors-page p,
.sponsors-page .intro,
.sponsors-page li {
	font-size: 0.98rem;
}

.sponsors-page p:last-child,
.sponsors-page ul:last-child {
	margin-bottom: 0;
}

.sponsors-page ul {
	margin-bottom: 0;
}

.sponsors-section + .sponsors-section {
	margin-top: 0.25rem;
	padding-top: 0.25rem;
	border-top: 1px solid rgba(15, 23, 42, 0.06);
}

.sponsors-photo-row img {
	width: 100%;
}

.sponsors-signoff .signature {
	margin-bottom: 0.6rem;
}

@media (min-width: 768px) {
	.sponsors-logo-grid__item {
		width: 25%;
	}
}

@media (min-width: 1200px) {
	.sponsors-logo-grid__item {
		width: 12.5%;
	}
}

@media (max-width: 767px) {
	.sponsors-hero-panel,
	.sponsors-main-panel {
		padding: 1rem;
	}

	.sponsors-hero-layout {
		grid-template-columns: 1fr;
		gap: 0.9rem;
	}

	.sponsors-hero-copy,
	.sponsors-page h1 {
		text-align: center;
	}

	.sponsors-subtitle {
		margin: 0 auto;
		text-align: center;
	}

	.sponsors-subtitle--hero {
		margin-top: 0.6rem;
		text-align: center;
	}

	.sponsors-page h2,
	.sponsors-page h3,
	.sponsors-page h4 {
		text-align: center;
	}

	.sponsors-page .intro,
	.sponsors-page p {
		text-align: left;
	}

	.sponsors-signoff .signature {
		display: block;
		margin-left: auto;
		margin-right: auto;
	}
}

