<!DOCTYPE html><html lang="en"><head><script async src="https://www.googletagmanager.com/gtag/js?id=G-DBHB6S9ZFJ"></script><script>window.dataLayer=window.dataLayer||[];function gtag(){dataLayer.push(arguments);}gtag("js",new Date());gtag("config","G-DBHB6S9ZFJ");</script><link rel="preconnect" href="https://fonts.googleapis.com"><link rel="preconnect" href="https://fonts.gstatic.com" crossorigin><link href="https://fonts.googleapis.com/css2?family=Lora:wght@400;700&family=Montserrat:wght@300;400;500;600;700;900&display=swap" rel="stylesheet"><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Ministry</title><meta name="description" content="Watch thousands of sermons online from churches and ministries worldwide. Stream live broadcasts and archived messages."><link rel="canonical" href="https://fimcdecatur.sermon.tv/"><meta property="og:title" content="Ministry"><meta property="og:description" content="Watch thousands of sermons online from churches and ministries worldwide. Stream live broadcasts and archived messages."><meta property="og:image" content="https://sermon.tv/assets/og-default.jpg"><meta property="og:url" content="https://fimcdecatur.sermon.tv/"><meta property="og:type" content="website"><meta property="og:site_name" content="sermon.tv"><meta name="twitter:card" content="summary_large_image"><meta name="twitter:title" content="Ministry"><meta name="twitter:description" content="Watch thousands of sermons online from churches and ministries worldwide. Stream live broadcasts and archived messages."><meta name="twitter:image" content="https://sermon.tv/assets/og-default.jpg"><style>
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}


:root {
	--primary: #3A86FF;
	--primary-dark: #2563eb;
	--bg-dark: #1E1E2F;
	--bg-card: #272738;
	--bg-card-hover: #2f2f42;
	--bg-header: #1E1E2F;
	--text-primary: #ffffff;
	--text-secondary: #EFEEEA;
	--text-muted: #9ca3af;
	--border: #3a3a4f;
	--accent: #00C2A8;
	--highlight: #FBBF24;
	--innovation-blue: #3A86FF;
	--slate-charcoal: #1E1E2F;
	--mission-teal: #00C2A8;
	--sanctuary-gold: #FBBF24;
}


html, body {
	font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
	background: var(--bg-dark);
	color: var(--text-primary);
	line-height: 1.5;
	min-height: 100vh;
}

a {
	color: inherit;
	text-decoration: none;
}

img {
	max-width: 100%;
	height: auto;
}

/* header */
.header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: var(--bg-header);
	border-bottom: 1px solid var(--border);
	padding: 0 24px;
	height: 64px;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.header__logo {
	font-size: 24px;
	font-weight: 700;
	color: var(--primary);
}

.header__logo span {
	color: var(--highlight);
}

.header__nav {
	display: flex;
	align-items: center;
	gap: 32px;
}

.header__nav a {
	display: flex;
	align-items: center;
	gap: 8px;
	color: var(--text-secondary);
	font-size: 15px;
	font-weight: 500;
	transition: color 0.2s;
}

.header__nav a:hover,
.header__nav a.active {
	color: var(--primary);
}

.header__search {
	position: relative;
}

.header__search input {
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 8px;
	padding: 8px 16px 8px 40px;
	color: var(--text-primary);
	font-size: 14px;
	width: 240px;
	outline: none;
	transition: border-color 0.2s;
}

.header__search input:focus {
	border-color: var(--primary);
}

.search-suggest {
	position: absolute;
	top: calc(100% + 4px);
	left: 0;
	right: 0;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 10px;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
	overflow: hidden;
	z-index: 200;
}

.search-suggest:empty {
	display: none;
}

.search-suggest__item {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 14px;
	font-size: 14px;
	cursor: pointer;
	transition: background 0.12s;
}

.search-suggest__item:hover,
.search-suggest__item--active {
	background: var(--bg-card-hover);
}

.search-suggest__icon {
	font-size: 14px;
	flex-shrink: 0;
	width: 24px;
	text-align: center;
}

.search-suggest__logo {
	width: 24px;
	height: 24px;
	border-radius: 4px;
	object-fit: cover;
	flex-shrink: 0;
	background: var(--bg-card-hover);
}

.search-suggest__info {
	flex: 1;
	min-width: 0;
}

.search-suggest__text {
	display: block;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.search-suggest__sub {
	display: block;
	font-size: 11px;
	color: var(--text-muted);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.search-suggest__type {
	font-size: 11px;
	color: var(--text-muted);
	flex-shrink: 0;
}

.search-suggest__item--search {
	border-top: 1px solid var(--border);
	color: var(--primary);
}

.header__search input::placeholder {
	color: var(--text-muted);
}

.header__search svg {
	position: absolute;
	left: 12px;
	top: 50%;
	transform: translateY(-50%);
	color: var(--text-muted);
}

/* header right section (search + user) */
.header__right {
	display: flex;
	align-items: center;
	gap: 16px;
}

/* sign in button */
.header__signin-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 16px;
	background: var(--primary);
	color: var(--bg-dark);
	border-radius: 6px;
	font-size: 14px;
	font-weight: 600;
	transition: background 0.2s;
}

.header__signin-btn:hover {
	background: var(--primary-dark);
}

/* user menu */
.header__user {
	position: relative;
}

.header__user-btn {
	background: none;
	border: none;
	cursor: pointer;
	padding: 4px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.header__user-avatar {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: var(--primary);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	border: 2px solid transparent;
	transition: border-color 0.2s;
}

.header__user-btn:hover .header__user-avatar {
	border-color: var(--primary);
}

.header__user-avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.header__user-avatar span {
	font-size: 14px;
	font-weight: 600;
	color: var(--bg-dark);
}

.header__user-dropdown {
	position: absolute;
	top: calc(100% + 8px);
	right: 0;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 8px;
	min-width: 200px;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
	opacity: 0;
	visibility: hidden;
	transform: translateY(-8px);
	transition: opacity 0.2s, transform 0.2s, visibility 0.2s;
	z-index: 200;
}

.header__user:hover .header__user-dropdown,
.header__user:focus-within .header__user-dropdown {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.header__user-info {
	padding: 12px 16px;
}

.header__user-name {
	font-size: 14px;
	font-weight: 600;
	color: var(--text-primary);
}

.header__user-email {
	font-size: 12px;
	color: var(--text-muted);
	margin-top: 2px;
}

.header__user-divider {
	height: 1px;
	background: var(--border);
}

.header__user-item {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 12px 16px;
	font-size: 14px;
	color: var(--text-secondary);
	transition: background 0.2s, color 0.2s;
}

.header__user-item:hover {
	background: var(--bg-card-hover);
	color: var(--text-primary);
}

.header__user-item svg {
	width: 18px;
	height: 18px;
}

.header__user-item--logout {
	color: #ef4444;
}

.header__user-item--logout:hover {
	background: rgba(239, 68, 68, 0.1);
	color: #ef4444;
}

.header__user-avatar {
	position: relative;
}

.header__user-dot {
	position: absolute;
	top: -2px;
	right: -2px;
	width: 10px;
	height: 10px;
	background: #ef4444;
	border: 2px solid var(--bg-dark);
	border-radius: 50%;
	pointer-events: none;
}

.header__user-dot[hidden] {
	display: none;
}

.header__user-badge {
	margin-left: auto;
	min-width: 18px;
	height: 18px;
	padding: 0 6px;
	background: #ef4444;
	color: #fff;
	border-radius: 9px;
	font-size: 11px;
	font-weight: 700;
	line-height: 18px;
	text-align: center;
}

.header__user-badge[hidden] {
	display: none;
}

/* ministry notifications list on /subscriptions */
.ministry-notifications {
	margin-top: 8px;
	padding: 10px 12px;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 8px;
}

.ministry-notifications__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 8px;
	padding-bottom: 6px;
	border-bottom: 1px solid var(--border);
}

.ministry-notifications__header-label {
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	color: var(--text-muted);
}

.ministry-notifications__empty {
	font-size: 12px;
	color: var(--text-muted);
	text-align: center;
	padding: 4px 0;
}

.ministry-notifications__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.ministry-notifications__item {
	position: relative;
	font-size: 12px;
	color: var(--text-secondary);
	border-radius: 6px;
	transition: background 0.15s;
}

.ministry-notifications__item + .ministry-notifications__item {
	margin-top: 2px;
}

.ministry-notifications__link,
.ministry-notifications__item--static {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	padding: 6px 8px;
	color: inherit;
	text-decoration: none;
	border-radius: 6px;
}

.ministry-notifications__link:hover {
	background: var(--bg-card-hover);
	color: var(--text-primary);
}

.ministry-notifications__item.is-unread {
	background: rgba(250, 161, 19, 0.08);
	color: var(--text-primary);
}

.ministry-notifications__item.is-unread::before {
	content: '';
	position: absolute;
	top: 12px;
	left: 2px;
	width: 6px;
	height: 6px;
	background: var(--primary);
	border-radius: 50%;
	pointer-events: none;
}

.ministry-notifications__item.is-unread .ministry-notifications__link,
.ministry-notifications__item.is-unread.ministry-notifications__item--static {
	padding-left: 14px;
}

.ministry-notifications__text {
	flex: 1;
	min-width: 0;
}

.ministry-notifications__title-row {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 8px;
}

.ministry-notifications__title {
	flex: 1;
	font-size: 13px;
	font-weight: 600;
	color: var(--text-primary);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	line-height: 1.3;
}

.ministry-notifications__body {
	margin-top: 2px;
	font-size: 12px;
	color: var(--text-secondary);
	overflow: hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	line-height: 1.35;
}

.ministry-notifications__timestamp {
	margin-top: 4px;
	font-size: 10px;
	color: var(--text-muted);
	letter-spacing: 0.2px;
}

.ministry-notifications__time {
	color: var(--text-muted);
	font-size: 11px;
	flex-shrink: 0;
}

/* main content */
.main {
	max-width: 1400px;
	margin: 0 auto;
	padding: 24px 32px;
}

/* section */
.section {
	margin-bottom: 56px;
}

.search-divider {
	height: 2px;
	background: #FBBF24;
	margin: 32px 0;
	position: relative;
	z-index: 5;
}

.section__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 20px;
}

.section__header--sticky {
	position: sticky;
	top: 140px;
	background: var(--bg-dark);
	padding: 16px 0;
	margin-bottom: 16px;
	z-index: 15;
}

.section--has-sticky-header {
	margin-top: 0;
}

.section__title {
	font-size: 21px;
	font-weight: 600;
}

.section__more {
	display: flex;
	align-items: center;
	gap: 4px;
	color: var(--primary);
	font-size: 14px;
	font-weight: 500;
}

.section__more:hover {
	text-decoration: underline;
}

/* grid */
.grid {
	display: grid;
	gap: 20px;
}

.grid--2 { grid-template-columns: repeat(2, 1fr); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--4 { grid-template-columns: repeat(4, 1fr); }
.grid--5 { grid-template-columns: repeat(5, 1fr); }
.grid--6 { grid-template-columns: repeat(6, 1fr); }

@media (max-width: 1200px) {
	.grid--5, .grid--6 { grid-template-columns: repeat(4, 1fr); }
}

@media (max-width: 900px) {
	.grid--4, .grid--5, .grid--6 { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 600px) {
	.grid--3, .grid--4, .grid--5, .grid--6 { grid-template-columns: repeat(2, 1fr); }
	.header__nav { display: none; }
	.header__search input { width: 160px; }
	/* hide items 11-20 on mobile (home page shows only 10) */
	.grid--home-sermons .sermon-card-wrapper[data-hide-mobile="true"] { display: none; }
}

/* cards */
.card {
	background: var(--bg-card);
	border-radius: 8px;
	overflow: hidden;
	transition: transform 0.2s, background 0.2s;
}

.card:hover {
	transform: translateY(-4px);
	background: var(--bg-card-hover);
}

.card__image {
	position: relative;
	aspect-ratio: 16/9;
	overflow: hidden;
	background: var(--bg-card-hover);
}

.card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.card__video-preview {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: 0;
	transition: opacity 0.3s;
	pointer-events: none;
}

.card__video-preview.active {
	opacity: 1;
}

.card__loading-bar {
	position: absolute;
	bottom: 0;
	left: 0;
	height: 3px;
	width: 0;
	background: rgba(255, 255, 255, 0.4);
	z-index: 5;
	pointer-events: none;
	opacity: 0;
	transition: opacity 0.2s;
}

.card__loading-bar.active {
	opacity: 1;
	animation: card-loading 2s ease-out forwards;
}

@keyframes card-loading {
	from { width: 0; }
	to { width: 100%; }
}

.card__play {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0,0,0,0.4);
	opacity: 0;
	transition: opacity 0.2s;
}

.card:hover .card__play {
	opacity: 1;
}

.card__play-btn {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: var(--highlight);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--bg-dark);
}

.card__live {
	position: absolute;
	top: 8px;
	left: 8px;
	background: var(--sanctuary-gold);
	color: var(--slate-charcoal);
	padding: 4px 8px;
	border-radius: 4px;
	font-size: 11px;
	font-weight: 600;
	display: flex;
	align-items: center;
	gap: 4px;
	text-transform: uppercase;
}



.card__duration {
	position: absolute;
	bottom: 8px;
	right: 8px;
	background: rgba(0,0,0,0.8);
	color: white;
	padding: 2px 6px;
	border-radius: 4px;
	font-size: 12px;
	font-weight: 500;
}

.card__body {
	padding: 14px 16px;
}

.card__title {
	font-size: 15px;
	font-weight: 500;
	margin-bottom: 6px;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.card__meta {
	font-size: 13px;
	color: var(--text-secondary);
}

.card__meta span {
	display: inline-flex;
	align-items: center;
}

.card__meta span + span::before {
	content: '•';
	margin: 0 8px;
	color: var(--text-muted);
}

/* episode card v2 */
.ep-card {
	background: var(--bg-card);
	border-radius: 12px;
	overflow: hidden;
	transition: transform 0.2s, box-shadow 0.2s;
	display: flex;
	flex-direction: column;
	height: 100%;
}

.sermon-card-wrapper {
	display: flex;
}

.ep-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
}

.ep-card__thumb {
	position: relative;
	aspect-ratio: 16/9;
	overflow: hidden;
	background: var(--bg-card-hover);
}

.ep-card__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.3s;
}

.ep-card:hover .ep-card__thumb img {
	transform: scale(1.05);
}

.ep-card__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 50%, rgba(0, 0, 0, 0.4) 100%);
	opacity: 0;
	transition: opacity 0.2s;
}

.ep-card:hover .ep-card__overlay {
	opacity: 1;
}

.ep-card__live {
	position: absolute;
	top: 8px;
	left: 8px;
	background: var(--sanctuary-gold);
	color: var(--slate-charcoal);
	padding: 4px 8px;
	border-radius: 6px;
	font-size: 11px;
	font-weight: 700;
	display: flex;
	align-items: center;
	gap: 4px;
	text-transform: uppercase;
	z-index: 2;
}

.ep-card__live svg {
	width: 14px;
	height: 14px;
}

.ep-card__media {
	position: absolute;
	bottom: 8px;
	left: 8px;
	background: rgba(0, 0, 0, 0.75);
	color: #fff;
	width: 28px;
	height: 28px;
	border-radius: 6px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.ep-card__media svg {
	width: 16px;
	height: 16px;
}

.ep-card__duration {
	position: absolute;
	bottom: 8px;
	right: 8px;
	background: rgba(0, 0, 0, 0.8);
	color: #fff;
	padding: 3px 8px;
	border-radius: 6px;
	font-size: 12px;
	font-weight: 500;
}

.ep-card__body {
	padding: 16px;
	display: flex;
	flex-direction: column;
	gap: 4px;
	flex: 1;
}

.ep-card__title {
	font-size: 16px;
	font-weight: 600;
	line-height: 1.35;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.ep-card__speaker {
	font-size: 14px;
	color: var(--primary);
	font-weight: 500;
}

.ep-card__meta {
	font-size: 12px;
	color: var(--text-muted);
	margin-top: auto;
	padding-top: 8px;
}

.ep-card__meta span + span::before {
	content: '•';
	margin: 0 6px;
}

/* auto-responsive episode grid */
.ep-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 24px;
}

/* ministry card */
.ministry-card {
	position: relative;
	background: var(--bg-card);
	border-radius: 8px;
	overflow: hidden;
	transition: transform 0.2s, background 0.2s;
}

.ministry-card__favorite {
	position: absolute;
	top: 8px;
	right: 8px;
	z-index: 2;
	color: #ff4757;
	filter: drop-shadow(0 1px 2px rgba(0,0,0,0.5));
}

.ministry-card__favorite svg {
	width: 20px;
	height: 20px;
	fill: currentColor;
}

.ministry-card:hover {
	transform: translateY(-4px);
	background: var(--bg-card-hover);
}

.ministry-card__image {
	position: relative;
	aspect-ratio: 16/9;
	overflow: hidden;
	background: var(--bg-card-hover);
}

.ministry-card__image img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.ministry-card__body {
	padding: 14px 16px;
}

.ministry-card__name {
	font-size: 15px;
	font-weight: 500;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.ministry-card__subscribers {
	margin-top: 4px;
	font-size: 12px;
	color: var(--text-muted);
}

/* ministry card wrapper (for subscribe button positioning) */
.ministry-card-wrapper {
	position: relative;
}

/* subscribe button */
.subscribe-btn {
	position: absolute;
	top: 8px;
	right: 8px;
	z-index: 10;
	width: 36px;
	height: 36px;
	border: none;
	border-radius: 50%;
	background: rgba(0, 0, 0, 0.6);
	color: #fff;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background 0.2s, transform 0.2s, color 0.2s;
	backdrop-filter: blur(4px);
}

.subscribe-btn:hover {
	background: rgba(0, 0, 0, 0.8);
	transform: scale(1.1);
}

.subscribe-btn svg {
	width: 20px;
	height: 20px;
}

.subscribe-btn--subscribed {
	color: #ff4757;
	background: rgba(255, 71, 87, 0.2);
}

.subscribe-btn--subscribed:hover {
	background: rgba(255, 71, 87, 0.3);
}

.subscribe-btn--loading {
	pointer-events: none;
	opacity: 0.6;
}

/* subscribe button in ministry header (watch page) */
.ministry-header .subscribe-btn {
	position: static;
	flex-shrink: 0;
	margin-left: 12px;
}

/* home page favorite ministry banner */
.home-favorite {
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 12px 16px;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 10px;
	margin-bottom: 24px;
	text-decoration: none;
	transition: background 0.2s, border-color 0.2s;
}
.home-favorite:hover {
	background: var(--bg-card-hover);
	border-color: var(--highlight);
}
.home-favorite__image {
	width: 56px;
	height: 56px;
	border-radius: 8px;
	overflow: hidden;
	flex-shrink: 0;
}
.home-favorite__image img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}
.home-favorite__label {
	display: flex;
	align-items: center;
	gap: 4px;
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	color: var(--highlight);
}
.home-favorite__label svg {
	width: 14px;
	height: 14px;
}
.home-favorite__name {
	font-size: 15px;
	font-weight: 600;
	color: var(--text-primary);
	margin-top: 2px;
}
.home-favorite__live {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	background: #ef4444;
	color: #fff;
	font-size: 10px;
	font-weight: 700;
	padding: 2px 8px;
	border-radius: 4px;
	margin-left: 8px;
	animation: live-pulse 2s ease-in-out infinite;
}
.home-favorite__live svg {
	width: 12px;
	height: 12px;
}
@keyframes live-pulse {
	0%, 100% { opacity: 1; }
	50% { opacity: 0.7; }
}
.home-favorite--live {
	border-color: #ef4444;
}

/* header favorite menu item */
.header__user-item--favorite {
	color: var(--highlight);
}
.header__user-item--favorite svg {
	width: 16px;
	height: 16px;
}

/* hero */
.hero {
	position: relative;
	min-height: 320px;
	margin: -24px -24px 24px -24px;
	overflow: hidden;
}

.hero__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
}

.hero__bg::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(to right, rgba(10,10,10,0.95) 0%, rgba(10,10,10,0.7) 50%, rgba(10,10,10,0.3) 100%);
}

.hero__content {
	position: relative;
	height: 100%;
	max-width: 550px;
	padding: 32px 48px;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.hero__badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: var(--primary);
	color: var(--bg-dark);
	padding: 4px 10px;
	border-radius: 4px;
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	width: fit-content;
	margin-bottom: 12px;
}

