/**
 * PPCJobs homepage — “Browse jobs” stacked hub (light lavender + purple hover).
 * Loaded only on the front page.
 */

.ppcjobs-home-browse-hub-stack {
	--ppcjobs-hub-bg: #f3e8ff;
	--ppcjobs-hub-border: #e9d5ff;
	--ppcjobs-hub-text: #581c87;
	--ppcjobs-hub-hover-bg: #9333ea;
	--ppcjobs-hub-hover-text: #fff;
	--ppcjobs-hub-active-bg: #7e22ce;
	--ppcjobs-hub-active-text: #fff;
	--ppcjobs-hub-radius: 9999px;
	--ppcjobs-hub-gap: 0.85rem;
	--ppcjobs-hub-pill-py: 0.75rem;
	--ppcjobs-hub-pill-px: 1.25rem;
	--ppcjobs-hub-font: clamp(1rem, 1.35vw, 1.125rem);
	--ppcjobs-hub-icon: 1.35rem;
	margin: 0 auto 3rem;
	padding: 0.5rem 0 0.75rem;
	max-width: 100%;
}

@media (min-width: 992px) {
	.ppcjobs-home-browse-hub-stack {
		--ppcjobs-hub-gap: 1rem;
		--ppcjobs-hub-pill-py: 0.85rem;
		--ppcjobs-hub-pill-px: 1.4rem;
		--ppcjobs-hub-icon: 1.5rem;
	}
}

.ppcjobs-home-browse-hub-stack__title {
	margin: 0 0 2rem;
	text-align: center;
	font-size: clamp(1.85rem, 3.5vw, 2.5rem);
	font-weight: 800;
	color: #1f2937;
	letter-spacing: -0.02em;
}

.ppcjobs-home-browse-hub-stack__section {
	margin: 0 0 2.25rem;
}

.ppcjobs-home-browse-hub-stack__section:last-child {
	margin-bottom: 0;
}

.ppcjobs-home-browse-hub-stack__heading {
	margin: 0 0 0.85rem;
	font-size: clamp(1.05rem, 1.5vw, 1.2rem);
	font-weight: 700;
	color: #111827;
	text-align: left;
}

.ppcjobs-home-browse-hub-stack__row {
	display: flex;
	flex-wrap: wrap;
	gap: var(--ppcjobs-hub-gap);
	align-items: center;
}

.ppcjobs-home-browse-hub-stack__row--ad-channel {
	flex-wrap: nowrap;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	padding-bottom: 0.15rem;
	scrollbar-width: thin;
}

@media (max-width: 639px) {
	.ppcjobs-home-browse-hub-stack__row--ad-channel {
		flex-wrap: wrap;
		overflow-x: visible;
	}
}

.ppcjobs-home-browse-hub-stack__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.55rem;
	padding: var(--ppcjobs-hub-pill-py) var(--ppcjobs-hub-pill-px);
	border-radius: var(--ppcjobs-hub-radius);
	border: 1px solid var(--ppcjobs-hub-border);
	background: var(--ppcjobs-hub-bg);
	color: var(--ppcjobs-hub-text);
	font-size: var(--ppcjobs-hub-font);
	font-weight: 600;
	text-decoration: none;
	line-height: 1.25;
	white-space: nowrap;
	transition:
		background-color 0.18s ease,
		color 0.18s ease,
		border-color 0.18s ease,
		box-shadow 0.18s ease;
}

.ppcjobs-home-browse-hub-stack__btn:hover,
.ppcjobs-home-browse-hub-stack__btn:focus-visible {
	background: var(--ppcjobs-hub-hover-bg);
	border-color: var(--ppcjobs-hub-hover-bg);
	color: var(--ppcjobs-hub-hover-text);
	box-shadow: 0 2px 10px rgba(147, 51, 234, 0.35);
	outline: none;
}

.ppcjobs-home-browse-hub-stack__btn.is-active {
	background: var(--ppcjobs-hub-active-bg);
	border-color: var(--ppcjobs-hub-active-bg);
	color: var(--ppcjobs-hub-active-text);
}

.ppcjobs-home-browse-hub-stack__btn.is-active:hover,
.ppcjobs-home-browse-hub-stack__btn.is-active:focus-visible {
	background: #7e22ce;
	border-color: #7e22ce;
	color: #fff;
}

.ppcjobs-home-browse-hub-stack__btn .fa {
	font-size: var(--ppcjobs-hub-icon);
	width: 1.25em;
	text-align: center;
	opacity: 0.95;
}

.ppcjobs-home-browse-hub-stack__brand-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--ppcjobs-hub-gap);
	list-style: none;
	margin: 0;
	padding: 0;
}

@media (min-width: 768px) {
	.ppcjobs-home-browse-hub-stack__brand-grid {
		grid-template-columns: repeat(5, minmax(0, 1fr));
	}
}

.ppcjobs-home-browse-hub-stack__brand {
	margin: 0;
}

.ppcjobs-home-browse-hub-stack__brand-link {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	width: 100%;
	min-height: 3.5rem;
	padding: 0.65rem 0.85rem;
	border-radius: 0.75rem;
	border: 1px solid var(--ppcjobs-hub-border);
	background: var(--ppcjobs-hub-bg);
	color: var(--ppcjobs-hub-text);
	font-size: var(--ppcjobs-hub-font);
	font-weight: 600;
	text-decoration: none;
	text-align: left;
	transition:
		background-color 0.18s ease,
		color 0.18s ease,
		border-color 0.18s ease,
		box-shadow 0.18s ease;
}

.ppcjobs-home-browse-hub-stack__brand-link:hover,
.ppcjobs-home-browse-hub-stack__brand-link:focus-visible {
	background: var(--ppcjobs-hub-hover-bg);
	border-color: var(--ppcjobs-hub-hover-bg);
	color: var(--ppcjobs-hub-hover-text);
	box-shadow: 0 2px 10px rgba(147, 51, 234, 0.3);
	outline: none;
}

.ppcjobs-home-browse-hub-stack__brand-link .fa {
	flex-shrink: 0;
	width: 2.75rem;
	min-width: 2.75rem;
	text-align: center;
	font-size: clamp(1.35rem, 2.5vw, 1.65rem);
	line-height: 1;
}

.ppcjobs-home-browse-hub-stack__brand-mark {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 2.75rem;
	height: 2.75rem;
	min-width: 2.75rem;
	border-radius: 0.45rem;
	font-size: clamp(1rem, 2vw, 1.15rem);
	font-weight: 800;
	color: #fff;
	line-height: 1;
}

@media (min-width: 992px) {
	.ppcjobs-home-browse-hub-stack__brand-link {
		min-height: 3.75rem;
		padding: 0.75rem 1rem;
		gap: 0.85rem;
	}

	.ppcjobs-home-browse-hub-stack__brand-link .fa {
		width: 3rem;
		min-width: 3rem;
		font-size: 1.75rem;
	}

	.ppcjobs-home-browse-hub-stack__brand-mark {
		width: 3rem;
		height: 3rem;
		min-width: 3rem;
		font-size: 1.2rem;
	}
}

.ppcjobs-home-browse-hub-stack__brand-text {
	flex: 1;
	min-width: 0;
	line-height: 1.25;
}

.ppcjobs-home-browse-hub-stack__org .ppcjobs-home-browse-hub-stack__btn {
	flex: 1 1 220px;
	white-space: normal;
	text-align: center;
	padding-top: max(var(--ppcjobs-hub-pill-py), 0.85rem);
	padding-bottom: max(var(--ppcjobs-hub-pill-py), 0.85rem);
}