.hero__title {
	font-size: 44px;
	font-weight: 700;
	margin-bottom: 6px;
	line-height: 1.15;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.hero__subtitle {
	font-size: 18px;
	color: var(--text-secondary);
	margin-top: 12px;
}

.hero__ministry {
	font-size: 14px;
	color: var(--primary);
	margin-bottom: 8px;
}

.hero__description {
	font-size: 13px;
	color: var(--text-secondary);
	margin-bottom: 16px;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.hero__actions {
	display: flex;
	gap: 10px;
}

.hero__actions .btn {
	padding: 10px 20px;
	font-size: 13px;
}

/* buttons */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 14px 28px;
	border-radius: 10px;
	font-size: 15px;
	font-weight: 600;
	cursor: pointer;
	border: none;
	transition: background 0.2s, transform 0.2s;
}

.btn:active {
	transform: scale(0.98);
}

.btn--primary {
	background: var(--highlight);
	color: var(--bg-dark);
}

.btn--primary:hover {
	background: #e5ac20;
}

.btn--secondary {
	background: var(--bg-card);
	color: var(--text-primary);
	border: 1px solid var(--border);
}

.btn--secondary:hover {
	background: var(--bg-card-hover);
}

/* video player page */
.watch-page {
	display: flex;
	flex-direction: column;
	gap: 24px;
}

.watch-page__top {
	display: grid;
	grid-template-columns: 1fr 360px;
	gap: 24px;
	align-items: start;
}

.watch-page__player {
	min-width: 0;
}

@media (max-width: 1000px) {
	.watch-page__top {
		grid-template-columns: 1fr;
	}
	.sidebar {
		max-height: none;
	}
	.sidebar__list {
		max-height: 400px;
	}
}

/* playlists row (bottom section) */
.playlists-row {
	background: var(--bg-card);
	border-radius: 8px;
	padding: 16px;
}

.playlists-row__header {
	font-size: 16px;
	font-weight: 600;
	margin-bottom: 16px;
	color: var(--text-primary);
}

.playlists-row__scroll {
	display: flex;
	gap: 16px;
	overflow-x: auto;
	padding-bottom: 8px;
	scrollbar-width: thin;
	scrollbar-color: var(--border) transparent;
}

.playlists-row__scroll::-webkit-scrollbar {
	height: 6px;
}

.playlists-row__scroll::-webkit-scrollbar-track {
	background: transparent;
}

.playlists-row__scroll::-webkit-scrollbar-thumb {
	background: var(--border);
	border-radius: 3px;
}

.playlists-row__scroll::-webkit-scrollbar-thumb:hover {
	background: var(--text-secondary);
}

.playlist-tile {
	flex-shrink: 0;
	width: 180px;
	background: var(--bg-card-hover);
	border-radius: 8px;
	overflow: hidden;
	transition: transform 0.2s, box-shadow 0.2s;
	cursor: pointer;
}

.playlist-tile:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.playlist-tile--active {
	border: 2px solid var(--primary);
}

.playlist-tile__image {
	position: relative;
	aspect-ratio: 16/9;
	background: var(--bg-dark);
}

.playlist-tile__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.playlist-tile__badge {
	position: absolute;
	bottom: 8px;
	left: 8px;
	background: var(--primary);
	color: var(--bg-dark);
	padding: 4px 8px;
	border-radius: 4px;
	font-size: 10px;
	font-weight: 600;
	text-transform: uppercase;
}

/* protected playlist lock icon */
.playlist-tile--protected .playlist-tile__image::after {
	content: '';
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.5);
	pointer-events: none;
}

.playlist-tile__lock {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 40px;
	height: 40px;
	background: rgba(0, 0, 0, 0.7);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 2;
}

.playlist-tile__lock svg {
	width: 20px;
	height: 20px;
	color: var(--highlight);
}

.playlist-tile--protected:hover .playlist-tile__lock {
	background: var(--primary);
}

.playlist-tile--protected:hover .playlist-tile__lock svg {
	color: var(--bg-dark);
}

/* video player lock overlay for protected content */
.video-container--locked {
	position: relative;
}

.video-container--locked video,
.video-container--locked iframe {
	filter: blur(8px);
	pointer-events: none;
}

.content-lock-overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.75);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	z-index: 10;
	text-align: center;
	padding: 24px;
}

.content-lock-overlay__icon {
	width: 64px;
	height: 64px;
	background: var(--primary);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 16px;
}

.content-lock-overlay__icon svg {
	width: 32px;
	height: 32px;
	color: var(--bg-dark);
}

.content-lock-overlay__title {
	font-size: 20px;
	font-weight: 700;
	color: var(--text-primary);
	margin-bottom: 8px;
}

.content-lock-overlay__text {
	font-size: 14px;
	color: var(--text-secondary);
	margin-bottom: 20px;
}

.content-lock-overlay__btn {
	background: var(--primary);
	color: var(--bg-dark);
	border: none;
	padding: 12px 24px;
	border-radius: 8px;
	font-size: 16px;
	font-weight: 600;
	cursor: pointer;
	transition: background 0.2s;
}

.content-lock-overlay__btn:hover {
	background: var(--primary-dark);
}

/* sidebar episode lock icon */
.sidebar__item--locked .sidebar__item-thumb {
	position: relative;
}

.sidebar__item--locked .sidebar__item-thumb::after {
	content: '';
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.5);
	border-radius: 4px;
}

.sidebar__item-lock {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 28px;
	height: 28px;
	background: rgba(0, 0, 0, 0.7);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 2;
}

.sidebar__item-lock svg {
	width: 14px;
	height: 14px;
	color: var(--highlight);
}

.sidebar__item--locked:hover .sidebar__item-thumb::after {
	background: rgba(0, 0, 0, 0.3);
}

/* password popup modal */
.password-modal {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 1000;
	background: rgba(0, 0, 0, 0.5);
	backdrop-filter: blur(4px);
	align-items: center;
	justify-content: center;
	padding: 24px;
}

.password-modal.show {
	display: flex;
}

.password-modal__content {
	width: 100%;
	max-width: 400px;
	background: var(--bg-card);
	border-radius: 16px;
	padding: 32px;
	position: relative;
	animation: modal-slide-in 0.2s ease-out;
}

@keyframes modal-slide-in {
	from {
		opacity: 0;
		transform: translateY(-20px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.password-modal__close {
	position: absolute;
	top: 16px;
	right: 16px;
	background: none;
	border: none;
	color: var(--text-muted);
	cursor: pointer;
	padding: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: color 0.2s;
}

.password-modal__close:hover {
	color: var(--text-primary);
}

.password-modal__icon {
	width: 56px;
	height: 56px;
	margin: 0 auto 20px;
	background: var(--primary);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--bg-dark);
}

.password-modal__icon svg {
	width: 28px;
	height: 28px;
}

.password-modal__title {
	font-size: 20px;
	font-weight: 700;
	text-align: center;
	margin-bottom: 8px;
}

.password-modal__subtitle {
	font-size: 14px;
	color: var(--text-secondary);
	text-align: center;
	margin-bottom: 24px;
}

.password-modal__playlist {
	color: var(--primary);
	font-weight: 500;
}

.password-modal__form {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.password-modal__input {
	width: 100%;
	padding: 14px 16px;
	background: var(--bg-dark);
	border: 2px solid var(--border);
	border-radius: 8px;
	color: var(--text-primary);
	font-size: 16px;
	outline: none;
	transition: border-color 0.2s;
}

.password-modal__input:focus {
	border-color: var(--primary);
}

.password-modal__submit {
	width: 100%;
	padding: 14px 20px;
	background: var(--primary);
	color: var(--bg-dark);
	border: none;
	border-radius: 8px;
	font-size: 16px;
	font-weight: 600;
	cursor: pointer;
	transition: background 0.2s;
}

.password-modal__submit:hover {
	background: var(--primary-dark);
}

.password-modal__submit:disabled {
	background: var(--text-muted);
	cursor: not-allowed;
}

.password-modal__error {
	background: rgba(239, 68, 68, 0.15);
	border: 1px solid rgba(239, 68, 68, 0.3);
	color: #f87171;
	padding: 12px;
	border-radius: 8px;
	font-size: 14px;
	text-align: center;
	display: none;
}

.password-modal__error.show {
	display: block;
}

.password-modal__loading {
	display: none;
	align-items: center;
	justify-content: center;
	gap: 8px;
	color: var(--text-secondary);
	font-size: 14px;
}

.password-modal__loading.show {
	display: flex;
}

.password-modal__spinner {
	width: 16px;
	height: 16px;
	border: 2px solid var(--border);
	border-top-color: var(--primary);
	border-radius: 50%;
	animation: spin 1s linear infinite;
}

.playlist-tile__title {
	padding: 10px 12px 4px;
	font-size: 13px;
	font-weight: 500;
	color: var(--text-primary);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.playlist-tile__count {
	padding: 0 12px 10px;
	font-size: 11px;
	color: var(--text-secondary);
}

@media (max-width: 600px) {
	.playlist-tile {
		width: 150px;
	}
	.playlists-row {
		padding: 12px;
	}
}

.video-container {
	position: relative;
	aspect-ratio: 16/9;
	background: #000;
	border-radius: 8px;
	overflow: hidden;
}

/* Hide time display for live streams - WebKit/Safari */
.video-container--live video::-webkit-media-controls-time-remaining-display,
.video-container--live video::-webkit-media-controls-current-time-display,
.video-container--live video::-webkit-media-controls-timeline {
	display: none !important;
}


.video-container video,
.video-container stream {
	width: 100%;
	height: 100%;
	display: block;
}

/* Cast buttons - desktop only, hidden on mobile/touch devices */
.video-container google-cast-launcher,
.video-container .remote-playback-btn {
	position: absolute;
	top: 12px;
	z-index: 10;
	width: 32px;
	height: 32px;
	background: rgba(0,0,0,0.6);
	border-radius: 4px;
	cursor: pointer;
	opacity: 0;
	transition: opacity 0.3s;
}
.video-container google-cast-launcher {
	right: 12px;
	--disconnected-color: #fff;
	--connected-color: var(--primary);
}
.video-container .remote-playback-btn {
	right: 52px;
	display: none;
	align-items: center;
	justify-content: center;
	border: none;
}
.remote-playback-btn svg {
	width: 20px;
	height: 20px;
	fill: #fff;
}

/* Show cast buttons on hover - desktop only */
@media (hover: hover) and (pointer: fine) {
	.video-container:hover google-cast-launcher,
	.video-container:hover .remote-playback-btn.available {
		opacity: 1;
	}
}

/* Remote playback states */
.remote-playback-btn.connecting {
	opacity: 1;
	animation: cast-pulse 1s infinite;
}
.remote-playback-btn.connected {
	opacity: 1;
	background: var(--primary);
}
@keyframes cast-pulse {
	0%, 100% { opacity: 0.6; }
	50% { opacity: 1; }
}

/* Hide cast buttons on mobile/touch */
@media (pointer: coarse) {
	.video-container google-cast-launcher,
	.video-container .remote-playback-btn {
		display: none !important;
	}
}

/* Hide Google Cast when not supported */
.video-container google-cast-launcher[style*="display: none"] {
	display: none !important;
}

.video-live-badge {
	position: absolute;
	top: 12px;
	left: 12px;
	z-index: 10;
	background: var(--sanctuary-gold);
	color: var(--slate-charcoal);
	padding: 6px 12px;
	border-radius: 4px;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.5px;
	display: flex;
	align-items: center;
	gap: 6px;
}

.video-live-badge::before {
	content: '';
	width: 8px;
	height: 8px;
	background: var(--slate-charcoal);
	border-radius: 50%;
	animation: pulse 1.5s ease-in-out infinite;
}

@keyframes pulse {
	0%, 100% { opacity: 1; }
	50% { opacity: 0.4; }
}

.stream-ended-overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.85);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 20;
}

.stream-ended-overlay__box {
	text-align: center;
}

.stream-ended-overlay__icon {
	font-size: 36px;
	color: var(--text-muted);
	margin-bottom: 12px;
}

.stream-ended-overlay__text {
	font-size: 18px;
	font-weight: 600;
	color: var(--text-primary);
}

/* Hide Firefox native overlay controls - we use the standard video controls */
video::-moz-pip-button,
video::-moz-media-controls-picture-in-picture-button,
.PictureInPictureToggle,
.pictureInPictureToggleButton,
.pictureInPictureOverlay {
	display: none !important;
	opacity: 0 !important;
	visibility: hidden !important;
	pointer-events: none !important;
}

/* caption styling */
video::cue {
	background: rgba(0, 0, 0, 0.8);
	color: #fff;
	font-size: 18px;
	line-height: 1.4;
}

/* audio-only player */
.audio-player {
	position: relative;
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}

.audio-player__bg {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	/* note: no default blur/brightness — episode artwork renders sharp at
	   full brightness so the player matches the thumbnail. Producers can
	   apply blur/dim intentionally via their artwork tooling; the player
	   shouldn't impose visual effects on content it didn't author. */
}

.audio-player__badge {
	position: relative;
	z-index: 1;
	background: var(--primary);
	color: var(--bg-dark);
	padding: 8px 16px;
	border-radius: 6px;
	font-size: 14px;
	font-weight: 600;
	margin-bottom: 24px;
}

.audio-player audio {
	position: relative;
	z-index: 1;
	width: 80%;
	max-width: 400px;
}

.video-info {
	padding: 20px 0;
}

.video-info__title {
	font-size: 22px;
	font-weight: 600;
	line-height: 1.3;
	margin-bottom: 8px;
}

.video-info__meta {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-top: 10px;
	margin-bottom: 16px;
	font-size: 14px;
}

.video-info__ministry {
	display: flex;
	align-items: center;
	gap: 8px;
}

.video-info__ministry img {
	width: 36px;
	height: 36px;
	border-radius: 50%;
}

.video-info__ministry-name {
	font-size: 14px;
	font-weight: 500;
}

.video-info__stats {
	font-size: 13px;
	color: var(--text-secondary);
}

.video-info__description {
	font-size: 14px;
	color: var(--text-secondary);
	line-height: 1.6;
}

.video-info__resources {
	margin-top: 20px;
	padding-top: 16px;
	border-top: 1px solid var(--border);
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
}

.video-info__resources-title {
	font-size: 16px;
	font-weight: 600;
	color: var(--text-primary);
	margin: 0;
	width: 100%;
	margin-bottom: 4px;
}

.video-info__resource-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 16px;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 6px;
	color: var(--text-primary);
	text-decoration: none;
	font-size: 14px;
	font-weight: 500;
	transition: background 0.2s, border-color 0.2s;
}

.video-info__resource-link:hover {
	background: var(--primary);
	border-color: var(--primary);
	color: #fff;
}

.video-info__resource-link svg {
	flex-shrink: 0;
}

.video-info__resource-link--locked {
	position: relative;
	pointer-events: none;
	opacity: 0.6;
}

.video-info__resource-link--locked::after {
	content: '';
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.4);
	border-radius: 6px;
}

.video-info__resource-lock {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 24px;
	height: 24px;
	background: rgba(0, 0, 0, 0.7);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 2;
}

.video-info__resource-lock svg {
	width: 12px;
	height: 12px;
	color: var(--highlight);
}

/* sidebar playlist */
.sidebar {
	background: var(--bg-card);
	border-radius: 8px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	max-height: calc(100vh - 120px);
}

.sidebar__header {
	padding: 16px;
	border-bottom: 1px solid var(--border);
	font-weight: 600;
}

.sidebar__upcoming {
	border-bottom: 1px solid var(--border);
}

.sidebar__upcoming .sidebar__header {
	border-bottom: none;
	padding-bottom: 8px;
}

.sidebar__upcoming-card {
	display: block;
	padding: 0 16px 16px;
}

.sidebar__upcoming-thumb {
	position: relative;
	width: 100%;
	aspect-ratio: 16/9;
	border-radius: 8px;
	overflow: hidden;
	margin-bottom: 12px;
}

.sidebar__upcoming-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.sidebar__upcoming-badge {
	position: absolute;
	top: 8px;
	left: 8px;
	background: var(--primary);
	color: var(--bg-dark);
	padding: 4px 8px;
	border-radius: 4px;
	font-size: 11px;
	font-weight: 600;
}

.sidebar__upcoming-info {
	padding: 0;
}

.sidebar__upcoming-title {
	font-weight: 600;
	margin-bottom: 4px;
	line-height: 1.3;
}

.sidebar__upcoming-date {
	font-size: 13px;
	color: var(--text-secondary);
}

.sidebar__countdown {
	padding: 12px 16px 16px;
	text-align: center;
}

.sidebar__countdown-label {
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 1px;
	color: var(--text-muted);
	margin-bottom: 8px;
}

.sidebar__countdown-timer {
	display: flex;
	justify-content: center;
	gap: 8px;
}

.sidebar__countdown-unit {
	background: var(--bg-card);
	border-radius: 6px;
	padding: 6px 10px;
	min-width: 44px;
}

.sidebar__countdown-num {
	display: block;
	font-size: 20px;
	font-weight: 700;
	color: var(--primary);
	line-height: 1.2;
	font-variant-numeric: tabular-nums;
}

.sidebar__countdown-txt {
	font-size: 10px;
	color: var(--text-muted);
	text-transform: uppercase;
}

.sidebar__list {
	flex: 1;
	min-height: 200px;
	overflow-y: auto;
	scrollbar-width: thin;
	scrollbar-color: var(--border) transparent;
}

.sidebar__list::-webkit-scrollbar {
	width: 6px;
}

.sidebar__list::-webkit-scrollbar-track {
	background: transparent;
}

.sidebar__list::-webkit-scrollbar-thumb {
	background: var(--border);
	border-radius: 3px;
}

.sidebar__list::-webkit-scrollbar-thumb:hover {
	background: var(--text-secondary);
}

.sidebar__item {
	display: flex;
	gap: 12px;
	padding: 10px;
	transition: background 0.2s;
}

.sidebar__item:hover {
	background: var(--bg-card-hover);
}

.sidebar__item.active {
	background: var(--bg-card-hover);
	border-left: 3px solid var(--primary);
}

.sidebar__item-thumb {
	width: 120px;
	aspect-ratio: 16/9;
	border-radius: 4px;
	overflow: hidden;
	flex-shrink: 0;
}

.sidebar__item-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.sidebar__item-info {
	flex: 1;
	min-width: 0;
}

.sidebar__item-title {
	font-size: 14px;
	font-weight: 500;
	line-height: 1.4;
	margin-bottom: 4px;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.sidebar__item-date {
	font-size: 11px;
	color: var(--text-secondary, #8a8a8a);
	margin-top: 2px;
}

.sidebar__item-meta {
	font-size: 12px;
	color: var(--text-secondary);
}

.sidebar__sentinel {
	height: 1px;
	width: 100%;
}

.sidebar__loading {
	padding: 16px;
	text-align: center;
	color: var(--text-secondary);
	font-size: 13px;
}

/* page header (for browse, ministry pages) */
.page-header {
	margin-bottom: 32px;
}

.page-header--sticky {
	position: sticky;
	top: 64px;
	background: var(--bg-dark);
	padding: 16px 0;
	margin: -24px 0 24px 0;
	z-index: 20;
	--sticky-offset: 140px;
}

.page-header__back {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: var(--text-secondary);
	font-size: 14px;
	margin-bottom: 16px;
	transition: color 0.2s;
}

.page-header__back:hover {
	color: var(--primary);
}

.page-header__title {
	font-size: 28px;
	font-weight: 700;
}

.page-header__subtitle {
	font-size: 16px;
	color: var(--text-secondary);
	margin-top: 8px;
}

/* browse search */
.browse-search {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-top: 20px;
}

.browse-search input {
	flex: 1;
	max-width: 400px;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 8px;
	padding: 12px 16px;
	color: var(--text-primary);
	font-size: 14px;
	outline: none;
	transition: border-color 0.2s;
}

.browse-search input:focus {
	border-color: var(--primary);
}

.browse-search input::placeholder {
	color: var(--text-muted);
}

.browse-search__count {
	font-size: 14px;
	color: var(--text-secondary);
	white-space: nowrap;
}

@media (max-width: 600px) {
	.browse-search {
		flex-direction: column;
		align-items: stretch;
		gap: 8px;
	}
	.browse-search input {
		max-width: none;
	}
	.browse-search__count {
		text-align: center;
	}
}

/* browse sort toggle */
.browse-sort {
	display: inline-flex;
	gap: 0;
	margin-top: 12px;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 8px;
	padding: 4px;
}

.browse-sort__btn {
	padding: 8px 14px;
	font-size: 13px;
	font-weight: 500;
	color: var(--text-secondary);
	background: transparent;
	border-radius: 6px;
	text-decoration: none;
	cursor: pointer;
	transition: background 0.2s, color 0.2s;
}

.browse-sort__btn:hover {
	color: var(--text-primary);
}

.browse-sort__btn--active {
	background: var(--primary);
	color: #fff;
	cursor: default;
}

.browse-sort__btn--active:hover {
	color: #fff;
}

/* ministry header */
.ministry-header {
	display: flex;
	align-items: center;
	gap: 24px;
	margin-bottom: 32px;
	padding-bottom: 24px;
	border-bottom: 1px solid var(--border);
}

.ministry-header__logo {
	width: 100px;
	height: 100px;
	border-radius: 12px;
	overflow: hidden;
	background: var(--bg-card);
}

.ministry-header__logo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ministry-header__info {
	flex: 1;
}

.ministry-header__name {
	font-size: 28px;
	font-weight: 700;
	margin-bottom: 4px;
}

.ministry-header__stats {
	font-size: 14px;
	color: var(--text-secondary);
}

.ministry-header__logo-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--primary);
	color: white;
	font-size: 36px;
	font-weight: 700;
}

/* watch page variant - smaller header, logo won't be cut off */
.ministry-header--watch {
	margin-bottom: 16px;
	padding-bottom: 16px;
	gap: 16px;
}

.ministry-header--watch .ministry-header__logo {
	width: 128px;
	aspect-ratio: 16/9;
	border-radius: 8px;
	background: var(--bg-card);
	flex-shrink: 0;
}

.ministry-header--watch .ministry-header__logo img {
	object-fit: contain;
}

.ministry-header--watch .ministry-header__logo-placeholder {
	font-size: 24px;
}

.ministry-header--watch .ministry-header__name {
	font-size: 20px;
}

.ministry-header__details {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	color: var(--text-secondary);
	margin-top: 4px;
}

.ministry-header__sep {
	color: var(--text-secondary);
	opacity: 0.5;
}

.ministry-header__location,
.ministry-header__phone {
	color: var(--text-secondary);
}

.ministry-header__website {
	color: var(--primary);
	text-decoration: none;
}

.ministry-header__website:hover {
	text-decoration: underline;
}

.ministry-header__description {
	font-size: 14px;
	color: var(--text-secondary);
	margin-top: 8px;
	line-height: 1.5;
	max-width: 600px;
}

.ministry-header--watch .ministry-header__description {
	font-size: 13px;
	margin-top: 6px;
	max-width: none;
}

@media (max-width: 600px) {
	.ministry-header__details {
		font-size: 12px;
	}
	.ministry-header__description {
		font-size: 13px;
	}
}

/* empty state */
.empty {
	text-align: center;
	padding: 48px 24px;
	color: var(--text-secondary);
}

.empty__title {
	font-size: 18px;
	font-weight: 500;
	margin-bottom: 8px;
	color: var(--text-primary);
}

/* favorites page */
.favorites-login,
.favorites-empty {
	text-align: center;
	padding: 60px 24px;
	max-width: 400px;
	margin: 40px auto;
}

.favorites-login__icon,
.favorites-empty__icon {
	width: 80px;
	height: 80px;
	background: rgba(58, 134, 255, 0.1);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 24px;
}

.favorites-login__icon svg,
.favorites-empty__icon svg {
	width: 40px;
	height: 40px;
	color: var(--primary);
}

.favorites-login__title,
.favorites-empty__title {
	font-size: 24px;
	font-weight: 600;
	color: var(--text-primary);
	margin: 0 0 12px;
}

.favorites-login__text,
.favorites-empty__text {
	font-size: 14px;
	color: var(--text-secondary);
	margin: 0 0 24px;
	line-height: 1.6;
}

/* subscriptions page sections */
.subs-section {
	margin-bottom: 40px;
}
.subs-section__title {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 20px;
	font-weight: 600;
	color: var(--text-primary);
	margin: 0 0 16px;
}
.subs-section__title svg {
	width: 20px;
	height: 20px;
	color: var(--highlight);
}
.subs-section__empty {
	display: flex;
	align-items: center;
	gap: 6px;
	color: var(--text-muted);
	font-size: 14px;
	margin: 0;
}
.subs-section__empty svg {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
}

/* favorite button (star) */
.favorite-btn {
	position: absolute;
	top: 8px;
	left: 8px;
	z-index: 10;
	width: 36px;
	height: 36px;
	border: none;
	border-radius: 50%;
	background: rgba(0, 0, 0, 0.6);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: background 0.2s, transform 0.2s, color 0.2s;
	backdrop-filter: blur(4px);
}
.favorite-btn:hover {
	background: rgba(0, 0, 0, 0.8);
	transform: scale(1.1);
}
.favorite-btn svg {
	width: 20px;
	height: 20px;
}
.favorite-btn--active {
	color: var(--highlight);
	background: rgba(251, 191, 36, 0.2);
}
.favorite-btn--active:hover {
	background: rgba(251, 191, 36, 0.3);
}
.favorite-btn--loading {
	pointer-events: none;
	opacity: 0.6;
}

/* notification bell button */
.notification-btn {
	position: absolute;
	top: 8px;
	right: 52px;
	z-index: 10;
	width: 36px;
	height: 36px;
	border: none;
	border-radius: 50%;
	background: rgba(0, 0, 0, 0.6);
	color: #fff;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background 0.2s, transform 0.2s, color 0.2s;
	backdrop-filter: blur(4px);
}
.notification-btn:hover {
	background: rgba(0, 0, 0, 0.8);
	transform: scale(1.1);
}
.notification-btn svg {
	width: 20px;
	height: 20px;
}
.notification-btn--enabled {
	color: var(--primary, #FAA113);
	background: rgba(250, 161, 19, 0.2);
}
.notification-btn--enabled:hover {
	background: rgba(250, 161, 19, 0.3);
}
.notification-btn--blocked {
	color: #999;
	opacity: 0.6;
}
.notification-btn--loading {
	pointer-events: none;
	opacity: 0.6;
}

/* post-login push opt-in banner */
.push-banner {
	position: fixed;
	bottom: 80px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 100;
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 16px;
	background: var(--bg-card, #1a1a1a);
	border: 1px solid var(--border, #333);
	border-radius: 12px;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
	max-width: 480px;
	width: calc(100% - 32px);
	animation: push-banner-in 0.3s ease-out;
}
@keyframes push-banner-in {
	from { opacity: 0; transform: translate(-50%, 20px); }
	to { opacity: 1; transform: translate(-50%, 0); }
}
.push-banner__icon {
	flex-shrink: 0;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: rgba(250, 161, 19, 0.15);
	color: var(--primary, #FAA113);
	display: flex;
	align-items: center;
	justify-content: center;
}
.push-banner__text {
	flex: 1;
	font-size: 14px;
	color: var(--text-primary, #fff);
	line-height: 1.4;
}
.push-banner__actions {
	display: flex;
	gap: 8px;
	flex-shrink: 0;
}
.push-banner__btn {
	padding: 8px 14px;
	border: none;
	border-radius: 6px;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	transition: opacity 0.2s;
}
.push-banner__btn--primary {
	background: var(--primary, #FAA113);
	color: #000;
}
.push-banner__btn--secondary {
	background: transparent;
	color: var(--text-secondary, #999);
}
.push-banner__btn:hover { opacity: 0.85; }
@media (max-width: 640px) {
	.push-banner { bottom: 72px; flex-wrap: wrap; }
	.push-banner__text { flex-basis: 100%; }
	.push-banner__actions { margin-left: auto; }
}

/* toast */
.snt-toast {
	position: fixed;
	bottom: 24px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 1000;
	padding: 10px 18px;
	background: rgba(0, 0, 0, 0.9);
	color: #fff;
	border-radius: 20px;
	font-size: 14px;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
	animation: snt-toast-in 0.2s ease-out;
}
@keyframes snt-toast-in {
	from { opacity: 0; transform: translate(-50%, 10px); }
	to { opacity: 1; transform: translate(-50%, 0); }
}

/* loading */
.loading {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 48px;
}

.loading__spinner {
	width: 32px;
	height: 32px;
	border: 3px solid var(--border);
	border-top-color: var(--primary);
	border-radius: 50%;
	animation: spin 1s linear infinite;
}

@keyframes spin {
	to { transform: rotate(360deg); }
}

/* pagination */
.pagination {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	margin-top: 32px;
	padding: 16px 0;
}

.pagination__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 8px 12px;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 6px;
	color: var(--text-primary);
	font-size: 14px;
	font-weight: 500;
	transition: background 0.2s, border-color 0.2s;
	min-width: 40px;
}

.pagination__btn:hover {
	background: var(--bg-card-hover);
	border-color: var(--primary);
}

.pagination__btn--num {
	padding: 8px 14px;
}

.pagination__btn--arrow {
	font-size: 16px;
}

.pagination__btn--active {
	background: var(--primary);
	border-color: var(--primary);
	color: var(--bg-dark);
}

.pagination__btn--active:hover {
	background: var(--primary-dark);
	border-color: var(--primary-dark);
}

.pagination__btn--disabled {
	color: var(--text-muted);
	cursor: not-allowed;
}

.pagination__btn--disabled:hover {
	background: var(--bg-card);
	border-color: var(--border);
}

.pagination__ellipsis {
	color: var(--text-muted);
	padding: 0 4px;
}

/* mobile nav */
.mobile-nav {
	display: none;
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	background: var(--bg-header);
	border-top: 1px solid var(--border);
	padding: 8px 0;
	z-index: 100;
}

.mobile-nav__items {
	display: flex;
	justify-content: space-around;
}

.mobile-nav__item {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
	color: var(--text-secondary);
	font-size: 11px;
	padding: 8px 16px;
}

.mobile-nav__item.active {
	color: var(--primary);
}

.footer__content {
	padding: 48px 32px;
	gap: 48px;
}

.footer__tagline {
	font-size: 15px;
	line-height: 1.6;
}

@media (max-width: 768px) {
	.main {
		padding: 20px 16px;
	}
}

@media (max-width: 600px) {
	.mobile-nav {
		display: block;
	}
	.main {
		padding: 20px 16px;
		padding-bottom: 80px;
	}
}



/* THE CHOSEN page */
.chosen-hero {
	position: relative;
	min-height: 500px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: -24px -24px 0;
	padding: 80px 24px;
	overflow: hidden;
}

.chosen-hero__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center top;
	filter: brightness(0.4);
}


.chosen-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to bottom, transparent 0%, var(--bg-dark) 100%);
}

.chosen-hero__content {
	position: relative;
	z-index: 1;
	text-align: center;
	max-width: 800px;
}

.chosen-hero__badge {
	display: inline-block;
	background: var(--primary);
	color: #fff;
	padding: 6px 16px;
	border-radius: 20px;
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 1px;
	margin-bottom: 20px;
}

.chosen-hero__title {
	font-size: 48px;
	font-weight: 700;
	color: #fff;
	margin: 0 0 16px;
	line-height: 1.1;
}
.chosen-hero__cas-logo {
	max-height: 180px;
	max-width: 80%;
	height: auto;
	width: auto;
	margin-bottom: 8px;
}
.chosen-hero__title-sub {
	font-size: 0.55em;
	font-weight: 400;
	opacity: 0.85;
}

.chosen-hero__subtitle {
	font-size: 18px;
	color: var(--text-secondary);
	margin: 0 0 32px;
	line-height: 1.6;
}

/* note: text_emphasis variants — pulled from page_config.hero.text_emphasis
   so producers can dial in legibility per page. "shadow" applies a soft
   dark glow; "block" wraps the title + subtitle in a translucent backdrop. */
.chosen-hero--emph-shadow .chosen-hero__title,
.chosen-hero--emph-shadow .chosen-hero__subtitle {
	text-shadow: 0 2px 14px rgba(0, 0, 0, 0.85), 0 1px 3px rgba(0, 0, 0, 0.65);
}
.chosen-hero--emph-block .chosen-hero__title,
.chosen-hero--emph-block .chosen-hero__subtitle {
	background: rgba(0, 0, 0, 0.50);
	-webkit-backdrop-filter: blur(4px);
	backdrop-filter: blur(4px);
	border-radius: 10px;
	padding: 16px 20px;
	display: inline-block;
}
.chosen-hero--emph-block .chosen-hero__title { margin-bottom: 14px; }
.chosen-hero--emph-block .chosen-hero__subtitle {
	display: block;
	max-width: 720px;
	margin-left: auto;
	margin-right: auto;
}
.chosen-hero__subtitle p { margin: 0 0 12px; }
.chosen-hero__subtitle p:last-child { margin-bottom: 0; }
.chosen-hero__subtitle ul {
	list-style: none;
	margin: 8px auto 12px;
	padding: 0;
	max-width: 640px;
	text-align: left;
}
.chosen-hero__subtitle ul li {
	position: relative;
	padding-left: 22px;
	margin-bottom: 6px;
	font-size: 16px;
}
.chosen-hero__subtitle ul li::before {
	content: "✓";
	position: absolute;
	left: 0;
	top: 0;
	color: var(--primary, #3A86FF);
	font-weight: 700;
}
.chosen-hero__subtitle .chosen-hero__subtitle-note {
	font-size: 13px;
	color: var(--text-muted, #a8a8b8);
	font-style: italic;
	margin-top: 4px;
}

.chosen-hero__actions {
	display: flex;
	gap: 16px;
	justify-content: center;
	flex-wrap: wrap;
}

.chosen-hero__btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 14px 28px;
	border-radius: 8px;
	font-size: 16px;
	font-weight: 600;
	text-decoration: none;
	transition: all 0.2s;
}

.chosen-hero__btn--primary {
	background: var(--primary);
	color: #fff;
}

.chosen-hero__btn--primary:hover {
	background: var(--primary-dark);
	transform: translateY(-2px);
}

.chosen-hero__btn--secondary {
	background: rgba(255, 255, 255, 0.1);
	color: #fff;
	border: 1px solid rgba(255, 255, 255, 0.3);
}

.chosen-hero__btn--secondary:hover {
	background: rgba(255, 255, 255, 0.2);
}

.chosen-hero--with-tiles {
	min-height: 600px;
	padding-bottom: 40px;
}

.chosen-hero--with-tiles .chosen-hero__content {
	max-width: 1200px;
}

.chosen-hero__tiles-heading {
	color: rgba(255, 255, 255, 0.9);
	font-size: 24px;
	font-weight: 600;
	margin: 0 0 20px;
	text-align: center;
}

.chosen-hero__tiles {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 16px;
	margin-top: 16px;
	max-width: 66%;
	margin-left: auto;
	margin-right: auto;
}
.chosen-hero__tiles--three {
	grid-template-columns: repeat(3, 1fr);
	max-width: 100%;
	margin-top: 32px;
}
.chosen-hero__tiles--top {
	margin-top: 32px;
}

.chosen-hero__tile {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 16px 20px;
	background: rgba(0, 0, 0, 0.5);
	backdrop-filter: blur(8px);
	border: 1px solid rgba(255, 255, 255, 0.15);
	border-radius: 12px;
	text-decoration: none;
	transition: all 0.2s;
}

.chosen-hero__tile:hover {
	background: rgba(0, 0, 0, 0.65);
	border-color: rgba(255, 255, 255, 0.3);
	transform: translateY(-2px);
}

/* note: primary CTA — middle tile (Movie Night). Slightly larger padding +
   accent border + brighter background to draw the eye. The grid still
   sizes columns equally so the visual emphasis is purely styling. */
.chosen-hero__tile--primary {
	padding: 22px 24px;
	background: rgba(0, 0, 0, 0.7);
	border-color: var(--primary);
	box-shadow: 0 0 0 1px var(--primary), 0 8px 24px rgba(58, 134, 255, 0.25);
	transform: scale(1.05);
}
.chosen-hero__tile--primary:hover {
	transform: scale(1.05) translateY(-2px);
	box-shadow: 0 0 0 1px var(--primary), 0 12px 28px rgba(58, 134, 255, 0.35);
}
.chosen-hero__tile--primary .chosen-hero__tile-icon {
	width: 48px;
	height: 48px;
	background: var(--primary);
}
.chosen-hero__tile--primary .chosen-hero__tile-icon svg {
	width: 26px;
	height: 26px;
	color: #fff;
}
.chosen-hero__tile--primary .chosen-hero__tile-text h3 {
	font-size: 17px;
}
@media (max-width: 600px) {
	/* note: drop the scale on stacked mobile layout — less visual room */
	.chosen-hero__tile--primary { transform: none; }
	.chosen-hero__tile--primary:hover { transform: translateY(-2px); }
}

.chosen-hero__tile-icon {
	flex-shrink: 0;
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(255, 255, 255, 0.1);
	border-radius: 10px;
}

.chosen-hero__tile-icon svg {
	width: 22px;
	height: 22px;
	color: var(--primary);
}

.chosen-hero__tile-text {
	flex: 1;
	text-align: center;
}
.chosen-hero__tile-text h3 {
	color: #fff;
	font-size: 15px;
	font-weight: 600;
	margin: 0 0 4px;
}

.chosen-hero__tile-text p {
	color: rgba(255, 255, 255, 0.7);
	font-size: 13px;
	margin: 0;
	line-height: 1.4;
}

@media (max-width: 600px) {
	.chosen-hero__tiles {
		grid-template-columns: 1fr;
		max-width: 100%;
	}
	.chosen-hero__tiles--three {
		grid-template-columns: 1fr;
	}
	.chosen-hero--with-tiles {
		min-height: auto;
	}

}

/* popular sermon packages widget */
.wizard-packages {
	margin: 0 0 20px;
}

.wizard-packages__title {
	font-size: 15px;
	font-weight: 600;
	margin-bottom: 10px;
	color: var(--text-muted);
}

.wizard-packages__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	gap: 10px;
}

.wizard-pkg {
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 10px;
	padding: 14px;
	display: flex;
	flex-direction: column;
	gap: 6px;
	transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
}

.wizard-pkg:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.25);
	border-color: var(--primary);
}

.wizard-pkg__topic {
	font-size: 14px;
	font-weight: 600;
	text-transform: capitalize;
}

.wizard-pkg__tags {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}

.wizard-pkg__tag {
	font-size: 12px;
	padding: 3px 10px;
	border-radius: 20px;
	background: rgba(58, 134, 255, 0.12);
	color: var(--primary);
	font-weight: 500;
}

.wizard-pkg__count {
	font-size: 13px;
	color: var(--text-muted);
	margin-top: auto;
}

/* wizard quick-pick packages (step 0) */
.wizard__packages {
	margin-bottom: 12px;
}

.wizard__packages-label {
	font-size: 12px;
	font-weight: 600;
	color: var(--text-muted);
	text-transform: uppercase;
	letter-spacing: 0.5px;
	margin-bottom: 8px;
}

.wizard__packages-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.wizard__package {
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 10px;
	padding: 10px 16px;
	font-size: 14px;
	font-weight: 500;
	color: var(--text-primary);
	cursor: pointer;
	transition: background 0.15s, border-color 0.15s, transform 0.1s;
	text-transform: capitalize;
}

.wizard__package:hover {
	background: var(--bg-card-hover);
	border-color: var(--primary);
	transform: translateY(-1px);
}

.wizard__package:active {
	transform: scale(0.97);
}

.wizard__divider {
	display: flex;
	align-items: center;
	gap: 12px;
	margin: 20px 0 14px;
	color: var(--text-secondary);
	font-size: 13px;
	font-weight: 500;
}

.wizard__divider::before,
.wizard__divider::after {
	content: '';
	flex: 1;
	height: 1px;
	background: var(--border);
}

/* wizard popular topic chips */
.wizard__chips {
	margin-top: 16px;
}

.wizard__chips-label {
	font-size: 12px;
	font-weight: 600;
	color: var(--text-muted);
	text-transform: uppercase;
	letter-spacing: 0.5px;
	margin-bottom: 8px;
}

.wizard__chips-wrap {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.wizard__chip {
	background: rgba(58, 134, 255, 0.1);
	color: var(--primary);
	border: 1px solid rgba(58, 134, 255, 0.2);
	border-radius: 20px;
	padding: 6px 14px;
	font-size: 13px;
	font-weight: 500;
	cursor: pointer;
	transition: background 0.15s, border-color 0.15s, transform 0.1s;
	display: inline-flex;
	align-items: center;
	gap: 6px;
}

.wizard__chip:hover {
	background: rgba(58, 134, 255, 0.2);
	border-color: var(--primary);
	transform: translateY(-1px);
}

.wizard__chip:active {
	transform: scale(0.97);
}

.wizard__chip-count {
	font-size: 10px;
	background: rgba(255, 255, 255, 0.08);
	padding: 1px 6px;
	border-radius: 10px;
	color: var(--text-muted);
}

/* wizard search suggestions */
.wizard__input-wrap {
	position: relative;
}

.wizard__suggestions {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 0 0 8px 8px;
	max-height: 240px;
	overflow-y: auto;
	z-index: 10;
}

.wizard__suggestions:empty {
	display: none;
}

.wizard__suggestion {
	padding: 10px 16px;
	font-size: 14px;
	cursor: pointer;
	display: flex;
	justify-content: space-between;
	align-items: center;
	transition: background 0.15s;
}

.wizard__suggestion:hover {
	background: var(--bg-card-hover);
}

.wizard__suggestion-count {
	font-size: 11px;
	color: var(--text-muted);
	background: rgba(255, 255, 255, 0.06);
	padding: 2px 8px;
	border-radius: 10px;
}

/* guided wizard popup */
.wizard-overlay {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.85);
	z-index: 1000;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s ease, visibility 0.3s ease;
	-webkit-backdrop-filter: blur(4px);
	backdrop-filter: blur(4px);
}
.wizard-overlay.open {
	opacity: 1;
	visibility: visible;
}
.wizard {
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%) scale(0.95);
	background: var(--bg-header);
	border: 1px solid var(--border);
	border-radius: 16px;
	z-index: 1001;
	width: 90%;
	max-width: 440px;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
}
.wizard.open {
	opacity: 1;
	visibility: visible;
	transform: translate(-50%, -50%) scale(1);
}
.wizard__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 20px 24px 0;
}
.wizard__title {
	font-size: 18px;
	font-weight: 700;
	color: var(--text-primary);
	margin: 0;
}
.wizard__close {
	background: none;
	border: none;
	color: var(--text-muted);
	cursor: pointer;
	padding: 4px;
}
.wizard__close svg {
	width: 20px;
	height: 20px;
}
.wizard__body {
	padding: 20px 24px;
}
.wizard__question {
	font-size: 15px;
	color: var(--text-secondary);
	margin: 0 0 16px;
}
.wizard__info {
	font-size: 15px;
	color: var(--text-primary);
	line-height: 1.6;
	padding: 16px 20px;
	background: rgba(250, 161, 19, 0.08);
	border: 1px solid rgba(250, 161, 19, 0.25);
	border-radius: 8px;
}
.wizard__options {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.wizard__option {
	padding: 8px 16px;
	border-radius: 20px;
	border: 1px solid var(--border);
	background: var(--bg-card);
	color: var(--text-primary);
	font-size: 14px;
	cursor: pointer;
	transition: background 0.15s, border-color 0.15s;
}
.wizard__option:hover {
	border-color: var(--primary);
}
.wizard__option--selected {
	background: var(--primary);
	border-color: var(--primary);
	color: #fff;
}
.wizard__input {
	width: 100%;
	padding: 12px 14px;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 8px;
	color: var(--text-primary);
	font-size: 14px;
}
.wizard__input::placeholder {
	color: var(--text-muted);
}
.wizard__input:focus {
	outline: none;
	border-color: var(--primary);
}
.wizard__hint {
	font-size: 12px;
	color: var(--text-muted);
	margin: 8px 0 0;
}
.wizard__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0 24px 20px;
}
.wizard__steps {
	display: flex;
	gap: 6px;
}
.wizard__dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--border);
}
.wizard__dot--active {
	background: var(--primary);
}
.wizard__actions {
	display: flex;
	gap: 8px;
}
.wizard__btn {
	padding: 8px 20px;
	border-radius: 8px;
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	border: none;
}
.wizard__btn--back {
	background: var(--bg-card);
	color: var(--text-primary);
	border: 1px solid var(--border);
}
.wizard__btn--next {
	background: var(--primary);
	color: #fff;
}
.wizard__btn--next:hover {
	background: var(--primary-dark);
}
.wizard-toast {
	position: fixed;
	bottom: 80px;
	left: 50%;
	transform: translateX(-50%) translateY(20px);
	background: var(--bg-card);
	border: 1px solid var(--border);
	color: var(--text-secondary);
	padding: 12px 20px;
	border-radius: 10px;
	font-size: 13px;
	z-index: 500;
	opacity: 0;
	transition: opacity 0.3s ease, transform 0.3s ease;
	max-width: 90%;
	text-align: center;
}
.wizard-toast.show {
	opacity: 1;
	transform: translateX(-50%) translateY(0);
}

/* note: AI wizard wide mode for recommendation cards */
.wizard.wizard--wide {
	max-width: 680px;
	max-height: 80vh;
	overflow-y: auto;
	overflow-x: hidden;
}
/* note: extra-wide for promo wizard (boxed group cards, 2-column grids) */
.wizard.wizard--xwide {
	max-width: 1100px;
	max-height: 85vh;
	overflow-y: auto;
	overflow-x: hidden;
}
/* note: prevent any wizard child from forcing a horizontal scrollbar */
.wizard, .wizard__body, .wizard__body * { box-sizing: border-box; }
.wizard__body { max-width: 100%; overflow-x: hidden; }
.wizard .promo-grid { max-width: 100%; }
.wizard .promo-tile, .wizard .promo-group-card { min-width: 0; max-width: 100%; }
.promo-group-card {
	background: #0f0f1a;
	border: 1px solid #2a2a3a;
	border-radius: 10px;
	padding: 16px;
	margin-bottom: 14px;
}
.promo-group-card__title {
	font-size: 15px;
	font-weight: 600;
	color: var(--highlight, #3A86FF);
	margin-bottom: 4px;
	display: flex;
	align-items: center;
	gap: 8px;
}
.promo-group-card__count {
	font-size: 12px;
	font-weight: 400;
	color: var(--text-muted, #888);
}
.promo-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 10px;
	margin-top: 10px;
}
@media (max-width: 900px) {
	.promo-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
	.promo-grid { grid-template-columns: 1fr; }
}
.promo-thumb {
	width: 100%;
	aspect-ratio: 16 / 9;
	border-radius: 6px;
	overflow: hidden;
	background: #000;
	position: relative;
	display: block;
}
.promo-thumb img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
}

/* note: collapsible Browse All Resources header. Default collapsed; clicking
   the header reveals filter bar + #resources-grid. Chevron rotates 180deg
   when open. Sized to feel like a clickable section divider. */
#browse-collapsible { margin: 40px 0 0; }
.browse-toggle {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	width: 100%;
	background: linear-gradient(135deg, rgba(58,134,255,0.10), rgba(124,58,237,0.10));
	border: 1px solid rgba(255,255,255,0.08);
	border-radius: 12px;
	padding: 18px 22px;
	cursor: pointer;
	color: #fff;
	font-family: inherit;
	transition: background 0.2s, border-color 0.2s;
	text-align: left;
}
.browse-toggle:hover {
	background: linear-gradient(135deg, rgba(58,134,255,0.16), rgba(124,58,237,0.16));
	border-color: rgba(255,255,255,0.16);
}
.browse-toggle__lock { display: none; flex-shrink: 0; align-items: center; justify-content: center; width: 36px; height: 36px; border-radius: 50%; background: rgba(250, 161, 19, 0.15); color: #faa113; }
.browse-toggle.chosen-locked .browse-toggle__lock { display: inline-flex; }
.browse-toggle__text { display: flex; flex-direction: column; gap: 2px; min-width: 0; flex: 1; }
.browse-toggle__title { font-size: 18px; font-weight: 600; }
.browse-toggle__subtitle { font-size: 13px; color: var(--text-muted, #a8a8b8); }
.browse-toggle__chevron { flex-shrink: 0; transition: transform 0.2s; color: var(--text-muted, #a8a8b8); }
.browse-toggle--open .browse-toggle__chevron { transform: rotate(180deg); }

/* note: locked-content overlay used by wizard final screens. Lighter blur so
   users can preview the result, and CTA pinned to the TOP of the veil so it
   sits in the visible area immediately (the wizard body can be tall and
   center-aligned would push the CTA below the fold). */
.chosen-locked-veil { position: relative; min-height: 240px; }
.chosen-locked-veil__content { filter: blur(4px); opacity: 0.85; pointer-events: none; user-select: none; }
.chosen-locked-veil__cta {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 12px;
	padding: 24px 20px;
	background: linear-gradient(180deg, rgba(0,0,0,0.78) 0%, rgba(0,0,0,0.62) 70%, rgba(0,0,0,0) 100%);
	border-radius: 12px 12px 0 0;
	text-align: center;
	z-index: 2;
	/* note: force own compositing layer + reset any inherited filter so the CTA
	   stays crisp even if an ancestor or quirky stacking context tries to
	   apply blur. */
	filter: none;
	-webkit-filter: none;
	backdrop-filter: none;
	transform: translateZ(0);
	will-change: transform;
}
.chosen-locked-veil__cta * { filter: none; -webkit-filter: none; }
.chosen-locked-veil__cta-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: rgba(250, 161, 19, 0.18);
	color: #faa113;
}
.chosen-locked-veil__cta-title { font-size: 18px; font-weight: 600; color: #fff; max-width: 460px; }
.chosen-locked-veil__cta-subtitle { font-size: 13px; color: var(--text-muted, #a8a8b8); max-width: 460px; }
.chosen-locked-veil__cta-btn {
	background: #faa113;
	color: #1a1a2a;
	border: none;
	border-radius: 8px;
	padding: 10px 22px;
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
}
.chosen-locked-veil__cta-btn:hover { background: #ffb531; }

/* note: scoped overrides for the Browse "Promotional Materials" block — keep
   tiles at roughly clip-thumb size (220px) and prevent right-edge bleed. */
#promo-browse-block { box-sizing: border-box; max-width: 100%; overflow: hidden; }
#promo-browse-block * { box-sizing: border-box; }
#promo-browse-block .promo-grid {
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: 16px;
}
#promo-browse-block .promo-tile { min-width: 0; max-width: 100%; }
#promo-browse-block .promo-thumb { aspect-ratio: 16 / 9; max-width: 100%; }
@media (max-width: 600px) {
	#promo-browse-block .promo-grid { grid-template-columns: repeat(2, 1fr); }
}

.wizard__loading {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 16px;
	padding: 40px 20px;
	color: var(--text-muted);
	font-size: 14px;
}

.wizard__loading-spinner {
	width: 36px;
	height: 36px;
	border: 3px solid var(--border);
	border-top-color: var(--primary);
	border-radius: 50%;
	animation: wizard-spin 0.8s linear infinite;
}

@keyframes wizard-spin {
	to { transform: rotate(360deg); }
}

.wizard__recs {
	display: flex;
	flex-direction: column;
	gap: 16px;
	padding: 4px 0;
}

.wizard__rec-card {
	background: var(--bg-dark);
	border: 1px solid var(--border);
	border-radius: 12px;
	padding: 20px;
	transition: border-color 0.2s;
}

.wizard__rec-card:hover {
	border-color: var(--primary);
}

.wizard__rec-header {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 8px;
	flex-wrap: wrap;
}

.wizard__rec-title {
	font-size: 16px;
	font-weight: 600;
	color: var(--text-primary);
}

.wizard__rec-badge {
	background: rgba(58, 134, 255, 0.15);
	color: var(--primary);
	font-size: 11px;
	font-weight: 600;
	padding: 3px 10px;
	border-radius: 12px;
	white-space: nowrap;
}

.wizard__rec-tags {
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
	margin-bottom: 10px;
}

.wizard__rec-tag {
	background: var(--bg-header);
	color: var(--text-muted);
	font-size: 11px;
	padding: 2px 8px;
	border-radius: 4px;
}

.wizard__rec-tag--scripture {
	color: var(--accent);
}

.wizard__rec-rationale {
	font-size: 13px;
	line-height: 1.6;
	color: var(--text-secondary);
	margin-bottom: 14px;
	font-style: italic;
}

.wizard__rec-clips-label {
	font-size: 11px;
	font-weight: 600;
	color: var(--text-muted);
	text-transform: uppercase;
	letter-spacing: 0.5px;
	margin-bottom: 8px;
}

.wizard__rec-clips {
	display: flex;
	gap: 12px;
	overflow-x: auto;
	padding-bottom: 8px;
	margin-bottom: 14px;
}

.wizard__rec-clip {
	flex-shrink: 0;
	width: 160px;
}

.wizard__rec-clip__thumb {
	position: relative;
	width: 160px;
	aspect-ratio: 16/9;
	border-radius: 6px;
	overflow: hidden;
	margin-bottom: 6px;
	background: var(--bg-dark);
}

.wizard__rec-clip__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.wizard__rec-clip__play {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0,0,0,0.4);
	opacity: 0;
	transition: opacity 0.2s;
}

.wizard__rec-clip__thumb:hover .wizard__rec-clip__play {
	opacity: 1;
}

.wizard__rec-clip__play svg {
	width: 28px;
	height: 28px;
	fill: #fff;
	filter: drop-shadow(0 2px 4px rgba(0,0,0,0.3));
}

.wizard__rec-clip__title {
	font-size: 11px;
	font-weight: 600;
	color: var(--text-primary);
	margin-bottom: 2px;
}

.wizard__rec-clip__note {
	font-size: 11px;
	color: var(--accent);
	line-height: 1.4;
}

.wizard__rec-actions {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

.wizard__rec-btn {
	padding: 10px 18px;
	border-radius: 8px;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	border: none;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 6px;
}

.wizard__rec-btn--primary {
	background: var(--primary);
	color: #000;
}

.wizard__rec-btn--primary:hover {
	background: #2563eb;
}

.wizard__rec-btn--secondary {
	background: var(--bg-header);
	color: var(--text-secondary);
}

.wizard__rec-btn--secondary:hover {
	background: var(--border);
}

.wizard__powered {
	text-align: center;
	font-size: 11px;
	color: var(--text-muted);
	padding: 8px 0 4px;
}

.bulk-download-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 10px 18px;
	background: var(--primary);
	color: #000;
	border: none;
	border-radius: 8px;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
}

.bulk-download-btn:hover {
	background: #2563eb;
}

.bulk-download-btn.loading {
	opacity: 0.7;
	cursor: wait;
}

@media (max-width: 768px) {
	.wizard.wizard--wide {
		max-width: 95%;
		max-height: 90vh;
	}

	.wizard__rec-clip {
		width: 140px;
	}

	.wizard__rec-clip__thumb {
		width: 140px;
	}

	.wizard__rec-clip__play {
		opacity: 1;
	}
}

.chosen-section {
	padding: 60px 0;
	border-bottom: 1px solid var(--border);
}

.chosen-section:last-child {
	border-bottom: none;
}

.chosen-section__title {
	font-size: 32px;
	font-weight: 700;
	color: var(--text-primary);
	margin: 0 0 8px;
	text-align: center;
}

.anchor-offset {
	display: block;
	position: relative;
	top: -140px;
	visibility: hidden;
}

.chosen-section__subtitle {
	font-size: 16px;
	color: var(--text-secondary);
	margin: 0 0 40px;
	text-align: center;
}

.chosen-formats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}

.chosen-formats--grid {
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
}

.chosen-format {
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 12px;
	padding: 32px 24px;
	text-align: center;
}

.chosen-formats--grid .chosen-format {
	padding: 24px 20px;
}

.chosen-formats--grid .chosen-format__desc {
	margin: 0;
}

.chosen-format__icon {
	width: 56px;
	height: 56px;
	background: rgba(58, 134, 255, 0.1);
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 20px;
}

.chosen-format__icon svg {
	width: 28px;
	height: 28px;
	color: var(--primary);
}

.chosen-format__title {
	font-size: 20px;
	font-weight: 600;
	color: var(--text-primary);
	margin: 0 0 12px;
}

.chosen-format__desc {
	font-size: 14px;
	color: var(--text-secondary);
	margin: 0 0 20px;
	line-height: 1.6;
}

.chosen-format__list {
	list-style: none;
	padding: 0;
	margin: 0;
	text-align: left;
}

.chosen-format__list li {
	font-size: 14px;
	color: var(--text-secondary);
	padding: 8px 0;
	padding-left: 24px;
	position: relative;
}

.chosen-format__list li::before {
	content: '✓';
	position: absolute;
	left: 0;
	color: var(--accent);
	font-weight: 600;
}

.chosen-format--link {
	text-decoration: none;
	cursor: pointer;
	transition: all 0.2s;
}

.chosen-format--link:hover {
	border-color: var(--primary);
	transform: translateY(-4px);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
}

.chosen-format__link {
	display: block;
	margin-top: 20px;
	padding-top: 16px;
	border-top: 1px solid var(--border);
	color: var(--primary);
	font-size: 14px;
	font-weight: 600;
	text-align: center;
}

.chosen-format--link:hover .chosen-format__link {
	text-decoration: underline;
}

.chosen-seasons {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 20px;
}

.chosen-season {
	display: block;
	text-decoration: none;
	border-radius: 12px;
	overflow: hidden;
	background: var(--bg-card);
	border: 1px solid var(--border);
	transition: all 0.2s;
}

.chosen-season:hover {
	transform: translateY(-4px);
	border-color: var(--primary);
}

.chosen-season__thumb {
	position: relative;
	aspect-ratio: 16/9;
	overflow: hidden;
}

.chosen-season__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.chosen-season__play {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 48px;
	height: 48px;
	background: rgba(0, 0, 0, 0.7);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	transition: opacity 0.2s;
}

.chosen-season:hover .chosen-season__play {
	opacity: 1;
}

.chosen-season__play svg {
	width: 24px;
	height: 24px;
	color: #fff;
	margin-left: 3px;
}

.chosen-season__info {
	padding: 16px;
}

.chosen-season__title {
	font-size: 16px;
	font-weight: 600;
	color: var(--text-primary);
	margin: 0 0 4px;
}

.chosen-season__meta {
	font-size: 13px;
	color: var(--text-secondary);
}

.chosen-season--clip {
	opacity: 0.9;
}

.chosen-resources {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}

.chosen-resource {
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 12px;
	padding: 32px 24px;
	text-align: center;
	position: relative;
}

.chosen-resource--coming {
	opacity: 0.6;
}

.chosen-resource__icon {
	width: 56px;
	height: 56px;
	background: rgba(58, 134, 255, 0.1);
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 20px;
}

.chosen-resource__icon svg {
	width: 28px;
	height: 28px;
	color: var(--primary);
}

.chosen-resource__title {
	font-size: 18px;
	font-weight: 600;
	color: var(--text-primary);
	margin: 0 0 8px;
}

.chosen-resource__desc {
	font-size: 14px;
	color: var(--text-secondary);
	margin: 0 0 16px;
}

.chosen-resource__badge {
	display: inline-block;
	background: var(--highlight);
	color: #000;
	padding: 4px 12px;
	border-radius: 12px;
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
}

/* resource episode cards */
.chosen-episodes {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.chosen-episode {
	display: flex;
	align-items: center;
	justify-content: space-between;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 10px;
	padding: 16px 20px;
	transition: border-color 0.2s;
}

.chosen-episode:hover {
	border-color: var(--primary);
}

.chosen-episode__thumb {
	position: relative;
	flex-shrink: 0;
	width: 120px;
	height: 68px;
	border-radius: 6px;
	overflow: hidden;
	margin-right: 16px;
}

.chosen-episode__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.chosen-episode__thumb .chosen-episode__play {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 32px;
	height: 32px;
	background: rgba(0, 0, 0, 0.7);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	transition: opacity 0.2s;
}

.chosen-episode__thumb:hover .chosen-episode__play {
	opacity: 1;
}

.chosen-episode__thumb .chosen-episode__play svg {
	width: 14px;
	height: 14px;
	color: #fff;
	margin-left: 2px;
}

.chosen-episode__info {
	flex: 1;
	min-width: 0;
}

.chosen-episode__title {
	font-size: 15px;
	font-weight: 600;
	color: var(--text-primary);
	margin: 0 0 2px;
}

.chosen-episode__meta {
	font-size: 13px;
	color: var(--text-secondary);
}

.chosen-episode__actions {
	display: flex;
	gap: 10px;
	margin-left: 16px;
}

.chosen-episode__btn {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 2px;
	padding: 10px 16px;
	border-radius: 8px;
	text-decoration: none;
	transition: all 0.2s;
	min-width: 180px;
}

.chosen-episode__btn--primary {
	background: var(--primary);
	color: #fff;
}

.chosen-episode__btn--primary:hover {
	background: #2563eb;
}

.chosen-episode__btn--secondary {
	background: rgba(58, 134, 255, 0.1);
	color: var(--primary);
	border: 1px solid rgba(58, 134, 255, 0.3);
}

.chosen-episode__btn--secondary:hover {
	background: rgba(58, 134, 255, 0.2);
}

.chosen-episode__btn--disabled {
	background: var(--bg-secondary);
	color: var(--text-muted);
	cursor: default;
	pointer-events: none;
}

.chosen-episode__btn-label {
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	opacity: 0.8;
}

.chosen-episode__btn-file {
	font-size: 12px;
	font-weight: 500;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 160px;
}

.chosen-episode__btn--disabled .chosen-episode__btn-file {
	font-style: italic;
}

@media (max-width: 768px) {
	.chosen-episode {
		flex-direction: column;
		align-items: stretch;
		gap: 12px;
	}

	.chosen-episode__thumb {
		width: 100%;
		height: auto;
		aspect-ratio: 16/9;
		margin-right: 0;
		margin-bottom: 8px;
	}

	.chosen-episode__thumb .chosen-episode__play {
		opacity: 1;
	}

	.chosen-episode__actions {
		margin-left: 0;
		flex-direction: column;
	}

	.chosen-episode__btn {
		min-width: 100%;
	}
}

/* resource section tabs */
.chosen-tabs {
	display: flex;
	gap: 8px;
	margin-bottom: 24px;
	border-bottom: 1px solid var(--border);
	padding-bottom: 16px;
}

.chosen-tab {
	padding: 10px 20px;
	border-radius: 8px;
	background: transparent;
	border: 1px solid var(--border);
	color: var(--text-secondary);
	font-size: 14px;
	font-weight: 500;
	cursor: pointer;
	transition: all 0.2s;
}

.chosen-tab:hover {
	border-color: var(--primary);
	color: var(--text-primary);
}

.chosen-tab.active {
	background: var(--primary);
	border-color: var(--primary);
	color: #fff;
}

.chosen-tab-content {
	display: none;
}

.chosen-tab-content.active {
	display: block;
}

.chosen-tab-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 20px;
	padding-bottom: 16px;
	border-bottom: 1px solid var(--border);
}

.chosen-tab-header p {
	color: var(--text-secondary);
	margin: 0;
	flex: 1;
}

.chosen-tab-link {
	color: var(--primary);
	font-size: 14px;
	font-weight: 600;
	text-decoration: none;
	white-space: nowrap;
	margin-left: 24px;
}

.chosen-tab-link:hover {
	text-decoration: underline;
}

@media (max-width: 768px) {
	.chosen-tab-header {
		flex-direction: column;
		align-items: flex-start;
		gap: 12px;
	}

	.chosen-tab-link {
		margin-left: 0;
	}
}

.chosen-cta {
	background: linear-gradient(135deg, var(--primary) 0%, #2563eb 100%);
	margin: 0 -24px -24px;
	padding: 60px 24px;
	text-align: center;
}

.chosen-cta__title {
	font-size: 32px;
	font-weight: 700;
	color: #fff;
	margin: 0 0 12px;
}

.chosen-cta__text {
	font-size: 16px;
	color: rgba(255, 255, 255, 0.9);
	margin: 0 0 28px;
}

.chosen-cta__btn {
	display: inline-block;
	background: #fff;
	color: var(--primary);
	padding: 14px 32px;
	border-radius: 8px;
	font-size: 16px;
	font-weight: 600;
	text-decoration: none;
	transition: all 0.2s;
}

.chosen-cta__btn:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 20px rgba(0, 0, 0, 0.3);
}

.chosen-cta--alt {
	background: var(--bg-card);
	border-top: 1px solid var(--border);
	margin: 48px -24px -24px;
}

.chosen-cta--alt .chosen-cta__title {
	color: var(--text-primary);
}

.chosen-cta--alt .chosen-cta__text {
	color: var(--text-secondary);
}

.chosen-cta--alt .chosen-cta__btn {
	background: var(--primary);
	color: #fff;
}

/* compact hero for sub-pages */
.chosen-hero--compact {
	min-height: 280px;
	padding: 40px 24px 60px;
}

.chosen-hero--compact .chosen-hero__title {
	font-size: 36px;
}

.chosen-hero--compact .chosen-hero__subtitle {
	font-size: 16px;
	max-width: 600px;
}

/* breadcrumb */
.chosen-breadcrumb {
	display: inline-block;
	color: rgba(255, 255, 255, 0.7);
	font-size: 14px;
	text-decoration: none;
	margin-bottom: 16px;
	transition: color 0.2s;
}

.chosen-breadcrumb:hover {
	color: #fff;
}

/* how-to steps */
.chosen-howto {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
}

.chosen-howto__step {
	display: flex;
	gap: 16px;
	align-items: flex-start;
}

.chosen-howto__num {
	width: 40px;
	height: 40px;
	background: var(--primary);
	color: #fff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
	font-weight: 700;
	flex-shrink: 0;
}

.chosen-howto__text h3 {
	font-size: 16px;
	font-weight: 600;
	color: var(--text-primary);
	margin: 0 0 6px;
}

.chosen-howto__text p {
	font-size: 14px;
	color: var(--text-secondary);
	margin: 0;
	line-height: 1.5;
}

/* season headers */
.chosen-season-header {
	color: var(--text-primary);
	font-size: 20px;
	font-weight: 600;
	margin: 32px 0 16px;
	padding-bottom: 8px;
	border-bottom: 1px solid var(--border);
}

.chosen-season-header:first-of-type {
	margin-top: 0;
}

.chosen-season-resources {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-bottom: 20px;
}

.chosen-season-resource {
	display: flex;
	flex-direction: column;
	gap: 4px;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 8px;
	padding: 12px 16px;
	text-decoration: none;
	transition: all 0.2s ease;
}

.chosen-season-resource:hover {
	background: var(--bg-card-hover);
	border-color: var(--primary);
}

.chosen-season-resource__title {
	color: var(--primary);
	font-size: 14px;
	font-weight: 600;
}

.chosen-season-resource__file {
	color: var(--text-muted);
	font-size: 12px;
}

/* Resources Hub Page Styles */
.resources-actions {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 16px;
	margin-top: 24px;
}

.resources-action {
	display: flex;
	align-items: flex-start;
	gap: 16px;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 12px;
	padding: 20px;
	text-decoration: none;
	transition: all 0.2s ease;
}

.resources-action:hover {
	background: var(--bg-card-hover);
	border-color: var(--primary);
	transform: translateY(-2px);
}

.resources-action--coming {
	opacity: 0.6;
	pointer-events: none;
}

.resources-action__icon {
	flex-shrink: 0;
	width: 48px;
	height: 48px;
	background: rgba(58, 134, 255, 0.15);
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.resources-action__icon svg {
	width: 24px;
	height: 24px;
	color: var(--primary);
}

.resources-action__text h3 {
	color: var(--text-primary);
	font-size: 16px;
	font-weight: 600;
	margin: 0 0 4px;
}

.resources-action__text p {
	color: var(--text-muted);
	font-size: 13px;
	margin: 0;
}

/* note: Sticky filter bar on desktop */
.resources-filter-bar {
	position: sticky;
	top: 64px;
	z-index: 20;
	background: var(--bg-dark);
	padding: 24px 0 16px;
	margin: 40px 0 0;
	/* note: ensure content doesn't show through when scrolling */
	box-shadow: 0 10px 20px var(--bg-dark);
	transition: max-height 0.3s ease, opacity 0.3s ease, padding 0.3s ease, margin 0.3s ease;
	overflow: hidden;
}

.resources-filter-bar--collapsed {
	max-height: 0;
	opacity: 0;
	padding: 0;
	margin: 0;
	pointer-events: none;
}

.resources-filter-expand {
	display: block;
	width: 100%;
	padding: 12px;
	margin: 24px 0 0;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 8px;
	color: var(--text-secondary);
	font-size: 13px;
	cursor: pointer;
	transition: background 0.15s, color 0.15s;
	text-align: center;
}

.resources-filter-expand:hover {
	background: var(--bg-card-hover);
	color: var(--text-primary);
}

/* note: full-bleed background only needed when .main (max-width:1400px) is narrower than viewport */
@media (min-width: 1400px) {
	.resources-filter-bar::after {
		content: '';
		position: absolute;
		left: -50vw;
		right: -50vw;
		top: 0;
		bottom: 0;
		background: var(--bg-dark);
		z-index: -1;
	}
}

.resources-filter-bar__header {
	margin-bottom: 16px;
}

.resources-filter-bar__title {
	color: var(--text-primary);
	font-size: 24px;
	font-weight: 700;
	margin: 0;
}

.resources-filter-bar__subtitle {
	color: var(--text-secondary);
	font-size: 15px;
	margin: 8px 0 0;
	font-weight: 400;
}

.resources-filters {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
	margin-bottom: 16px;
}

.resources-filter {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.resources-filter label {
	color: var(--text-muted);
	font-size: 12px;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.resources-filter select {
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 8px;
	color: var(--text-primary);
	padding: 10px 36px 10px 12px;
	font-size: 14px;
	cursor: pointer;
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 12px center;
}

.resources-filter select:hover {
	border-color: var(--primary);
}

.resources-filter select:focus {
	outline: none;
	border-color: var(--primary);
	box-shadow: 0 0 0 2px rgba(58, 134, 255, 0.2);
}

.resources-filter--search {
	flex: 1;
	max-width: 300px;
}

.resources-filter--search input[type="text"] {
	width: 100%;
	padding: 10px 14px;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 8px;
	color: var(--text);
	font-size: 14px;
}

.resources-filter--search input[type="text"]::placeholder {
	color: var(--text-muted);
}

.resources-filter--search input[type="text"]:focus {
	outline: none;
	border-color: var(--primary);
	box-shadow: 0 0 0 2px rgba(58, 134, 255, 0.2);
}

.resources-results-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 16px;
	padding-bottom: 16px;
	border-bottom: 1px solid var(--border);
}

.resources-count {
	color: var(--text-muted);
	font-size: 14px;
}

.resources-clear {
	color: var(--primary);
	font-size: 14px;
	text-decoration: none;
}

.resources-clear:hover {
	text-decoration: underline;
}

/* note: hide mobile-only elements on desktop */
.resources-filter-toggle,
.resources-filter-drawer,
.resources-filter-drawer__overlay,
.resources-filters--mobile {
	display: none;
}

.resources-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 16px;
}

.resources-season {
	display: flex;
	gap: 32px;
	padding: 32px 0;
	border-bottom: 1px solid var(--border);
}

.resources-season:first-child {
	padding-top: 16px;
}

.resources-season:last-child {
	border-bottom: none;
}

.resources-season__sidebar {
	flex-shrink: 0;
	width: 280px;
	text-align: center;
	position: sticky;
	top: var(--filter-bar-offset);
	align-self: flex-start;
	z-index: auto;
	background: var(--bg-dark);
}

.resources-season__artwork {
	width: 100%;
	border-radius: 12px;
	margin-bottom: 12px;
}

.resources-season__title {
	color: var(--text-primary);
	font-size: 18px;
	font-weight: 700;
	margin-bottom: 4px;
}

.resources-season__count {
	color: var(--text-muted);
	font-size: 14px;
}

.resources-season__content {
	flex: 1;
	min-width: 0;
}

.resources-type-group {
	margin-bottom: 32px;
}

.resources-type-group:last-child {
	margin-bottom: 0;
}

.resources-type-group__title {
	color: var(--text-secondary);
	font-size: 14px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	margin: 0 0 16px;
	padding-bottom: 8px;
	border-bottom: 1px solid var(--border);
}

.resources-type-group__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 12px;
}

@media (max-width: 768px) {
	.resources-season {
		flex-direction: column;
		gap: 20px;
	}

	.resources-season__sidebar {
		width: 100%;
		display: flex;
		align-items: center;
		gap: 16px;
		text-align: left;
		position: sticky;
		top: var(--filter-bar-offset);
		align-self: auto;
		background: var(--bg-dark);
		padding: 12px 0;
		margin: -12px 0 0;
		z-index: auto;
	}

	.resources-season__artwork {
		width: 80px;
		flex-shrink: 0;
		margin-bottom: 0;
		border-radius: 8px;
	}

	.resources-type-group__grid {
		grid-template-columns: 1fr;
	}
}

.resources-card {
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 12px;
	padding: 20px;
	text-decoration: none;
	transition: all 0.2s ease;
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.resources-card:hover {
	background: var(--bg-card-hover);
	border-color: var(--primary);
	transform: translateY(-2px);
}

.resources-card__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.resources-card__type {
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	padding: 4px 8px;
	border-radius: 4px;
}

.resources-card--sermon .resources-card__type {
	background: rgba(58, 134, 255, 0.15);
	color: var(--primary);
}

.resources-card--guide .resources-card__type {
	background: rgba(0, 194, 168, 0.15);
	color: var(--accent);
}

.resources-card__episode {
	color: var(--text-muted);
	font-size: 12px;
	font-weight: 500;
}

.resources-card__title {
	color: var(--text-primary);
	font-size: 16px;
	font-weight: 600;
	margin: 0;
	line-height: 1.3;
}

.resources-card__meta {
	margin-top: auto;
}

.resources-card__file {
	color: var(--text-muted);
	font-size: 12px;
}

.resources-card__themes {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-top: 8px;
}

.resources-card__theme {
	background: var(--bg-hover);
	color: var(--text-muted);
	font-size: 11px;
	padding: 2px 8px;
	border-radius: 4px;
	text-transform: capitalize;
}

.resources-card--sermon .resources-card__theme {
	background: rgba(234, 179, 8, 0.15);
	color: #eab308;
}

.resources-card--guide .resources-card__theme {
	background: rgba(59, 130, 246, 0.15);
	color: #3b82f6;
}

.resources-card--devotional .resources-card__type {
	background: rgba(168, 85, 247, 0.15);
	color: #a855f7;
}

.resources-card--devotional .resources-card__theme {
	background: rgba(168, 85, 247, 0.15);
	color: #a855f7;
}

.resources-card--promo .resources-card__type {
	background: rgba(236, 72, 153, 0.15);
	color: #ec4899;
}

.resources-card--promo .resources-card__theme {
	background: rgba(236, 72, 153, 0.15);
	color: #ec4899;
}

.resources-card--teaching .resources-card__type {
	background: rgba(251, 191, 36, 0.15);
	color: #fbbf24;
}

.resources-card--teaching .resources-card__theme {
	background: rgba(251, 191, 36, 0.15);
	color: #fbbf24;
}

.resources-card__download {
	display: flex;
	align-items: center;
	gap: 8px;
	color: var(--primary);
	font-size: 13px;
	font-weight: 500;
	padding-top: 12px;
	border-top: 1px solid var(--border);
}

.resources-card__download svg {
	width: 16px;
	height: 16px;
}

.resources-card__scripture {
	display: flex;
	align-items: flex-start;
	flex-wrap: wrap;
	gap: 6px;
	color: var(--text-muted);
	font-size: 12px;
	padding-top: 12px;
	border-top: 1px solid var(--border);
	margin-top: auto;
}

.resources-card__scripture-icon {
	width: 14px;
	height: 14px;
	flex-shrink: 0;
	margin-top: 1px;
	opacity: 0.7;
}

.resources-card__scripture-ref {
	background: rgba(251, 191, 36, 0.1);
	color: var(--highlight);
	padding: 2px 6px;
	border-radius: 3px;
	font-size: 11px;
}

/* note: Episode-centric layout - each episode row with watch link + resources */
.episode-row {
	display: flex;
	flex-direction: column;
	gap: 16px;
	padding: 24px 0;
	border-bottom: 1px solid var(--border);
}

.episode-row:last-child {
	border-bottom: none;
}

.episode-row__header {
	display: flex;
	gap: 16px;
	align-items: flex-start;
}

.episode-row__watch {
	display: flex;
	gap: 16px;
	align-items: flex-start;
	text-decoration: none;
	transition: transform 0.2s ease;
}

.episode-row__watch:hover {
	transform: translateY(-2px);
}

.episode-row__watch.playing {
	transform: none;
}

.episode-row__thumb {
	position: relative;
	border-radius: 10px;
	overflow: hidden;
	width: 280px;
	flex-shrink: 0;
	aspect-ratio: 16/9;
	background: var(--bg-card);
}

.episode-row__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.episode-row__thumb video,
.episode-row__thumb iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: contain;
	background: #000;
}

.episode-row__play {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, 0.4);
	opacity: 0;
	transition: opacity 0.2s ease;
	cursor: pointer;
}

.episode-row__watch:hover .episode-row__play {
	opacity: 1;
}

.episode-row__watch.playing .episode-row__play {
	display: none;
}

.episode-row__play svg {
	width: 48px;
	height: 48px;
	color: #fff;
	filter: drop-shadow(0 2px 4px rgba(0,0,0,0.3));
}

.episode-row__info {
	text-align: left;
	flex: 1;
}

.episode-row__number {
	color: var(--text-muted);
	font-size: 12px;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.episode-row__title {
	color: var(--text-primary);
	font-size: 14px;
	font-weight: 600;
	line-height: 1.3;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.episode-row__section-title {
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	color: var(--text-muted);
	margin: 12px 0 8px;
}
.episode-row__resources {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

/* note: Clips thumbnail strip within episode rows */
.episode-clips {
	padding: 0 16px 16px;
}

.episode-clips__label {
	font-size: 13px;
	color: var(--text-muted);
	margin-bottom: 12px;
	display: flex;
	align-items: center;
	gap: 8px;
}

.episode-clips__label svg {
	width: 16px;
	height: 16px;
}

.episode-clips__strip {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
}

.clip-thumb {
	position: relative;
	width: 220px;
	cursor: pointer;
	text-decoration: none;
	transition: transform 0.2s;
}

.clip-thumb:hover {
	transform: translateY(-2px);
	z-index: 200;
}

.clip-thumb.playing {
	transform: none;
}

.clip-thumb__image {
	position: relative;
	width: 220px;
	aspect-ratio: 16/9;
	border-radius: 8px;
	overflow: hidden;
	margin-bottom: 8px;
	background: var(--bg-dark);
}

.clip-thumb__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* note: iframe inside clip thumbnail when playing */
.clip-thumb__image iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: none;
	background: #000;
}

.clip-thumb__play {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0,0,0,0.4);
	opacity: 0;
	transition: opacity 0.2s;
}

.clip-thumb:hover .clip-thumb__play {
	opacity: 1;
}

.clip-thumb.playing .clip-thumb__play {
	display: none;
}

.clip-thumb__play svg {
	width: 32px;
	height: 32px;
	fill: #fff;
	filter: drop-shadow(0 2px 4px rgba(0,0,0,0.3));
}

.clip-thumb__download {
	position: absolute;
	bottom: 8px;
	right: 8px;
	width: 28px;
	height: 28px;
	background: rgba(0, 0, 0, 0.7);
	border: none;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	transition: opacity 0.2s, background 0.2s;
	z-index: 3;
	cursor: pointer;
	padding: 0;
}

.clip-thumb:hover .clip-thumb__download {
	opacity: 1;
}

.clip-thumb__download:hover {
	background: var(--primary-gold);
}

.clip-thumb__download.loading {
	opacity: 1;
	background: var(--primary-gold);
	animation: pulse-loading 1s infinite;
}

@keyframes pulse-loading {
	0%, 100% { opacity: 0.7; }
	50% { opacity: 1; }
}

.clip-thumb__download svg {
	width: 14px;
	height: 14px;
	stroke: #fff;
}

.clip-thumb.playing .clip-thumb__download {
	opacity: 1;
}

.clip-thumb__tooltip {
	position: absolute;
	bottom: calc(100% + 8px);
	left: 50%;
	transform: translateX(-50%);
	width: 280px;
	background: var(--bg-header);
	border: 1px solid var(--border);
	color: var(--text-primary);
	font-size: 12px;
	line-height: 1.5;
	padding: 12px 14px;
	border-radius: 8px;
	pointer-events: none;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.2s ease, visibility 0.2s ease;
	z-index: 200;
	box-shadow: 0 8px 24px rgba(0,0,0,0.3);
}

.clip-thumb__tooltip::after {
	content: '';
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	border: 6px solid transparent;
	border-top-color: var(--border);
}

.clip-thumb__tooltip.loaded {
	opacity: 1;
	visibility: visible;
}

.clip-thumb.playing .clip-thumb__tooltip {
	display: none;
}

.clip-thumb__title {
	font-size: 12px;
	color: var(--text-secondary);
	line-height: 1.3;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.clip-thumb.playing .clip-thumb__title {
	color: var(--primary-gold);
}

.episode-row__empty {
	color: var(--text-muted);
	font-size: 13px;
	font-style: italic;
	padding: 8px 0;
}

/* note: Resource badges within episode rows */
.episode-resource {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 8px;
	padding: 10px 14px;
	text-decoration: none;
	transition: all 0.2s ease;
	max-width: 100%;
	position: relative;
}

.episode-resource:hover {
	border-color: var(--primary);
	background: rgba(58, 134, 255, 0.05);
}

.episode-resource__type {
	flex-shrink: 0;
	background: var(--bg-dark);
	color: var(--text-muted);
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.3px;
	padding: 4px 8px;
	border-radius: 4px;
}

.episode-resource__title {
	color: var(--text-primary);
	font-size: 13px;
	font-weight: 500;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 200px;
}

.episode-resource__icon {
	flex-shrink: 0;
	width: 14px;
	height: 14px;
	color: var(--text-muted);
}

/* note: Type-specific colors for resource badges */
.episode-resource.resources-card--sermon .episode-resource__type {
	background: rgba(251, 191, 36, 0.15);
	color: #fbbf24;
}

.episode-resource.resources-card--guide .episode-resource__type {
	background: rgba(59, 130, 246, 0.15);
	color: #3b82f6;
}

.episode-resource.resources-card--devotional .episode-resource__type {
	background: rgba(168, 85, 247, 0.15);
	color: #a855f7;
}

.episode-resource.resources-card--promo .episode-resource__type {
	background: rgba(236, 72, 153, 0.15);
	color: #ec4899;
}

.episode-resource.resources-card--teaching .episode-resource__type {
	background: rgba(251, 191, 36, 0.15);
	color: #fbbf24;
}

/* note: Resource tooltip - desktop hover */
.resource-tooltip {
	position: absolute;
	bottom: calc(100% + 8px);
	left: 50%;
	transform: translateX(-50%);
	background: var(--bg-header);
	border: 1px solid var(--border);
	border-radius: 8px;
	padding: 12px;
	min-width: 200px;
	max-width: 280px;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.2s ease, visibility 0.2s ease;
	z-index: 200;
	pointer-events: none;
}

.resource-tooltip::after {
	content: '';
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	border: 6px solid transparent;
	border-top-color: var(--border);
}

.episode-resource.has-tooltip:hover .resource-tooltip {
	opacity: 1;
	visibility: visible;
}

.resource-tooltip__row {
	display: flex;
	flex-direction: column;
	gap: 2px;
	margin-bottom: 10px;
}

.resource-tooltip__row:last-child {
	margin-bottom: 0;
}

.resource-tooltip__label {
	color: var(--text-muted);
	font-size: 10px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.resource-tooltip__value {
	color: var(--text-primary);
	font-size: 13px;
	font-weight: 400;
	line-height: 1.4;
}

/* note: Mobile - tap to expand instead of hover */
@media (max-width: 768px) {
	.resource-tooltip {
		position: static;
		transform: none;
		opacity: 1;
		visibility: visible;
		margin-top: 10px;
		padding: 10px;
		min-width: auto;
		max-width: none;
		width: 100%;
		box-shadow: none;
		display: none;
	}

	.resource-tooltip::after {
		display: none;
	}

	.episode-resource.has-tooltip {
		flex-wrap: wrap;
	}

	.episode-resource.has-tooltip.expanded .resource-tooltip {
		display: block;
	}

	/* note: info icon indicator on mobile */
	.episode-resource.has-tooltip::before {
		content: 'ℹ';
		position: absolute;
		top: -6px;
		right: -6px;
		width: 18px;
		height: 18px;
		background: var(--primary);
		color: #fff;
		font-size: 11px;
		font-weight: 600;
		border-radius: 50%;
		display: flex;
		align-items: center;
		justify-content: center;
	}
}

/* note: Season-level resources section */
.season-resources {
	margin-top: 24px;
	padding-top: 24px;
	border-top: 1px solid var(--border);
}

.season-resources__title {
	color: var(--text-secondary);
	font-size: 14px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	margin: 0 0 16px;
}

.season-resources__grid {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.episode-resource--season .episode-resource__title {
	max-width: 300px;
}

@media (max-width: 768px) {
	.episode-row {
		flex-direction: column;
		gap: 16px;
		padding: 16px 0;
	}

	.episode-row__header {
		width: 100%;
		display: block;
	}

	.episode-row__watch {
		display: block;
		width: 100%;
	}

	.episode-row__watch.playing {
		display: block;
	}

	.episode-row__thumb {
		width: 100%;
		flex-shrink: 0;
		margin-bottom: 12px;
	}

	.episode-row__info {
		text-align: left;
		flex: 1;
	}

	.episode-row__resources {
		width: 100%;
	}

	.episode-resource {
		width: 100%;
	}

	.episode-resource__title {
		max-width: none;
		flex: 1;
	}

	/* note: Mobile clips */
	.episode-clips {
		padding: 0 0 16px;
	}

	.episode-clips__strip {
		gap: 12px;
	}

	.clip-thumb {
		width: calc(50% - 6px);
	}

	.clip-thumb__image {
		width: 100%;
	}

	.clip-thumb__title {
		font-size: 11px;
	}

	.clip-thumb__tooltip {
		position: static;
		transform: none;
		opacity: 1;
		visibility: visible;
		width: 100%;
		font-size: 11px;
		margin-top: 6px;
		padding: 10px;
		box-shadow: none;
		display: none;
	}

	.clip-thumb__tooltip::after {
		display: none;
	}

	.clip-thumb.expanded .clip-thumb__tooltip {
		display: block;
	}

	/* note: blue info icon on mobile clip thumbnails */
	.clip-thumb.has-clip-info::before {
		content: 'ℹ';
		position: absolute;
		top: -6px;
		right: -6px;
		width: 18px;
		height: 18px;
		background: var(--primary);
		color: #fff;
		font-size: 11px;
		font-weight: 600;
		border-radius: 50%;
		display: flex;
		align-items: center;
		justify-content: center;
		z-index: 5;
	}
}

/* note: Legacy episode grid styles (keeping for backward compat) */
.resources-video-section {
	margin-bottom: 20px;
}

.resources-episodes-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	gap: 16px;
}

.resources-episode {
	text-decoration: none;
	transition: transform 0.2s ease;
}

.resources-episode:hover {
	transform: translateY(-4px);
}

.resources-episode__thumb {
	position: relative;
	border-radius: 12px;
	overflow: hidden;
	aspect-ratio: 16/9;
	background: var(--bg-card);
}

.resources-episode__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.resources-episode__play {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, 0.3);
	opacity: 0;
	transition: opacity 0.2s ease;
}

.resources-episode:hover .resources-episode__play {
	opacity: 1;
}

.resources-episode__play svg {
	width: 48px;
	height: 48px;
	color: #fff;
	filter: drop-shadow(0 2px 4px rgba(0,0,0,0.3));
}

.resources-episode__info {
	padding: 10px 4px 4px;
}

.resources-episode__title {
	color: var(--text-primary);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.3;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* note: Clips grid within resources */
.resources-clips-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: 20px;
}

.resources-clip-card {
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 12px;
	overflow: hidden;
	text-decoration: none;
	transition: all 0.2s ease;
}

.resources-clip-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
	border-color: var(--primary);
}

.resources-clip-card__thumb {
	aspect-ratio: 16/9;
	overflow: hidden;
}

.resources-clip-card__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.resources-clip-card__info {
	padding: 16px;
}

.resources-clip-card__title {
	color: var(--text-primary);
	font-size: 16px;
	font-weight: 600;
	margin-bottom: 4px;
}

.resources-clip-card__count {
	color: var(--text-muted);
	font-size: 14px;
}

/* note: Clips inline link style */
.resources-clips-inline {
	margin-bottom: 8px;
}

.resources-clip-link {
	display: flex;
	align-items: center;
	gap: 16px;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 12px;
	padding: 16px 20px;
	text-decoration: none;
	transition: all 0.2s ease;
}

.resources-clip-link:hover {
	border-color: var(--primary);
	background: rgba(58, 134, 255, 0.05);
}

.resources-clip-link__icon {
	width: 48px;
	height: 48px;
	background: var(--primary);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.resources-clip-link__icon svg {
	width: 24px;
	height: 24px;
	color: #fff;
	margin-left: 2px;
}

.resources-clip-link__text {
	flex: 1;
}

.resources-clip-link__title {
	display: block;
	color: var(--text-primary);
	font-size: 16px;
	font-weight: 600;
	margin-bottom: 2px;
}

.resources-clip-link__desc {
	display: block;
	color: var(--text-muted);
	font-size: 14px;
}

.resources-clip-link__arrow {
	color: var(--text-muted);
	transition: transform 0.2s ease;
}

.resources-clip-link:hover .resources-clip-link__arrow {
	transform: translateX(4px);
	color: var(--primary);
}

.resources-clip-link__arrow svg {
	width: 20px;
	height: 20px;
}

@media (max-width: 768px) {
	.resources-episodes-grid {
		grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
		gap: 12px;
	}

	.resources-episode__play svg {
		width: 36px;
		height: 36px;
	}

	.resources-episode__title {
		font-size: 13px;
	}

	.resources-clip-link {
		padding: 12px 16px;
		gap: 12px;
	}

	.resources-clip-link__icon {
		width: 40px;
		height: 40px;
	}

	.resources-clip-link__icon svg {
		width: 20px;
		height: 20px;
	}

	.resources-clip-link__title {
		font-size: 14px;
	}

	.resources-clip-link__desc {
		font-size: 13px;
	}
}

.resources-help {
	background: var(--bg-card);
	border-radius: 16px;
	padding: 32px;
	margin-top: 48px;
}

.resources-help .chosen-section__title {
	margin-bottom: 8px;
}

.resources-help > p {
	color: var(--text-muted);
	margin-bottom: 24px;
}

.resources-suggestions {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}

.resources-suggestion {
	background: var(--bg-dark);
	border-radius: 12px;
	padding: 20px;
}

.resources-suggestion h3 {
	color: var(--text-primary);
	font-size: 16px;
	font-weight: 600;
	margin: 0 0 8px;
}

.resources-suggestion p {
	color: var(--text-muted);
	font-size: 14px;
	margin: 0 0 16px;
	line-height: 1.5;
}

.resources-suggestion a {
	color: var(--primary);
	font-size: 14px;
	font-weight: 500;
	text-decoration: none;
}

.resources-suggestion a:hover {
	text-decoration: underline;
}

@media (max-width: 1024px) {
	.resources-actions {
		grid-template-columns: repeat(2, 1fr);
	}

	.resources-suggestions {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 640px) {
	.resources-actions {
		grid-template-columns: 1fr;
	}

	.resources-filter-bar {
		position: -webkit-sticky;
		position: sticky;
		top: 64px;
		padding: 12px 0;
		margin: 24px 0 0;
		z-index: 100;
		background: var(--bg-dark);
		box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
	}

	.resources-filter-bar__header {
		margin-bottom: 8px;
		transition: max-height 0.2s ease, opacity 0.2s ease, margin 0.2s ease;
		max-height: 80px;
		opacity: 1;
		overflow: hidden;
	}

	/* note: collapse title/subtitle when stuck to reclaim vertical space */
	.resources-filter-bar.stuck .resources-filter-bar__header {
		max-height: 0;
		opacity: 0;
		margin-bottom: 0;
	}

	.resources-filter-bar__title {
		font-size: 18px;
	}

	.resources-filter-bar__subtitle {
		font-size: 13px;
		margin-top: 4px;
	}

	/* note: hide desktop filters on mobile, show in drawer instead */
	.resources-filters--desktop {
		display: none;
	}

	/* note: mobile filter toggle button */
	.resources-filter-toggle {
		display: flex;
		align-items: center;
		gap: 8px;
		background: var(--bg-card);
		border: 1px solid var(--border);
		border-radius: 8px;
		padding: 10px 16px;
		color: var(--text-primary);
		font-size: 14px;
		font-weight: 500;
		cursor: pointer;
		width: 100%;
		margin-bottom: 8px;
	}

	.resources-filter-toggle svg {
		width: 18px;
		height: 18px;
		flex-shrink: 0;
	}

	.resources-filter-toggle__count {
		background: var(--primary);
		color: #fff;
		font-size: 12px;
		font-weight: 600;
		padding: 2px 7px;
		border-radius: 10px;
		margin-left: auto;
	}

	.resources-filter-toggle__count:empty {
		display: none;
	}

	/* note: mobile filter drawer - slides up from bottom */
	.resources-filter-drawer {
		position: fixed;
		bottom: 0;
		left: 0;
		right: 0;
		background: var(--bg-header);
		border-top-left-radius: 16px;
		border-top-right-radius: 16px;
		z-index: 1001;
		transform: translateY(100%);
		transition: transform 0.3s ease;
		max-height: 85vh;
		display: flex;
		flex-direction: column;
	}

	.resources-filter-drawer.open {
		transform: translateY(0);
	}

	.resources-filter-drawer__header {
		display: flex;
		align-items: center;
		justify-content: space-between;
		padding: 16px 20px;
		border-bottom: 1px solid var(--border);
		flex-shrink: 0;
	}

	.resources-filter-drawer__header h4 {
		font-size: 18px;
		font-weight: 600;
		color: var(--text-primary);
		margin: 0;
	}

	.resources-filter-drawer__close {
		background: none;
		border: none;
		padding: 8px;
		cursor: pointer;
		color: var(--text-secondary);
		border-radius: 8px;
	}

	.resources-filter-drawer__close:hover {
		background: var(--bg-card);
	}

	.resources-filter-drawer__close svg {
		width: 20px;
		height: 20px;
	}

	.resources-filter-drawer__content {
		padding: 16px 20px;
		overflow-y: auto;
		flex: 1;
	}

	.resources-filter-drawer__content .resources-filters {
		display: flex;
		flex-direction: column;
		gap: 16px;
	}

	.resources-filter-drawer__content .resources-filter {
		width: 100%;
	}

	.resources-filter-drawer__content .resources-filter label {
		display: block;
		font-size: 13px;
		font-weight: 500;
		color: var(--text-secondary);
		margin-bottom: 6px;
	}

	.resources-filter-drawer__content .resources-filter select,
	.resources-filter-drawer__content .resources-filter input {
		width: 100%;
		padding: 12px 14px;
		font-size: 15px;
	}

	.resources-filter-drawer__footer {
		display: flex;
		gap: 12px;
		padding: 16px 20px;
		border-top: 1px solid var(--border);
		flex-shrink: 0;
	}

	.resources-filter-drawer__clear {
		flex: 1;
		background: var(--bg-card);
		border: 1px solid var(--border);
		border-radius: 8px;
		padding: 12px 16px;
		color: var(--text-primary);
		font-size: 14px;
		font-weight: 500;
		cursor: pointer;
	}

	.resources-filter-drawer__apply {
		flex: 2;
		background: var(--primary);
		border: none;
		border-radius: 8px;
		padding: 12px 16px;
		color: #fff;
		font-size: 14px;
		font-weight: 600;
		cursor: pointer;
	}

	/* note: drawer overlay/backdrop */
	.resources-filter-drawer__overlay {
		position: fixed;
		inset: 0;
		background: rgba(0, 0, 0, 0.5);
		z-index: 1000;
		opacity: 0;
		visibility: hidden;
		transition: opacity 0.3s ease, visibility 0.3s ease;
	}

	.resources-filter-drawer__overlay.open {
		opacity: 1;
		visibility: visible;
	}

	/* note: season headers sticky on mobile - below filter bar */
	.resources-season__sidebar {
		position: -webkit-sticky;
		position: sticky;
		top: var(--filter-bar-offset);
		padding: 12px 0;
		margin: 0;
		width: 100%;
	}

	.resources-help {
		padding: 24px 16px;
	}
}

/* note: landscape short screens — hide filter bar on scroll-down using top offset, not transform (transform breaks sticky) */
@media (orientation: landscape) and (max-height: 500px) {
	.resources-filter-bar {
		transition: top 0.25s ease, opacity 0.25s ease;
	}
	.resources-filter-bar.scroll-down {
		top: -200px;
		opacity: 0;
		pointer-events: none;
	}
}

@media (max-width: 768px) {
	.chosen-hero--compact {
		min-height: 220px;
		padding: 30px 20px 40px;
	}

	.chosen-hero--compact .chosen-hero__title {
		font-size: 28px;
	}

	.chosen-howto {
		grid-template-columns: 1fr;
		gap: 24px;
	}
}

@media (max-width: 1024px) {
	.chosen-seasons {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 768px) {
	.chosen-hero {
		min-height: 400px;
		padding: 60px 20px;
	}

	.chosen-hero__title {
		font-size: 32px;
	}

	.chosen-hero__subtitle {
		font-size: 16px;
	}

	.chosen-formats {
		grid-template-columns: 1fr;
	}

	.chosen-formats--grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.chosen-seasons {
		grid-template-columns: repeat(2, 1fr);
	}

	.chosen-resources {
		grid-template-columns: 1fr;
	}

	.chosen-section__title {
		font-size: 24px;
	}
}

/* footer */
.footer {
	background: var(--bg-header);
	border-top: 1px solid var(--border);
	padding: 48px 24px 24px;
	margin-top: 48px;
}

.footer__content {
	max-width: 1400px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	gap: 48px;
	justify-content: space-between;
}

.footer__brand {
	flex: 1;
	min-width: 200px;
	max-width: 300px;
}

.footer__logo {
	font-size: 24px;
	font-weight: 700;
	color: var(--primary);
	margin-bottom: 12px;
}

.footer__logo span {
	color: var(--highlight);
}

.footer__tagline {
	font-size: 14px;
	color: var(--text-secondary);
	line-height: 1.6;
}

.footer__apps {
	flex: 1;
	min-width: 200px;
}

.footer__apps-title {
	font-size: 14px;
	font-weight: 600;
	margin-bottom: 16px;
	color: var(--text-primary);
}

.footer__app-links {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	gap: 12px;
}

.footer__app-link {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 8px;
	padding: 10px 16px;
	color: var(--text-primary);
	font-size: 14px;
	font-weight: 500;
	transition: background 0.2s, border-color 0.2s;
	width: fit-content;
}

.footer__app-link:hover {
	background: var(--bg-card-hover);
	border-color: var(--primary);
}

.footer__app-link svg {
	flex-shrink: 0;
}

.footer__app-link-text {
	display: flex;
	flex-direction: column;
	line-height: 1.2;
}

.footer__app-link-text small {
	font-size: 10px;
	color: var(--text-secondary);
	font-weight: 400;
}

.footer__bottom {
	max-width: 1400px;
	margin: 32px auto 0;
	padding-top: 24px;
	border-top: 1px solid var(--border);
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 16px;
}

.footer__copyright {
	font-size: 12px;
	color: var(--text-muted);
}

.footer__links {
	display: flex;
	gap: 24px;
}

.footer__links a {
	font-size: 12px;
	color: var(--text-secondary);
	transition: color 0.2s;
}

.footer__links a:hover {
	color: var(--primary);
}

@media (max-width: 600px) {
	.footer {
		padding: 32px 16px 100px;
	}
	.footer__content {
		flex-direction: column;
		gap: 32px;
	}
	.footer__brand {
		max-width: none;
	}
	.footer__bottom {
		flex-direction: column;
		text-align: center;
	}
}



/* app banner */
.app-banner {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
	padding: 12px 16px;
	z-index: 99;
	border-top: 1px solid var(--border);
	display: none;
}

.app-banner.show {
	display: block;
}

.app-banner__content {
	display: flex;
	align-items: center;
	gap: 12px;
	max-width: 1200px;
	margin: 0 auto;
}

.app-banner__icon {
	width: 40px;
	height: 40px;
	background: var(--primary);
	border-radius: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.app-banner__icon svg {
	color: var(--bg-dark);
}

.app-banner__text {
	flex: 1;
	min-width: 0;
}

.app-banner__text strong {
	display: block;
	color: var(--text-primary);
	font-size: 14px;
}

.app-banner__text span {
	font-size: 12px;
	color: var(--text-secondary);
}

.app-banner__button {
	background: var(--primary);
	color: var(--bg-dark);
	padding: 8px 16px;
	border-radius: 6px;
	font-size: 13px;
	font-weight: 600;
	white-space: nowrap;
	transition: background 0.2s;
}

.app-banner__button:hover {
	background: var(--primary-dark);
}

.app-banner__close {
	background: none;
	border: none;
	color: var(--text-muted);
	cursor: pointer;
	padding: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: color 0.2s;
}

.app-banner__close:hover {
	color: var(--text-primary);
}

@media (max-width: 600px) {
	.app-banner {
		bottom: 60px;
	}
	.app-banner__text span {
		display: none;
	}
}
</style><style>:root{--snt-header-h:0px}</style><script src="/static/hls.min.js"></script><script src="https://js.churchcenter.com/modal/v1"></script></head><body><main class="main"><style>

/* note: banner hero */
.mw__banner {
	position: relative;
	width: 100%;
	min-height: 340px;
	display: flex;
	align-items: flex-end;
	overflow: hidden;
}
.mw__banner-bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
}
/* note: default darkening only applied to studios that have NOT configured a
   welcome_center row in D1. Studios with a row control their own banner
   darkening via banner_dim (which renders as a separate overlay layer); we
   stay out of the way for them. Without a row we fall back to a mild
   brightness() so banner text stays readable over arbitrary photos. */
.mw__banner-bg--default-dim {
	filter: brightness(0.75);
}
/* note: dim overlay layer — only emitted when banner_dim > 0. Sits on
 * top of the bg image but BELOW .mw__banner-content so the title /
 * tagline / logo stay sharp and bright over the darkened image.
 */
.mw__banner-dim {
	position: absolute;
	inset: 0;
	background: #000;
	pointer-events: none;
}
.mw__banner-content {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 48px 32px 40px;
	display: flex;
	align-items: flex-end;
	gap: 24px;
}
.mw__banner-logo {
	width: 96px;
	height: 96px;
	border-radius: 16px;
	overflow: hidden;
	flex-shrink: 0;
	border: 3px solid rgba(255,255,255,0.2);
	background: var(--bg-card);
}
.mw__banner-logo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.mw__banner-logo-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 40px;
	font-weight: 700;
	color: var(--primary);
	background: var(--bg-card);
}
.mw__banner-info {
	flex: 1;
}
.mw__banner-name {
	font-size: 32px;
	font-weight: 700;
	color: #fff;
	margin: 0 0 6px;
	text-shadow: 0 2px 8px rgba(0,0,0,0.4);
}
.mw__banner-tagline {
	font-size: 16px;
	color: rgba(255,255,255,0.85);
	margin: 0;
	text-shadow: 0 1px 4px rgba(0,0,0,0.3);
}

/* note: section navigation tabs.
   --snt-header-h is the global sermon.tv header height. Apex defaults to 64px;
   white-label subdomains override to 0 in layout()'s injected <style>. */
.mw__nav {
	position: sticky;
	top: var(--snt-header-h, 64px);
	z-index: 20;
	background: rgba(30, 30, 47, 0.85);
	border-bottom: 1px solid var(--border);
	transition: background 0.3s, box-shadow 0.3s, backdrop-filter 0.3s;
}
.mw__nav--stuck {
	background: rgba(30, 30, 47, 0.97);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.4);
	border-bottom-color: rgba(58, 58, 79, 0.6);
}
.mw__nav,
.mw__nav-scroll {
	overflow: visible;
}
/* note: auth widget + More button never shrink — they must always fit. The
   inline links are flexible (the JS recompute pass shrinks the inline list
   by moving items into the More dropdown until everything fits). */
.mw__nav-auth, .mw__nav-auth-signin, .mw__nav-more { flex-shrink: 0; }
.mw__nav-link { flex-shrink: 0; }
.mw__nav-scroll {
	max-width: 1200px;
	width: 100%;
	margin: 0 auto;
	padding: 0 32px;
	display: flex;
	align-items: center;
	gap: 0;
	overflow: visible;
	box-sizing: border-box;
	min-width: 0;
}
.mw__nav-logo {
	display: block;
	width: 28px;
	height: 28px;
	border-radius: 6px;
	overflow: hidden;
	flex-shrink: 0;
	margin-right: 16px;
	opacity: 0;
	transform: scale(0.8);
	transition: opacity 0.3s, transform 0.3s;
	pointer-events: none;
	cursor: pointer;
	text-decoration: none;
}
.mw__nav--stuck .mw__nav-logo {
	opacity: 1;
	transform: scale(1);
	pointer-events: auto;
}
.mw__nav-logo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.mw__nav-link {
	padding: 14px 20px;
	color: var(--text-muted);
	text-decoration: none;
	font-size: 14px;
	font-weight: 500;
	white-space: nowrap;
	border-bottom: 2px solid transparent;
	transition: color 0.2s, border-color 0.2s;
}
.mw__nav-link:hover {
	color: var(--text-primary);
}
.mw__nav-link--active {
	color: var(--primary);
	border-bottom-color: var(--primary);
}

/* note: more dropdown */
.mw__nav-more {
	position: relative;
	display: flex;
	align-items: stretch;
}
.mw__nav-more-btn {
	display: flex;
	align-items: center;
	background: none;
	border: none;
	border-bottom: 2px solid transparent;
	cursor: pointer;
	font-family: inherit;
	font-size: 14px;
	font-weight: 500;
	color: var(--text-muted);
	padding: 14px 20px;
	margin: 0;
	white-space: nowrap;
	line-height: 1;
	transition: color 0.2s, border-color 0.2s;
}
.mw__nav-more-btn:hover {
	color: var(--text-primary);
}
.mw__nav-more--open .mw__nav-more-btn {
	color: var(--primary);
}
.mw__nav-dropdown {
	display: none;
	position: absolute;
	top: 100%;
	right: 0;
	min-width: 180px;
	max-width: calc(100vw - 32px);
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 8px;
	box-shadow: 0 8px 24px rgba(0,0,0,0.4);
	padding: 6px 0;
	z-index: 30;
}
.mw__nav-more--open .mw__nav-dropdown {
	display: block;
}
.mw__nav-dropdown .mw__nav-link {
	display: block;
	padding: 10px 20px;
	border-bottom: none;
	white-space: nowrap;
}
.mw__nav-dropdown .mw__nav-link:hover {
	background: rgba(255,255,255,0.05);
}
.mw__nav-dropdown .mw__nav-link--active {
	color: var(--primary);
	border-bottom: none;
}

/* note: white-label auth widget — Sign In button OR avatar+dropdown for the
   logged-in user. Lives at the right end of .mw__nav, pushed there with
   margin-left:auto. Mirrors the apex header__user dropdown visually but
   scoped to .mw__ so it doesn't fight site chrome. */
.mw__nav-auth {
	margin-left: auto;
	position: relative;
}
.mw__nav-auth-btn {
	background: none;
	border: none;
	padding: 8px;
	cursor: pointer;
}
.mw__nav-auth-avatar {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	overflow: hidden;
	background: var(--primary);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 13px;
	font-weight: 600;
}
.mw__nav-auth-avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.mw__nav-auth-dropdown {
	display: none;
	position: absolute;
	top: 100%;
	right: 0;
	min-width: 220px;
	max-width: calc(100vw - 32px);
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 8px;
	box-shadow: 0 8px 24px rgba(0,0,0,0.4);
	padding: 8px 0;
	z-index: 30;
}
.mw__nav-auth.open .mw__nav-auth-dropdown {
	display: block;
}
.mw__nav-auth-info {
	padding: 8px 16px 12px;
}
.mw__nav-auth-name {
	font-weight: 600;
	color: var(--text-primary);
	font-size: 14px;
}
.mw__nav-auth-email {
	font-size: 12px;
	color: var(--text-muted);
	margin-top: 2px;
}
.mw__nav-auth-divider {
	height: 1px;
	background: var(--border);
	margin: 4px 0;
}
.mw__nav-auth-item {
	display: block;
	padding: 10px 16px;
	color: var(--text-primary);
	text-decoration: none;
	font-size: 13px;
}
.mw__nav-auth-item:hover {
	background: rgba(255,255,255,0.05);
}
.mw__nav-auth-item--logout {
	color: var(--text-muted);
}
.mw__nav-auth-signin {
	margin-left: auto;
	padding: 8px 16px;
	background: var(--primary);
	color: #fff;
	border-radius: 6px;
	font-size: 13px;
	font-weight: 600;
	text-decoration: none;
	white-space: nowrap;
	transition: background 0.15s;
}
.mw__nav-auth-signin:hover {
	background: var(--primary-dark, var(--primary));
	filter: brightness(1.1);
}

/* note: generic section wrapper */
.mw__section {
	max-width: 1200px;
	margin: 0 auto;
	padding: 48px 32px;
	scroll-margin-top: calc(var(--snt-header-h, 64px) + 52px);
	border-top: 1px solid var(--border);
}
.mw__section:first-child,
.mw__media-center + .mw__section {
	border-top: none;
}
.mw__section-title {
	font-size: 21px;
	font-weight: 600;
	color: var(--text-primary);
	margin: 0 0 20px;
}
/* note: row wrapper around the section title + a trailing action button */
/* (e.g. the "View Calendar" button in the events section). */
.mw__section-title-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 20px;
}
.mw__section-title-row .mw__section-title { margin: 0; }
.mw__cal-view-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 14px;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 8px;
	color: var(--text-primary);
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
}
.mw__cal-view-btn:hover { border-color: var(--primary); color: var(--primary); }

/* note: repeatable Content section — image + text two-column rows. */
.mw__content-row {
	display: grid;
	grid-template-columns: minmax(240px, 420px) 1fr;
	gap: 32px;
	align-items: center;
	margin-bottom: 32px;
}
.mw__content-row--reverse { grid-template-columns: 1fr minmax(240px, 420px); }
.mw__content-row--reverse .mw__content-image { order: 2; }
.mw__content-row--reverse .mw__content-text { order: 1; }
.mw__content-row--valign-top { align-items: start; }
.mw__content-row--valign-bottom { align-items: end; }
.mw__content-image img {
	width: 100%;
	height: auto;
	border-radius: 10px;
	display: block;
}
.mw__content-item-title {
	font-size: 18px;
	font-weight: 600;
	color: var(--text-primary);
	margin: 0 0 8px;
}
.mw__content-body {
	font-size: 15px;
	line-height: 1.7;
	color: var(--text-secondary);
}
@media (max-width: 720px) {
	.mw__content-row, .mw__content-row--reverse {
		grid-template-columns: 1fr;
	}
	.mw__content-row--reverse .mw__content-image,
	.mw__content-row--reverse .mw__content-text { order: initial; }
}

/* note: two-column block (col1 + col2, each with optional image + text) */
.mw__content-two-col {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 32px;
	align-items: start;
	margin-bottom: 32px;
}
.mw__content-two-col .mw__content-item-title {
	grid-column: 1 / -1;
}
.mw__content-col .mw__content-image {
	margin-bottom: 12px;
}
.mw__content-col .mw__content-image img {
	width: 100%;
	height: auto;
	border-radius: 10px;
	display: block;
}
@media (max-width: 720px) {
	.mw__content-two-col { grid-template-columns: 1fr; }
}

/* note: image-only and text-only blocks */
.mw__content-image-block {
	margin-bottom: 32px;
}
.mw__content-image-block img {
	width: 100%;
	height: auto;
	border-radius: 10px;
	display: block;
}
.mw__content-text-block {
	margin-bottom: 32px;
}

/* note: event cards are clickable — cursor + subtle lift */
.mw__event-card { cursor: pointer; transition: transform 0.15s, border-color 0.15s; }
.mw__event-card:hover { transform: translateY(-1px); border-color: var(--primary); }
.mw__event-card:focus-visible { outline: 2px solid var(--primary); outline-offset: 2px; }

/* note: shared modal (event details + month view) */
.mw__modal {
	position: fixed;
	inset: 0;
	z-index: 100;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px;
}
.mw__modal[hidden] { display: none; }
.mw__modal-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0,0,0,0.7);
	backdrop-filter: blur(4px);
}
.mw__modal-card {
	position: relative;
	background: var(--bg-card, #1a1a1a);
	border: 1px solid var(--border);
	border-radius: 14px;
	padding: 32px;
	max-width: 560px;
	width: 100%;
	max-height: 90vh;
	overflow-y: auto;
	z-index: 1;
}
.mw__modal-card--wide { max-width: 960px; }
.mw__modal-close {
	position: absolute;
	top: 12px;
	right: 12px;
	background: transparent;
	border: none;
	color: var(--text-muted);
	font-size: 28px;
	line-height: 1;
	cursor: pointer;
	padding: 4px 10px;
}
.mw__modal-close:hover { color: var(--text-primary); }
.mw__modal-title {
	font-size: 22px;
	font-weight: 600;
	color: var(--text-primary);
	margin: 0 0 8px;
}
.mw__modal-meta {
	font-size: 13px;
	color: var(--text-muted);
	margin-bottom: 16px;
}
.mw__modal-desc {
	font-size: 15px;
	line-height: 1.7;
	color: var(--text-secondary);
	white-space: pre-line;
}
body.mw__modal-open { overflow: hidden; }

/* note: month-view modal grid */
.mw__month-nav {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 16px;
	padding-right: 40px;
}
.mw__month-title {
	font-size: 18px;
	font-weight: 600;
	color: var(--text-primary);
	margin: 0;
}
.mw__month-nav-btn {
	background: transparent;
	border: 1px solid var(--border);
	border-radius: 8px;
	color: var(--text-primary);
	font-size: 20px;
	width: 36px;
	height: 36px;
	cursor: pointer;
}
.mw__month-nav-btn:hover { border-color: var(--primary); color: var(--primary); }
.mw__month-grid {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	gap: 2px;
	background: var(--border);
	border: 1px solid var(--border);
	border-radius: 8px;
	overflow: hidden;
}
.mw__month-dow {
	background: var(--bg-card, #1a1a1a);
	padding: 8px 6px;
	font-size: 11px;
	font-weight: 600;
	color: var(--text-muted);
	text-transform: uppercase;
	text-align: center;
}
.mw__month-cell {
	background: var(--bg-card, #1a1a1a);
	min-height: 72px;
	padding: 6px;
	font-size: 12px;
}
.mw__month-cell--empty { background: transparent; }
/* note: subtle "has events" tint — was hardcoded to Sermon.tv brand blue
   which clashed for any studio using a different standalone_accent_color
   in Artwork & Appearance. Use color-mix off --primary so the tint follows
   the configured accent on standalone (white-label) pages while staying
   visible on the Sermon.tv network appearance. */
.mw__month-cell--has-events { background: color-mix(in srgb, var(--primary) 8%, transparent); }
.mw__month-num {
	font-weight: 600;
	color: var(--text-primary);
	margin-bottom: 4px;
}
.mw__month-event {
	background: var(--primary);
	color: #000;
	font-size: 11px;
	font-weight: 600;
	padding: 2px 6px;
	border-radius: 4px;
	margin-bottom: 2px;
	cursor: pointer;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
@media (max-width: 600px) {
	.mw__month-cell { min-height: 48px; font-size: 11px; }
	.mw__modal-card { padding: 20px 16px; }
}

/* note: about section */
.mw__about-short {
	font-size: 16px;
	line-height: 1.7;
	color: var(--text-secondary);
	margin: 0 0 12px;
}
.mw__about-long {
	font-size: 15px;
	line-height: 1.7;
	color: var(--text-muted);
	white-space: pre-line;
	margin: 0;
}
.mw__about-toggle {
	display: inline-block;
	margin-top: 8px;
	color: var(--primary);
	cursor: pointer;
	font-size: 14px;
	font-weight: 500;
	border: none;
	background: none;
	padding: 0;
}
.mw__about-toggle:hover {
	text-decoration: underline;
}

/* note: media center wrapper */
.mw__media-center {
	max-width: 1200px;
	margin: 0 auto;
	padding: 48px 32px;
	scroll-margin-top: calc(var(--snt-header-h, 64px) + 52px);
	border-top: 1px solid var(--border);
}
.mw__media-center:first-child {
	border-top: none;
}

/* note: service times */
.mw__times-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 16px;
}
.mw__time-card {
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 10px;
	padding: 20px;
	display: flex;
	gap: 16px;
	align-items: flex-start;
	transition: border-color 0.2s;
}
.mw__time-card:hover {
	border-color: var(--primary);
}
.mw__time-icon {
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(58,134,255,0.1);
	border-radius: 10px;
	flex-shrink: 0;
}
.mw__time-icon svg {
	width: 20px;
	height: 20px;
	color: var(--primary);
}
.mw__time-details {
	flex: 1;
}
.mw__time-day {
	font-size: 13px;
	font-weight: 600;
	color: var(--primary);
	text-transform: uppercase;
	letter-spacing: 0.5px;
	margin: 0 0 4px;
}
.mw__time-value {
	font-size: 18px;
	font-weight: 600;
	color: var(--text-primary);
	margin: 0 0 2px;
}
.mw__time-label {
	font-size: 14px;
	color: var(--text-muted);
	margin: 0;
}

/* note: external media — responsive iframe wrappers */
.mw__embeds-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 24px;
}
.mw__embed-item {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.mw__embed-item--full { grid-column: 1 / -1; }
.mw__embed-title {
	font-size: 15px;
	font-weight: 500;
	color: var(--text-primary);
	margin: 0;
}
.mw__embed-wrap {
	position: relative;
	width: 100%;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
	border-radius: 8px;
	background: var(--bg-card);
}
.mw__embed-wrap iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: 0;
}
/* note: custom embeds self-size via iframe-resizer; don't force aspect ratio */
.mw__embed-custom {
	width: 100%;
	border-radius: 8px;
	overflow: hidden;
}
.mw__embed-custom iframe {
	width: 100%;
	border: 0;
	display: block;
}

/* note: unified contact & location section — left column stacks info boxes */
/* (email, phone, address) as aligned cards with consistent spacing; right */
/* column is the auto-embedded map. Columns stack on narrow viewports. */
.mw__cl-grid {
	display: grid;
	grid-template-columns: minmax(260px, 1fr) 1fr;
	gap: 28px;
	align-items: start;
}
.mw__cl-info {
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.mw__cl-item {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	padding: 16px 20px;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 10px;
	text-decoration: none;
	color: var(--text-primary);
	font-size: 15px;
	line-height: 1.5;
	transition: border-color 0.2s;
}
.mw__cl-item:hover { border-color: var(--primary); }
.mw__cl-item svg {
	flex-shrink: 0;
	color: var(--primary);
	margin-top: 2px;
}
.mw__cl-item--address {
	/* note: address can wrap multiple lines — stays flush with other items */
	cursor: default;
}
.mw__cl-item--address:hover { border-color: var(--border); }
.mw__cl-directions {
	font-size: 14px;
	color: var(--text-muted);
	line-height: 1.6;
	margin: 4px 4px 0;
	white-space: pre-line;
}
.mw__cl-message {
	font-size: 15px;
	color: var(--text-muted);
	line-height: 1.6;
	margin: 0 0 20px;
	white-space: pre-line;
}
.mw__cl-map {
	position: relative;
	width: 100%;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
	border-radius: 10px;
	border: 1px solid var(--border);
}
.mw__cl-map iframe {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
}
@media (max-width: 720px) {
	.mw__cl-grid { grid-template-columns: 1fr; }
}

/* note: giving section */
.mw__giving {
	background: linear-gradient(135deg, rgba(58,134,255,0.06) 0%, rgba(58,134,255,0.02) 100%);
	border: 1px solid rgba(58,134,255,0.2);
	border-left: 3px solid var(--primary);
	border-radius: 12px;
	padding: 40px;
	text-align: center;
}
.mw__giving-title {
	font-size: 21px;
	font-weight: 600;
	color: var(--text-primary);
	margin: 0 0 12px;
}
.mw__giving-message {
	font-size: 15px;
	color: var(--text-muted);
	line-height: 1.6;
	margin: 0 0 24px;
	max-width: 560px;
	margin-left: auto;
	margin-right: auto;
}
.mw__giving-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 14px 32px;
	background: var(--primary);
	color: #fff;
	border: none;
	border-radius: 8px;
	font-size: 15px;
	font-weight: 600;
	text-decoration: none;
	cursor: pointer;
	transition: background 0.2s, transform 0.2s;
}
.mw__giving-btn:hover {
	background: var(--primary-dark);
	transform: translateY(-1px);
}

/* Guest / Visitor Card — public render is now an Online-Giving-style CTA
   card with a button that opens a modal containing the actual form. Form
   is grouped into 4 steps (basics → contact → connection → submit) with
   Next / Back / Submit navigation. CSS below covers BOTH the CTA card on
   the page AND the in-modal form. Mobile-first; modal fills viewport on
   small screens. */
.mw__guest_visitor { }

/* CTA card — what visitors see on the page (form is hidden until they
   click). Mirrors the Online Giving card style: heading + message + button.
   Uses var(--bg-card) so it picks up the studio's Section Background. */
.mw__gv-cta {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
	padding: 24px 20px;
	background: var(--bg-card, #ffffff);
	border: 1px solid #e2e8f0;
	border-radius: 12px;
	text-align: center;
	box-shadow: 0 1px 2px rgba(10, 15, 30, 0.04);
}
.mw__gv-cta-title {
	margin: 0;
}
.mw__gv-cta-message {
	margin: 0;
	color: var(--text-secondary);
	max-width: 520px;
	line-height: 1.55;
}
.mw__gv-cta-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	margin-top: 6px;
	padding: 12px 22px;
	background: var(--primary, #2563eb);
	color: #fff;
	border: none;
	border-radius: 999px;
	font-size: 16px;
	font-weight: 600;
	font-family: inherit;
	cursor: pointer;
	transition: opacity 0.12s ease, transform 0.12s ease;
}
.mw__gv-cta-btn:hover { opacity: 0.92; }
.mw__gv-cta-btn:active { transform: translateY(1px); }

/* Modal — fixed overlay + centered panel. Mobile: panel fills the viewport
   for max usable space. The contenteditable form lives inside. */
.mw__gv-modal {
	position: fixed;
	inset: 0;
	z-index: 1000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 16px;
}
.mw__gv-modal[hidden] { display: none; }
.mw__gv-modal-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(10, 15, 30, 0.55);
	backdrop-filter: blur(2px);
	-webkit-backdrop-filter: blur(2px);
}
.mw__gv-modal-panel {
	position: relative;
	width: 100%;
	max-width: 560px;
	max-height: calc(100vh - 32px);
	display: flex;
	flex-direction: column;
	background: #fff;
	color: #111827;
	border-radius: 14px;
	box-shadow: 0 24px 60px rgba(10, 15, 30, 0.35);
	overflow: hidden;
}
@media (max-width: 600px) {
	.mw__gv-modal { padding: 0; }
	.mw__gv-modal-panel {
		max-width: 100%;
		max-height: 100vh;
		height: 100vh;
		border-radius: 0;
	}
}
.mw__gv-modal-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 16px 20px;
	border-bottom: 1px solid #e2e8f0;
}
.mw__gv-modal-title {
	margin: 0;
	font-size: 17px;
	font-weight: 700;
	color: #111827;
	line-height: 1.3;
}
.mw__gv-modal-close {
	flex-shrink: 0;
	width: 32px;
	height: 32px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: transparent;
	border: none;
	font-size: 24px;
	line-height: 1;
	color: #64748b;
	cursor: pointer;
	border-radius: 6px;
}
.mw__gv-modal-close:hover { background: #f1f5f9; color: #111827; }
.mw__gv-modal-body {
	padding: 16px 20px 20px;
	overflow-y: auto;
	flex: 1 1 auto;
	min-height: 0;
}

/* Step indicator — small "Step X of 4" muted label above the form. */
.mw__gv-step-indicator {
	margin: 0 0 14px;
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: #64748b;
}

.mw__gv-hp {
	position: absolute !important;
	left: -10000px !important;
	width: 1px !important;
	height: 1px !important;
	overflow: hidden !important;
}
.mw__gv-form {
	display: flex;
	flex-direction: column;
	gap: 20px;
	margin: 0;
}
.mw__gv-step {
	display: flex;
	flex-direction: column;
	gap: 22px;
}
.mw__gv-step[hidden] { display: none; }
.mw__gv-step-heading {
	margin: 0;
	font-size: 18px;
	font-weight: 700;
	color: #111827;
	line-height: 1.3;
}
.mw__gv-step-sub {
	margin: -4px 0 0;
	font-size: 13px;
	color: #64748b;
}
.mw__gv-row {
	display: flex;
	flex-direction: column;
	gap: 14px;
}
@media (min-width: 480px) {
	.mw__gv-row--two {
		flex-direction: row;
	}
	.mw__gv-row--two .mw__gv-field {
		flex: 1 1 0;
		min-width: 0;
	}
}
.mw__gv-field {
	display: flex;
	flex-direction: column;
	/* breathing room between the (now bolder) label and its input */
	gap: 10px;
}
.mw__gv-label {
	font-size: 15px;
	/* match the bolder fieldset legends so simple text/select labels
	   (Email, Mobile phone, Prayer request…) read as titles too */
	font-weight: 700;
	color: #111827;
}
.mw__gv-form input[type="text"],
.mw__gv-form input[type="email"],
.mw__gv-form input[type="tel"],
.mw__gv-form textarea,
.mw__gv-form select {
	width: 100%;
	padding: 10px 12px;
	background: #fff;
	color: #111827;
	border: 1px solid #cbd5e1;
	border-radius: 8px;
	font-size: 15px;
	font-family: inherit;
	line-height: 1.4;
	box-sizing: border-box;
}
.mw__gv-form input:focus,
.mw__gv-form textarea:focus,
.mw__gv-form select:focus {
	outline: none;
	border-color: var(--primary, #2563eb);
	box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.18);
}
.mw__gv-form textarea {
	resize: vertical;
	min-height: 100px;
}
.mw__gv-help {
	margin: -4px 0 0;
	font-size: 13px;
	color: #64748b;
}
.mw__gv-fieldset {
	margin: 0;
	padding: 0;
	border: none;
	display: flex;
	flex-direction: column;
	/* spacing between the bold legend and the option group below it */
	gap: 12px;
}
.mw__gv-legend {
	padding: 0;
	margin: 0;
	font-size: 15px;
	/* bolder legend so it reads as a section heading inside the step */
	font-weight: 700;
	color: #111827;
}
.mw__gv-radios,
.mw__gv-checks {
	display: flex;
	flex-wrap: wrap;
	/* breathing room between radio / check chips so adjacent fieldsets
	   (e.g. "I'm a *" + "Preferred contact *") don't visually merge */
	gap: 12px 18px;
}
.mw__gv-radio,
.mw__gv-check {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 14px;
	color: #475569;
	cursor: pointer;
}
.mw__gv-radio input,
.mw__gv-check input {
	accent-color: var(--primary, #2563eb);
}
.mw__gv-consent {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	margin-top: 4px;
	font-size: 14px;
	color: #475569;
	line-height: 1.5;
	cursor: pointer;
}
.mw__gv-consent input {
	margin-top: 3px;
	accent-color: var(--primary, #2563eb);
}

/* Review-step summary — read-only recap of key fields. */
.mw__gv-summary {
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: 12px 14px;
	background: #f8fafc;
	border: 1px solid #e2e8f0;
	border-radius: 8px;
}
.mw__gv-summary-row {
	display: flex;
	align-items: baseline;
	gap: 12px;
	font-size: 14px;
}
.mw__gv-summary-label {
	flex-shrink: 0;
	min-width: 130px;
	font-weight: 600;
	color: #111827;
}
.mw__gv-summary-value {
	color: #475569;
	word-break: break-word;
}

.mw__gv-error {
	padding: 10px 12px;
	background: #fef2f2;
	border: 1px solid #fecaca;
	color: #991b1b;
	border-radius: 8px;
	font-size: 14px;
}

/* Step nav (Back / Next / Submit). Submit/next are primary; Back is a
   ghost button. On wide modals they justify left/right; on narrow they
   wrap naturally. */
.mw__gv-nav {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	margin-top: 6px;
}
.mw__gv-back,
.mw__gv-next,
.mw__gv-submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 18px;
	border-radius: 999px;
	font-size: 15px;
	font-weight: 600;
	font-family: inherit;
	cursor: pointer;
	transition: opacity 0.12s ease, transform 0.12s ease, background 0.12s ease;
}
.mw__gv-back {
	background: transparent;
	color: #475569;
	border: 1px solid #cbd5e1;
	margin-right: auto;
}
.mw__gv-back:hover { background: #f1f5f9; }
.mw__gv-next,
.mw__gv-submit {
	background: var(--primary, #2563eb);
	color: #fff;
	border: none;
	margin-left: auto;
}
.mw__gv-next:hover,
.mw__gv-submit:hover { opacity: 0.92; }
.mw__gv-next:active,
.mw__gv-submit:active { transform: translateY(1px); }
.mw__gv-submit:disabled { opacity: 0.7; cursor: not-allowed; }
.mw__gv-back[hidden],
.mw__gv-next[hidden],
.mw__gv-submit[hidden] { display: none; }

/* Thank-you panel inside the modal — replaces the form on successful submit. */
.mw__gv-thanks {
	padding: 24px 20px;
	text-align: center;
}
.mw__gv-thanks[hidden] { display: none; }
.mw__gv-thanks-title {
	margin: 0 0 8px;
	font-size: 20px;
	font-weight: 700;
	color: #111827;
}
.mw__gv-thanks-body {
	margin: 0 auto 18px;
	max-width: 420px;
	color: #475569;
	line-height: 1.55;
}
.mw__gv-thanks-done {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 22px;
	background: var(--primary, #2563eb);
	color: #fff;
	border: none;
	border-radius: 999px;
	font-size: 15px;
	font-weight: 600;
	font-family: inherit;
	cursor: pointer;
}
.mw__gv-thanks-done:hover { opacity: 0.92; }

/* Webpage Announcements board (Notifications section_order slot). Stacked
   cards, newest at the top. Each card uses --bg-card so it picks up the
   studio's Section Background Color the same way Event Calendar / Service
   Times cards do. */
.mw__ann-list {
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.mw__ann-card {
	padding: 16px 18px;
	background: var(--bg-card, #ffffff);
	border: 1px solid #e2e8f0;
	border-radius: 12px;
	box-shadow: 0 1px 2px rgba(10, 15, 30, 0.04);
}
.mw__ann-title {
	margin: 0 0 4px;
	font-size: 18px;
	font-weight: 700;
	color: var(--text-primary);
	line-height: 1.3;
}
.mw__ann-date {
	display: block;
	margin: 0 0 8px;
	font-size: 12px;
	color: var(--text-muted);
	text-transform: uppercase;
	letter-spacing: 0.04em;
}
.mw__ann-body {
	font-size: 15px;
	line-height: 1.55;
	color: var(--text-primary);
}
.mw__ann-body p:first-child { margin-top: 0; }
.mw__ann-body p:last-child { margin-bottom: 0; }

/* note: featured links */
.mw__links-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 16px;
}
.mw__link-card {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 18px 20px;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 10px;
	text-decoration: none;
	color: var(--text-primary);
	font-size: 15px;
	font-weight: 500;
	transition: border-color 0.2s, transform 0.2s;
}
.mw__link-card:hover {
	border-color: var(--primary);
	transform: translateY(-2px);
}
.mw__link-icon {
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(58,134,255,0.1);
	border-radius: 10px;
	flex-shrink: 0;
}
.mw__link-icon svg {
	width: 20px;
	height: 20px;
	color: var(--primary);
}

/* note: additional sections */
.mw__additional-item {
	margin-bottom: 24px;
}
.mw__additional-item:last-child {
	margin-bottom: 0;
}
.mw__additional-title {
	font-size: 18px;
	font-weight: 600;
	color: var(--text-primary);
	margin: 0 0 8px;
}
.mw__additional-body {
	font-size: 15px;
	color: var(--text-muted);
	line-height: 1.7;
}

/* note: calendar / events */
.mw__events-list {
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.mw__event-card {
	display: flex;
	gap: 20px;
	padding: 20px;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 10px;
	transition: border-color 0.2s;
}
.mw__event-card:hover {
	border-color: var(--primary);
}
.mw__event-date {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	min-width: 56px;
	padding: 8px 12px;
	background: rgba(58,134,255,0.1);
	border-radius: 8px;
	flex-shrink: 0;
}
.mw__event-month {
	font-size: 12px;
	font-weight: 600;
	color: var(--primary);
	text-transform: uppercase;
	letter-spacing: 0.5px;
}
.mw__event-day {
	font-size: 24px;
	font-weight: 700;
	color: var(--text-primary);
	line-height: 1.1;
}
.mw__event-info {
	flex: 1;
	min-width: 0;
}
.mw__event-title {
	font-size: 16px;
	font-weight: 600;
	color: var(--text-primary);
	margin: 0 0 4px;
}
.mw__event-meta {
	font-size: 13px;
	color: var(--primary);
	margin: 0 0 8px;
}
.mw__event-desc {
	font-size: 14px;
	color: var(--text-muted);
	line-height: 1.5;
	margin: 0;
}

/* note: events empty state */
.mw__events-empty {
	text-align: center;
	padding: 32px 16px;
	color: var(--text-muted);
	font-size: 14px;
}
.mw__events-empty svg {
	display: block;
	margin: 0 auto 12px;
	color: var(--text-muted);
	opacity: 0.5;
}

/* note: ministry footer */
.mw__footer {
	max-width: 1200px;
	margin: 0 auto;
	padding: 32px 32px 48px;
	border-top: 1px solid var(--border);
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
}
.mw__footer-name {
	font-size: 13px;
	color: var(--text-muted);
}
.mw__footer-powered {
	font-size: 12px;
	color: var(--text-muted);
	opacity: 0.6;
}
.mw__footer-powered a {
	color: var(--text-muted);
	text-decoration: none;
}
.mw__footer-powered a:hover {
	color: var(--primary);
}

/* note: responsive */
@media (max-width: 900px) {
	.mw__embeds-grid {
		grid-template-columns: 1fr;
	}
}
@media (max-width: 600px) {
	.mw__banner {
		min-height: 260px;
	}
	.mw__banner-content {
		padding: 32px 20px 28px;
		flex-direction: column;
		align-items: flex-start;
		gap: 16px;
	}
	.mw__banner-logo {
		width: 72px;
		height: 72px;
		border-radius: 12px;
	}
	.mw__banner-name {
		font-size: 24px;
	}
	.mw__banner-tagline {
		font-size: 14px;
	}
	.mw__nav-scroll {
		padding: 0 16px;
	}
	.mw__nav-link {
		padding: 12px 14px;
		font-size: 13px;
	}
	.mw__section {
		padding: 32px 20px;
	}
	.mw__media-center {
		padding: 32px 20px;
	}
	.mw__giving {
		padding: 28px 20px;
	}
	.mw__times-grid {
		grid-template-columns: 1fr;
	}
	.mw__links-grid {
		grid-template-columns: 1fr;
	}
}

/* Controlled text-size + text-color classes from the Web Page Builder
 * rich-text editor (PB2). Saved as <span class="pb2_size_lg"> / <span
 * class="pb2_color_accent"> etc. via the server-side sanitizer allowlist
 * (channel-info.js SAFE_CLASS_RE). Mirror of the same class set in the
 * PB2 builder CSS so saved formatting renders identically across builder
 * preview, View mode, and the published page. Sizes are relative (em)
 * so they compose with heading typography without forcing pixels. */
.pb2_size_sm { font-size: 0.85em; }
.pb2_size_lg { font-size: 1.25em; }
.pb2_size_xl { font-size: 1.5em; }
.pb2_color_dark { color: #111827; }
.pb2_color_muted { color: #6b7280; }
.pb2_color_white { color: #ffffff; }
.pb2_color_primary { color: #2563eb; }
/* Accent resolves via a CSS custom property the public renderer sets from
 * the saved standalone_accent_color (see ministry_webpage.js's accent rule
 * push). The static hex fallback only applies on legacy / pre-config pages
 * where no accent has ever been chosen. */
.pb2_color_accent { color: var(--pb2-accent-color, #f59e0b); }

/* Intentionally-created lists inside saved rich body content. Matches the
   PB2 builder CSS scoping (.pb2_block_body / .pb2_inline_box) so what the
   user sees in the WYSIWYG editor and the builder preview is what they
   get on the published page — same marker style, indent, and spacing.
   Approved size/color spans inside <li> inherit normally. */
.mw__content-body ul {
	list-style: disc outside;
	padding-left: 1.6em;
	margin: 0.5em 0;
}
.mw__content-body ol {
	list-style: decimal outside;
	padding-left: 1.8em;
	margin: 0.5em 0;
}
.mw__content-body li {
	margin: 0.25em 0;
	line-height: 1.5;
}
.mw__content-body ul ul,
.mw__content-body ol ol {
	margin: 0.25em 0;
}

.main:has(.main--mw){max-width:none;padding:0;}</style><div class="main--mw"><div class="mw__banner"><div class="mw__banner-bg" style="background:linear-gradient(135deg, var(--bg-card) 0%, var(--bg-dark) 100%);filter:none;"></div><div class="mw__banner-content"><div class="mw__banner-logo"><div class="mw__banner-logo-placeholder"></div></div><div class="mw__banner-info"><h1 class="mw__banner-name"></h1></div></div></div><!--mw-banner-end--><nav class="mw__nav" id="mw-nav"><div class="mw__nav-scroll"><div class="mw__nav-more" data-mw-more style="display:none"><button class="mw__nav-more-btn" onclick="this.parentElement.classList.toggle('mw__nav-more--open');">More &#9662;</button><div class="mw__nav-dropdown"></div></div><a href="/login" class="mw__nav-auth-signin" data-mw-signin>Sign In</a></div></nav><script>document.addEventListener("DOMContentLoaded",function(){var nav=document.querySelector(".mw__nav");if(!nav)return;var hh=parseInt(getComputedStyle(document.documentElement).getPropertyValue("--snt-header-h"))||0;var sentinel=document.createElement("div");sentinel.style.cssText="height:1px;margin:0;padding:0;pointer-events:none";nav.parentNode.insertBefore(sentinel,nav);var obs=new IntersectionObserver(function(entries){nav.classList.toggle("mw__nav--stuck",!entries[0].isIntersecting);},{threshold:0,rootMargin:(-hh)+"px 0px 0px 0px"});obs.observe(sentinel);var moreDrop=nav.querySelector(".mw__nav-more");if(moreDrop){document.addEventListener("click",function(e){if(!moreDrop.contains(e.target))moreDrop.classList.remove("mw__nav-more--open");});moreDrop.querySelectorAll(".mw__nav-dropdown .mw__nav-link").forEach(function(l){l.addEventListener("click",function(){moreDrop.classList.remove("mw__nav-more--open");});});}var scroll=nav.querySelector(".mw__nav-scroll");var moreContainer=nav.querySelector("[data-mw-more]");var moreDropdown=moreContainer?moreContainer.querySelector(".mw__nav-dropdown"):null;var authWidget=nav.querySelector(".mw__nav-auth, .mw__nav-auth-signin");var inlineLinks=Array.prototype.slice.call(scroll?scroll.querySelectorAll(".mw__nav-link"):[]).filter(function(l){return !moreDropdown||!moreDropdown.contains(l);});var collapsed=[];function recompute(){if(!scroll||!moreContainer||!moreDropdown){console.log("[mw-nav] recompute skipped, missing element",{scroll:!!scroll,moreContainer:!!moreContainer,moreDropdown:!!moreDropdown});return;}while(collapsed.length){var item=collapsed.shift();scroll.insertBefore(item,moreContainer);}moreContainer.style.display="none";var scroll_pad=parseInt(getComputedStyle(scroll).paddingLeft)+parseInt(getComputedStyle(scroll).paddingRight);var avail=Math.min(nav.clientWidth, document.documentElement.clientWidth)-scroll_pad;var auth_w=Math.max(authWidget?authWidget.offsetWidth:0,100);var more_w=70;var budget=avail-auth_w-more_w-8;var used=0;for(var i=0;i<inlineLinks.length;i++){used+=inlineLinks[i].offsetWidth;}if(used<=avail-auth_w-8){moreDropdown.innerHTML="";return;}moreDropdown.innerHTML="";var pulled=[];used=0;for(var j=0;j<inlineLinks.length;j++){used+=inlineLinks[j].offsetWidth;if(used>budget){pulled=inlineLinks.slice(j);break;}}pulled.forEach(function(l){collapsed.push(l);moreDropdown.appendChild(l);});if(collapsed.length>0)moreContainer.style.display="";console.log("[mw-nav] avail=",avail,"auth_w=",auth_w,"budget=",budget,"used=",used,"pulled=",pulled.length);}requestAnimationFrame(recompute);setTimeout(recompute,100);setTimeout(recompute,500);window.addEventListener("load",recompute);window.addEventListener("resize",function(){requestAnimationFrame(recompute);});if(document.fonts&&document.fonts.ready)document.fonts.ready.then(recompute);var links=nav.querySelectorAll(".mw__nav-link");var sections=[];links.forEach(function(l){var id=l.getAttribute("href");if(id&&id.startsWith("#")){var el=document.querySelector(id);if(el)sections.push({el:el,link:l});}});if(sections.length){var spy=new IntersectionObserver(function(entries){entries.forEach(function(e){var match=sections.find(function(s){return s.el===e.target;});if(match)match.visible=e.isIntersecting;});var active=null;for(var i=0;i<sections.length;i++){if(sections[i].visible){active=sections[i];break;}}links.forEach(function(l){l.classList.remove("mw__nav-link--active");});if(active)active.link.classList.add("mw__nav-link--active");},{threshold:0.05,rootMargin:(-(hh+52))+"px 0px -50% 0px"});sections.forEach(function(s){spy.observe(s.el);});}});</script><script>(function(){var menu=document.querySelector("[data-mw-user-menu]");if(menu){menu.addEventListener("click",function(e){menu.classList.toggle("open");e.stopPropagation();});document.addEventListener("click",function(e){if(!menu.contains(e.target))menu.classList.remove("open");});}var hereFull=encodeURIComponent(location.href);var here=encodeURIComponent(location.pathname+location.search+location.hash);var signin=document.querySelector("[data-mw-signin]");if(signin)signin.href="https://sermon.tv/login?return_to="+hereFull;var signout=document.querySelector(".mw__nav-auth-item--logout");if(signout)signout.href="/auth/logout?return_to="+here;})();</script><div class="mw__footer"><span class="mw__footer-name">&copy; 2026 </span><span class="mw__footer-powered">Powered by <a href="https://sermon.tv" target="_blank" rel="noopener">sermon.tv</a></span></div></div></main><script src="https://www.gstatic.com/cv/js/sender/v1/cast_sender.js?loadCastFramework=1"></script><script src="/static/snt.js"></script></body></html>