/* ================================================================
   WDIP — What Does It Profit? Theme Stylesheet
   ================================================================ */

/* ── Custom Properties ────────────────────────────────────────── */
:root {
	--c-teal:    #2d697a;
	--c-red:     #e24f30;
	--c-green:   #40816a;
	--c-gold:    #d3b040;
	--c-dark:    #213C45;
	--c-white:   #ffffff;
	--c-off:     #f5f6f7;
	--c-gray:    #6b7280;
	--c-gray-lt: #d1d5db;
	--c-border:  #e5e7eb;

	--ff:        'Poppins', sans-serif;
	--fs-base:   1rem;
	--lh:        1.7;
	--max-w:     1200px;
	--max-w-sm:  760px;
	--radius:    10px;
	--radius-lg: 16px;
	--shadow:    0 1px 3px rgba(0,0,0,.08), 0 4px 12px rgba(0,0,0,.06);
	--shadow-lg: 0 4px 6px rgba(0,0,0,.06), 0 12px 32px rgba(0,0,0,.10);
	--transition: 0.2s ease;
}

/* ── Reset ────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

body {
	margin: 0;
	font-family: var(--ff);
	font-weight: 400;
	font-size: var(--fs-base);
	line-height: var(--lh);
	color: var(--c-dark);
	background: var(--c-white);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--ff);
	font-weight: 600;
	line-height: 1.25;
	margin: 0 0 .5em;
	color: var(--c-dark);
}

h1 { font-size: clamp(1.75rem, 4vw, 2.75rem); }
h2 { font-size: clamp(1.4rem, 3vw, 2rem); }
h3 { font-size: clamp(1.15rem, 2.5vw, 1.5rem); }

p    { margin: 0 0 1em; }
a    { color: var(--c-teal); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--c-green); }
img  { max-width: 100%; height: auto; display: block; }
ul, ol { padding-left: 1.5em; }

/* Screen reader only. */
.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	width: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	white-space: nowrap;
}

.skip-link {
	position: absolute;
	top: -100%;
	left: 1rem;
	z-index: 9999;
	background: var(--c-dark);
	color: var(--c-white);
	padding: .5rem 1rem;
	border-radius: var(--radius);
}
.skip-link:focus {
	top: 1rem;
}

/* ── Layout ───────────────────────────────────────────────────── */
.container       { max-width: var(--max-w); margin: 0 auto; padding: 0 1.5rem; }
.container--narrow { max-width: var(--max-w-sm); margin: 0 auto; padding: 0 1.5rem; }

.section         { padding: 5rem 0; }
.section--dark   { background: var(--c-dark); color: var(--c-white); }
.section--dark h1,
.section--dark h2,
.section--dark h3 { color: var(--c-white); }
.section--light  { background: var(--c-off); }
.section--accent { background: var(--c-teal); color: var(--c-white); }
.section--accent h2 { color: var(--c-white); }
.section--red    { background: var(--c-red); color: var(--c-white); }
.section--red h2 { color: var(--c-white); }
.section--green  { background: var(--c-green); color: var(--c-white); }
.section--green h2 { color: var(--c-white); }
.section--gold   { background: var(--c-gold); color: var(--c-white); }
.section--gold h2 { color: var(--c-white); }

.section__label {
	display: block;
	font-size: .8rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: var(--c-gold);
	margin-bottom: 1rem;
}

.section-header {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	margin-bottom: 2rem;
	flex-wrap: wrap;
	gap: .5rem;
}

.section-header__link {
	font-size: .9rem;
	font-weight: 500;
	color: var(--c-teal);
}

/* ── Prose ────────────────────────────────────────────────────── */
.prose { max-width: 72ch; }
.prose h2, .prose h3, .prose h4 { margin-top: 1.75em; }
.prose ul, .prose ol { margin-bottom: 1em; }
.prose img { border-radius: var(--radius); margin: 1.5em 0; }
.prose blockquote {
	border-left: 4px solid var(--c-teal);
	margin: 1.5em 0;
	padding: .75em 1.25em;
	color: var(--c-gray);
	font-style: italic;
}
.prose a { text-decoration: underline; text-underline-offset: 2px; }

/* ── Tags / Badges ────────────────────────────────────────────── */
.tag {
	display: inline-block;
	font-size: .75rem;
	font-weight: 600;
	padding: .2em .7em;
	border-radius: 4px;
	letter-spacing: .03em;
	line-height: 1.4;
}
.tag--teal  { background: rgba(45,105,122,.15); color: var(--c-teal); }
.tag--gold  { background: rgba(211,176,64,.15);  color: #a08520; }
.tag--red   { background: rgba(226,79,48,.12);   color: var(--c-red); }
.tag--muted { background: var(--c-off); color: var(--c-gray); }

/* ── Buttons ──────────────────────────────────────────────────── */
.btn {
	display: inline-flex;
	align-items: center;
	gap: .45em;
	padding: .7rem 1.6rem;
	font-family: var(--ff);
	font-size: .9rem;
	font-weight: 600;
	border: 2px solid transparent;
	border-radius: 50px;
	cursor: pointer;
	transition: background var(--transition), color var(--transition), border-color var(--transition), transform .1s;
	text-decoration: none;
	line-height: 1.4;
}
.btn:active { transform: scale(.97); }

.btn--primary {
	background: var(--c-red);
	color: var(--c-white);
	border-color: var(--c-red);
}
.btn--primary:hover {
	background: #c9402a;
	border-color: #c9402a;
	color: var(--c-white);
}

.btn--secondary {
	background: var(--c-teal);
	color: var(--c-white);
	border-color: var(--c-teal);
}
.btn--secondary:hover {
	background: #4da3bc;
	border-color: #4da3bc;
	color: var(--c-white);
}

.btn--outline-dark {
	background: transparent;
	color: var(--c-dark);
	border-color: var(--c-dark);
}
.btn--outline-dark:hover {
	background: var(--c-dark);
	color: var(--c-white);
}

.btn--white {
	background: var(--c-white);
	color: var(--c-dark);
	border-color: var(--c-white);
}
.btn--white:hover {
	background: var(--c-off);
	color: var(--c-dark);
}

.btn--subscribe {
	background: var(--c-red);
	color: var(--c-white);
	border-color: var(--c-red);
	font-size: .8rem;
	padding: .5rem 1.2rem;
}
.btn--subscribe:hover {
	background: #c9402a;
	color: var(--c-white);
}

.btn--muted {
	background: var(--c-off);
	color: var(--c-dark);
	border-color: var(--c-border);
}
.btn--muted:hover {
	background: var(--c-gray-lt);
}

.btn--gold {
	background: var(--c-gold);
	color: var(--c-white);
	border-color: var(--c-gold);
}
.btn--gold:hover {
	background: #bfa030;
	border-color: #bfa030;
	color: var(--c-white);
}

.btn--lg { padding: .85rem 2rem; font-size: 1rem; }

.btn:disabled,
.btn[disabled] {
	opacity: .5;
	cursor: not-allowed;
}

/* ── Header ───────────────────────────────────────────────────── */
.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: var(--c-dark);
	border-bottom: 1px solid rgba(255,255,255,.08);
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 72px;
}

.site-header__brand {
	display: flex;
	align-items: center;
	gap: .75rem;
	flex-shrink: 0;
}

.site-header__logo-link {
	display: inline-flex;
	align-items: center;
}

.site-header__text {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.site-header__title {
	color: var(--c-white);
	font-size: 1.05rem;
	font-weight: 600;
	white-space: nowrap;
	line-height: 1.3;
}
.site-header__title:hover { color: var(--c-gold); }

.site-header__subtitle {
	font-size: .72rem;
	color: rgba(255,255,255,.5);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	line-height: 1.3;
}

.site-header__toggle {
	display: none;
	background: none;
	border: none;
	color: var(--c-white);
	font-size: 1.4rem;
	cursor: pointer;
	padding: .5rem;
	line-height: 1;
}

.site-header__nav {
	display: flex;
	align-items: center;
	gap: .25rem;
}

.site-header__menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	align-items: center;
	gap: .15rem;
}

.site-header__menu li { position: relative; }

.site-header__menu a {
	display: block;
	padding: .45rem .85rem;
	color: rgba(255,255,255,.85);
	font-size: .875rem;
	font-weight: 500;
	border-radius: 6px;
	transition: background var(--transition), color var(--transition);
}
.site-header__menu a:hover,
.site-header__menu .current-menu-item > a,
.site-header__menu .current_page_item > a,
.site-header__menu .current-menu-ancestor > a {
	background: rgba(255,255,255,.1);
	color: var(--c-white);
}

/* Dropdowns. */
.site-header__menu .sub-menu {
	display: none;
	position: absolute;
	top: 100%;
	left: 0;
	min-width: 200px;
	background: var(--c-dark);
	border: 1px solid rgba(255,255,255,.08);
	border-radius: 0 0 var(--radius) var(--radius);
	padding: .4rem 0;
	box-shadow: var(--shadow-lg);
	z-index: 10;
}
.site-header__menu li:hover > .sub-menu { display: block; }
.site-header__menu .sub-menu a {
	padding: .4rem 1.1rem;
	font-size: .82rem;
}

/* ── Hero ─────────────────────────────────────────────────────── */
.hero {
	position: relative;
	background: var(--c-teal);
	color: var(--c-white);
	padding: 5rem 0 6rem;
	overflow: hidden;
}

.hero--has-bg {
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	min-height: 520px;
	display: flex;
	align-items: center;
}

.hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to bottom, rgba(33,60,69,.35) 0%, rgba(33,60,69,.55) 100%);
	pointer-events: none;
}

.hero--has-bg .hero__overlay {
	background: linear-gradient(to bottom, rgba(33,60,69,.2) 0%, rgba(33,60,69,.5) 100%);
}

.hero__inner {
	position: relative;
	z-index: 1;
	max-width: 720px;
	margin: 0 auto;
	text-align: center;
}

.hero__artwork {
	width: 220px;
	height: auto;
	border-radius: var(--radius-lg);
	margin: 0 auto 1.5rem;
	box-shadow: 0 8px 32px rgba(0,0,0,.35);
}

.hero__tagline {
	font-size: clamp(1rem, 2.2vw, 1.3rem);
	color: var(--c-white);
	line-height: 1.65;
	margin-bottom: 1rem;
	font-weight: 600;
	text-shadow: 0 1px 4px rgba(0,0,0,.3);
}

.hero__badge {
	display: inline-block;
	background: var(--c-red);
	color: var(--c-white);
	padding: .4rem 1.5rem;
	border-radius: 50px;
	font-size: .95rem;
	font-weight: 600;
	margin-bottom: 1.5rem;
}

.hero__actions {
	display: flex;
	gap: 1rem;
	justify-content: center;
	flex-wrap: wrap;
}

/* ── Info Cards ───────────────────────────────────────────────── */
.info-cards { padding: 0; margin-top: -3rem; position: relative; z-index: 2; background: var(--c-dark); }

.info-cards__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
}

.info-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 3rem 2rem;
	color: var(--c-white);
	text-decoration: none;
	transition: filter var(--transition), transform var(--transition);
}
.info-card:hover {
	filter: brightness(1.1);
	color: var(--c-white);
}

.info-card--teal  { background: var(--c-teal); }
.info-card--red   { background: var(--c-red); }
.info-card--green { background: var(--c-green); }
.info-card--gold  { background: var(--c-gold); }

.info-card__title {
	font-size: clamp(1.3rem, 3vw, 1.75rem);
	font-weight: 700;
	color: var(--c-white);
	margin-bottom: .35rem;
}

.info-card__text {
	font-size: .9rem;
	opacity: .9;
	margin: 0;
}

/* ── Host Intro ───────────────────────────────────────────────── */
.host-intro__inner {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 3rem;
	align-items: center;
}

.host-intro__photo {
	width: 280px;
	height: 280px;
	border-radius: 50%;
	object-fit: cover;
	box-shadow: var(--shadow-lg);
}

.host-intro__heading {
	font-size: 1.1rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .05em;
	color: var(--c-teal);
	margin-bottom: .75rem;
}

.host-intro__blurb {
	font-size: 1.1rem;
	line-height: 1.7;
	color: var(--c-gray);
	margin-bottom: 1.5rem;
}

/* ── Latest Episode ───────────────────────────────────────────── */
.latest-episode__inner {
	display: grid;
	grid-template-columns: 320px 1fr;
	gap: 3rem;
	align-items: start;
	margin-top: 1.5rem;
}

.latest-episode__artwork img {
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-lg);
	width: 100%;
	height: auto;
}

.latest-episode__meta {
	display: flex;
	gap: .5rem;
	flex-wrap: wrap;
	margin-bottom: .75rem;
}

.latest-episode__title {
	font-size: clamp(1.25rem, 3vw, 1.75rem);
	color: var(--c-white);
	margin-bottom: .5rem;
}
.latest-episode__title a { color: var(--c-white); }
.latest-episode__title a:hover { color: var(--c-gold); }

.latest-episode__guest {
	color: rgba(255,255,255,.6);
	font-size: .9rem;
	margin-bottom: 1rem;
}

.latest-episode__excerpt {
	color: rgba(255,255,255,.7);
	margin-bottom: 1.5rem;
}

.latest-episode__player {
	margin-bottom: 1.5rem;
	border-radius: var(--radius);
	overflow: hidden;
}
.latest-episode__player iframe,
.latest-episode__player audio {
	width: 100%;
	border: none;
}

/* ── Featured Episode ─────────────────────────────────────────── */
.featured-episode__inner {
	display: grid;
	grid-template-columns: 280px 1fr;
	gap: 3rem;
	align-items: start;
	margin-top: 1.5rem;
}

.featured-episode__artwork img {
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow);
	width: 100%;
}

.featured-episode__guest {
	color: var(--c-gray);
	font-size: .9rem;
	margin-bottom: 1rem;
}

.featured-episode__excerpt { margin-bottom: 1.5rem; color: var(--c-gray); }

.featured-episode__player {
	margin-bottom: 1.5rem;
	border-radius: var(--radius);
	overflow: hidden;
}
.featured-episode__player iframe,
.featured-episode__player audio { width: 100%; border: none; }

/* ── Awards ───────────────────────────────────────────────────── */
.awards__heading {
	text-align: center;
	margin-bottom: 2.5rem;
}

.awards__track {
	display: flex;
	gap: 2.5rem;
	justify-content: center;
	flex-wrap: wrap;
}

.awards__item { text-align: center; }

.awards__badge {
	width: 120px;
	height: 120px;
	object-fit: contain;
	margin: 0 auto .75rem;
	transition: transform var(--transition);
}
.awards__badge:hover { transform: scale(1.05); }
.awards__name { font-size: .82rem; color: var(--c-gray); font-weight: 500; }

/* ── Card Grid ────────────────────────────────────────────────── */
.card-grid {
	display: grid;
	gap: 1.75rem;
}
.card-grid--2 { grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); }
.card-grid--3 { grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); }
.card-grid--4 { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }

/* ── Card ─────────────────────────────────────────────────────── */
.card {
	background: var(--c-white);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow);
	transition: transform var(--transition), box-shadow var(--transition);
}
.card:hover {
	transform: translateY(-3px);
	box-shadow: var(--shadow-lg);
}

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

.card__avatar {
	width: 100%;
	aspect-ratio: 1;
	object-fit: cover;
}

.card__avatar-placeholder {
	width: 100%;
	aspect-ratio: 1;
	background: var(--c-off);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 3rem;
	color: var(--c-gray-lt);
}

.card__body { padding: 1.25rem 1.5rem 1.5rem; }

.card__meta {
	display: flex;
	gap: .4rem;
	flex-wrap: wrap;
	margin-bottom: .6rem;
}

.card__date {
	display: block;
	font-size: .78rem;
	color: var(--c-gray);
	margin-bottom: .35rem;
}

.card__title {
	font-size: 1.1rem;
	font-weight: 600;
	margin-bottom: .4rem;
	line-height: 1.35;
}
.card__title a { color: var(--c-dark); }
.card__title a:hover { color: var(--c-teal); }

.card__excerpt {
	font-size: .88rem;
	color: var(--c-gray);
	line-height: 1.6;
	margin: 0;
}

.card__guest {
	font-size: .82rem;
	color: var(--c-green);
	font-weight: 500;
	margin: .75rem 0 0;
}

.card__role {
	font-size: .85rem;
	color: var(--c-gray);
	margin: 0;
}

.card__org {
	font-size: .82rem;
	color: var(--c-teal);
	margin: .15rem 0 0;
}

/* ── Carousel ─────────────────────────────────────────────────── */
.carousel { position: relative; }

.carousel__track {
	display: flex;
	gap: 1.5rem;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
	padding: .5rem 0 1rem;
}
.carousel__track::-webkit-scrollbar { display: none; }
.carousel__track > .card {
	flex: 0 0 320px;
	scroll-snap-align: start;
}

.carousel__btn {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 5;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: 2px solid var(--c-border);
	background: var(--c-white);
	color: var(--c-dark);
	font-size: 1rem;
	cursor: pointer;
	box-shadow: var(--shadow);
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background var(--transition), border-color var(--transition);
}
.carousel__btn:hover:not(:disabled) {
	background: var(--c-dark);
	color: var(--c-white);
	border-color: var(--c-dark);
}
.carousel__btn:disabled { opacity: .3; cursor: default; }
.carousel__btn--prev { left: -22px; }
.carousel__btn--next { right: -22px; }

/* ── Recent Guests ────────────────────────────────────────────── */
.recent-guests { background: var(--c-off); }

.recent-guests__track > .card--guest {
	flex: 0 0 calc((100% - 3 * 1.5rem) / 4);
	scroll-snap-align: start;
	min-width: 220px;
}

@media (max-width: 960px) {
	.recent-guests__track > .card--guest {
		flex: 0 0 calc((100% - 2 * 1.5rem) / 3);
	}
}

@media (max-width: 720px) {
	.recent-guests__track > .card--guest {
		flex: 0 0 calc((100% - 1.5rem) / 2);
		min-width: 0;
	}
}

@media (max-width: 480px) {
	.recent-guests__track > .card--guest {
		flex: 0 0 75%;
	}
}

/* ── Concepts ─────────────────────────────────────────────────── */
.concepts__heading {
	text-align: center;
	margin-bottom: 3rem;
}

.concepts__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 2rem;
}

.concepts__item {
	text-align: center;
	padding: 2rem 1.5rem;
	border: 1px solid var(--c-border);
	border-radius: var(--radius-lg);
	transition: border-color var(--transition), box-shadow var(--transition);
}
.concepts__item:hover {
	border-color: var(--c-teal);
	box-shadow: var(--shadow);
}

.concepts__icon {
	font-size: 2rem;
	color: var(--c-teal);
	margin-bottom: 1rem;
}

.concepts__title {
	font-size: 1.05rem;
	margin-bottom: .5rem;
}

.concepts__desc {
	font-size: .88rem;
	color: var(--c-gray);
	line-height: 1.6;
}

.concepts__link {
	display: inline-block;
	margin-top: .75rem;
	font-size: .85rem;
	font-weight: 600;
	color: var(--c-teal);
}

/* ── CTA ──────────────────────────────────────────────────────── */
.cta { text-align: center; }
.cta__heading { color: var(--c-white); margin-bottom: .75rem; }
.cta__text { color: rgba(255,255,255,.85); max-width: 600px; margin: 0 auto 2rem; font-size: 1.05rem; }

/* ── Scripture Quote ──────────────────────────────────────────── */
.scripture { text-align: center; }

.scripture__quote {
	max-width: 700px;
	margin: 0 auto;
	border: none;
	padding: 0;
}
.scripture__quote p {
	font-size: clamp(1.15rem, 2.5vw, 1.5rem);
	font-style: italic;
	line-height: 1.6;
	font-weight: 400;
	color: var(--c-white);
	margin-bottom: 1rem;
}
.scripture__cite {
	display: block;
	font-size: 1rem;
	font-style: normal;
	color: rgba(255,255,255,.8);
	font-weight: 500;
}

/* ── Media Mentions / In the Media ────────────────────────────── */
.media-mentions { background: var(--c-off); }

.media-mentions__heading {
	text-align: center;
	font-size: clamp(1.5rem, 4vw, 2.25rem);
	font-weight: 700;
	margin-bottom: 3rem;
}

.media-mentions__carousel { padding: 0 .25rem; }

.media-mentions__track > .media-mentions__item {
	flex: 0 0 300px;
	scroll-snap-align: start;
}

.media-mentions__item {
	background: var(--c-white);
	border-radius: var(--radius-lg);
	padding: 2rem 1.5rem;
	text-align: center;
	box-shadow: var(--shadow);
	transition: transform var(--transition), box-shadow var(--transition);
	display: flex;
	flex-direction: column;
}
.media-mentions__item:hover {
	transform: translateY(-3px);
	box-shadow: var(--shadow-lg);
}

.media-mentions__logo {
	margin-bottom: 1rem;
	min-height: 60px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.media-mentions__logo img {
	max-height: 70px;
	max-width: 200px;
	width: auto;
	object-fit: contain;
}

.media-mentions__desc {
	font-size: .82rem;
	text-transform: uppercase;
	letter-spacing: .04em;
	color: var(--c-gray);
	font-weight: 600;
	margin-bottom: .5rem;
}

.media-mentions__headline {
	font-size: .95rem;
	font-style: italic;
	color: var(--c-dark);
	line-height: 1.5;
	margin: 0;
}
.media-mentions__headline a {
	color: var(--c-dark);
	text-decoration: none;
}
.media-mentions__headline a:hover {
	color: var(--c-teal);
}

.media-mentions__source {
	font-size: .85rem;
	font-weight: 600;
	color: var(--c-dark);
	margin-top: .5rem;
}

/* ── Filter Bar ───────────────────────────────────────────────── */
.filter-bar {
	display: flex;
	gap: .5rem;
	flex-wrap: wrap;
	justify-content: center;
	margin-bottom: 2.5rem;
}

.filter-bar__item {
	padding: .45rem 1.2rem;
	font-size: .85rem;
	font-weight: 500;
	border: 2px solid var(--c-border);
	border-radius: 50px;
	color: var(--c-gray);
	transition: all var(--transition);
}
.filter-bar__item:hover {
	border-color: var(--c-teal);
	color: var(--c-teal);
}
.filter-bar__item.is-active {
	background: var(--c-dark);
	border-color: var(--c-dark);
	color: var(--c-white);
}

/* ── Page Header ──────────────────────────────────────────────── */
.page-header,
.archive-header {
	background: var(--c-dark);
	color: var(--c-white);
	padding: 3.5rem 0 3rem;
}

.page-header__title,
.archive-header__title {
	color: var(--c-white);
	margin-bottom: .25rem;
}

.page-header__subtitle,
.archive-header__desc {
	color: rgba(255,255,255,.65);
	font-size: 1rem;
	margin: 0;
}

.page-header__date {
	display: block;
	font-size: .82rem;
	color: var(--c-gold);
	margin-bottom: .5rem;
}

.breadcrumb {
	font-size: .82rem;
	color: rgba(255,255,255,.5);
	margin-bottom: .75rem;
}
.breadcrumb a { color: rgba(255,255,255,.7); }
.breadcrumb a:hover { color: var(--c-white); }

/* ── Single Episode ───────────────────────────────────────────── */
.single-ep__header {
	background: var(--c-dark);
	color: var(--c-white);
	padding: 3rem 0;
}

.single-ep__header-inner {
	display: grid;
	grid-template-columns: 240px 1fr;
	gap: 2.5rem;
	align-items: center;
}

.single-ep__artwork img {
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-lg);
	width: 100%;
}

.single-ep__meta {
	display: flex;
	gap: .5rem;
	flex-wrap: wrap;
	margin-bottom: .75rem;
}

.single-ep__title {
	color: var(--c-white);
	margin-bottom: .5rem;
}

.single-ep__guest-line {
	color: rgba(255,255,255,.65);
	font-size: .95rem;
}
.single-ep__guest-line a {
	color: var(--c-gold);
	text-decoration: underline;
	text-decoration-color: rgba(211,176,64,.4);
	text-underline-offset: 2px;
	transition: text-decoration-color var(--transition);
}
.single-ep__guest-line a:hover {
	text-decoration-color: var(--c-gold);
	color: var(--c-white);
}
.single-ep__guest-line a strong { color: inherit; }
.single-ep__guest-role { opacity: .7; }

.single-ep__body { padding: 3rem 0 4rem; max-width: var(--max-w-sm); margin: 0 auto; }

/* Fallback player (raw embed / iframe). */
.single-ep__player {
	margin-bottom: 2.5rem;
	background: var(--c-off);
	padding: 1.5rem;
	border-radius: var(--radius-lg);
}
.single-ep__player iframe,
.single-ep__player audio { width: 100%; border: none; border-radius: var(--radius); }

/* ── Custom Audio Player ──────────────────────────────────────── */
.wdip-player {
	margin-bottom: 2.5rem;
	background: var(--c-dark);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-lg);
}

.wdip-player__inner {
	display: flex;
	align-items: stretch;
}

.wdip-player__controls {
	flex: 1;
	padding: 1.25rem 1.5rem;
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: .75rem;
	min-width: 0;
}

.wdip-player__top { min-width: 0; }

.wdip-player__title {
	font-size: .95rem;
	font-weight: 600;
	color: var(--c-white);
	margin: 0;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.wdip-player__sub {
	font-size: .78rem;
	color: rgba(255,255,255,.5);
	margin: .15rem 0 0;
}

/* Progress track. */
.wdip-player__track { user-select: none; }

.wdip-player__progress {
	position: relative;
	height: 6px;
	background: rgba(255,255,255,.15);
	border-radius: 3px;
	cursor: pointer;
	touch-action: none;
}

.wdip-player__bar {
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: 0;
	background: var(--c-teal);
	border-radius: 3px;
	transition: width .05s linear;
}

.wdip-player__knob {
	position: absolute;
	top: 50%;
	left: 0;
	width: 14px;
	height: 14px;
	background: var(--c-white);
	border-radius: 50%;
	transform: translate(-50%, -50%);
	box-shadow: 0 1px 4px rgba(0,0,0,.4);
	opacity: 0;
	transition: opacity .15s;
}

.wdip-player:hover .wdip-player__knob,
.wdip-player.is-playing .wdip-player__knob {
	opacity: 1;
}

.wdip-player__times {
	display: flex;
	justify-content: space-between;
	font-size: .72rem;
	color: rgba(255,255,255,.45);
	margin-top: .3rem;
	font-variant-numeric: tabular-nums;
}

/* Button row. */
.wdip-player__buttons {
	display: flex;
	align-items: center;
	gap: .5rem;
}

.wdip-player__btn {
	background: none;
	border: none;
	color: rgba(255,255,255,.7);
	font-family: var(--ff);
	font-size: .8rem;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: .2rem;
	padding: .35rem .5rem;
	border-radius: 6px;
	transition: color var(--transition), background var(--transition);
}
.wdip-player__btn:hover {
	color: var(--c-white);
	background: rgba(255,255,255,.1);
}

.wdip-player__btn--play {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: var(--c-teal);
	color: var(--c-white);
	font-size: 1.15rem;
	justify-content: center;
	padding: 0;
	transition: background var(--transition), transform .1s;
}
.wdip-player__btn--play:hover {
	background: #4da3bc;
	transform: scale(1.05);
}
.wdip-player.is-playing .wdip-player__btn--play {
	background: var(--c-red);
}
.wdip-player.is-playing .wdip-player__btn--play:hover {
	background: #c9402a;
}

.wdip-player__btn--back span,
.wdip-player__btn--fwd span {
	font-size: .65rem;
	font-weight: 700;
}

.wdip-player__btn--speed {
	font-weight: 600;
	font-size: .75rem;
	min-width: 38px;
	justify-content: center;
	color: var(--c-gold);
}
.wdip-player__btn--speed:hover {
	color: var(--c-white);
}

.wdip-player__speed {
	margin-left: auto;
}

/* Latest / featured episode players on front page. */
.latest-episode__player .wdip-player,
.featured-episode__player .wdip-player {
	box-shadow: none;
}

/* Responsive. */
@media (max-width: 520px) {
	.wdip-player__controls {
		padding: 1rem;
		gap: .5rem;
	}
	.wdip-player__btn--play {
		width: 42px;
		height: 42px;
		font-size: 1rem;
	}
}

.single-ep__guest-card {
	display: flex;
	gap: 1.5rem;
	align-items: center;
	padding: 1.5rem;
	background: var(--c-off);
	border-radius: var(--radius-lg);
	margin-bottom: 2.5rem;
}

.single-ep__guest-photo {
	width: 100px;
	height: 100px;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
}

.single-ep__guest-name { font-size: 1.15rem; margin-bottom: .15rem; }
.single-ep__guest-name a { color: var(--c-dark); }
.single-ep__guest-name a:hover { color: var(--c-teal); }
.single-ep__guest-title { font-size: .88rem; color: var(--c-gray); margin: 0 0 .5rem; }
.single-ep__guest-bio { font-size: .9rem; color: var(--c-gray); margin: 0; line-height: 1.6; }

/* Transcript. */
.single-ep__transcript {
	margin: 2.5rem 0;
	border: 1px solid var(--c-border);
	border-radius: var(--radius-lg);
}

.single-ep__transcript-toggle {
	padding: 1.25rem 1.5rem;
	font-family: var(--ff);
	font-size: 1rem;
	font-weight: 600;
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: .5rem;
	list-style: none;
	transition: background var(--transition);
}
.single-ep__transcript-toggle::-webkit-details-marker { display: none; }
.single-ep__transcript-toggle:hover { background: var(--c-off); }

.single-ep__transcript[open] .single-ep__transcript-toggle {
	border-bottom: 1px solid var(--c-border);
}

.single-ep__transcript-content {
	padding: 1.5rem;
	max-height: 600px;
	overflow-y: auto;
}

.single-ep__related { margin-top: 3rem; padding-top: 2.5rem; border-top: 1px solid var(--c-border); }

/* ── About Page ───────────────────────────────────────────────── */
.about-header__top {
	background: var(--c-red);
	color: var(--c-white);
	padding: 3rem 0 2.5rem;
	text-align: center;
}
.about-header__title {
	font-size: clamp(2rem, 5vw, 3rem);
	font-weight: 700;
	color: var(--c-white);
	margin: 0;
}

.about-header__scripture {
	background: var(--c-teal);
	color: var(--c-white);
	padding: 1.75rem 0;
	text-align: center;
}
.about-header__quote {
	font-size: clamp(1rem, 2.2vw, 1.25rem);
	margin: 0 0 .35rem;
	line-height: 1.5;
}
.about-header__tagline {
	font-size: 1rem;
	font-weight: 600;
	margin: 0;
	opacity: .9;
}

.about-body { font-size: 1.05rem; line-height: 1.8; }

/* Team section on about page. */
.about-team__heading {
	text-align: center;
	font-size: clamp(1.5rem, 4vw, 2.25rem);
	font-weight: 700;
	margin-bottom: 2.5rem;
}

.about-team__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2rem;
}

.about-team__member { text-align: center; }

.about-team__photo-link {
	display: block;
	margin-bottom: 0;
}

.about-team__photo {
	width: 100%;
	aspect-ratio: 1;
	object-fit: cover;
	object-position: top;
	border-radius: 0;
	transition: opacity var(--transition);
}
.about-team__photo-link:hover .about-team__photo {
	opacity: .85;
}

.about-team__photo-placeholder {
	width: 100%;
	aspect-ratio: 1;
	background: var(--c-off);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 3rem;
	color: var(--c-gray-lt);
}

.about-team__info {
	background: var(--c-teal);
	color: var(--c-white);
	padding: 1rem 1.25rem;
	text-align: left;
}

.about-team__name {
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--c-white);
	margin: 0 0 .15rem;
}
.about-team__name a {
	color: var(--c-white);
}
.about-team__name a:hover {
	color: var(--c-gold);
}

.about-team__role {
	font-size: .85rem;
	margin: 0;
	opacity: .85;
}

/* Legacy host bio (used on other pages). */
.host-bio { margin-top: 4rem; }

.host-bio__inner {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 3rem;
	align-items: start;
}

.host-bio__photo {
	width: 300px;
	height: 300px;
	border-radius: 50%;
	object-fit: cover;
	box-shadow: var(--shadow-lg);
}

.host-bio__role {
	font-size: .9rem;
	color: var(--c-teal);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 1rem;
}

/* ── Team Single ──────────────────────────────────────────────── */
.team-single,
.guest-single {
	display: grid;
	grid-template-columns: 280px 1fr;
	gap: 3rem;
	align-items: start;
}

.team-single__photo img,
.guest-single__photo img {
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow);
	width: 100%;
}

/* Black & white team headshots — toggled in Theme Settings → General. */
body.team-grayscale .card--team .card__avatar,
body.team-grayscale .about-team__photo,
body.team-grayscale .team-single__photo img {
	filter: grayscale(100%);
	transition: filter var(--transition), opacity var(--transition);
}
/* Fade back to full colour on hover. */
body.team-grayscale .card--team:hover .card__avatar,
body.team-grayscale .about-team__photo-link:hover .about-team__photo,
body.team-grayscale .team-single__photo:hover img {
	filter: grayscale(0);
}

.guest-single__episodes { margin-top: 3rem; }

/* ── Contact Page ─────────────────────────────────────────────── */
.contact-grid {
	display: grid;
	grid-template-columns: 1fr 380px;
	gap: 3rem;
	align-items: start;
}

.contact-info-card {
	background: var(--c-off);
	border: 1px solid var(--c-border);
	border-radius: var(--radius-lg);
	padding: 1.5rem;
	margin-bottom: 1.5rem;
}
.contact-info-card h2 {
	font-size: 1rem;
	margin-bottom: .75rem;
	display: flex;
	align-items: center;
	gap: .5rem;
}
.contact-info-card p { margin: 0; }
.contact-info-card a { font-weight: 500; }

.contact-form h2 { margin-bottom: .5rem; }
.contact-form > p { color: var(--c-gray); margin-bottom: 1.5rem; }

.contact-social { margin-top: 2rem; }
.contact-social h3 { font-size: .95rem; margin-bottom: .75rem; }

.contact-social__icons {
	display: flex;
	gap: .75rem;
}
.contact-social__link {
	width: 44px;
	height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: var(--c-off);
	color: var(--c-dark);
	font-size: 1.15rem;
	transition: background var(--transition), color var(--transition);
}
.contact-social__link:hover {
	background: var(--c-teal);
	color: var(--c-white);
}

/* ── Voice Recorder ───────────────────────────────────────────── */
.voice-recorder {
	background: var(--c-off);
	border: 1px solid var(--c-border);
	border-radius: var(--radius-lg);
	padding: 2rem;
}

.voice-recorder__heading {
	font-size: 1.1rem;
	margin-bottom: .5rem;
}

.voice-recorder__desc {
	font-size: .88rem;
	color: var(--c-gray);
	margin-bottom: 1.25rem;
}

.voice-recorder__fields { margin-bottom: 1.25rem; }

.voice-recorder__label {
	display: block;
	font-size: .82rem;
	font-weight: 600;
	margin-bottom: .3rem;
	margin-top: .75rem;
}
.voice-recorder__label:first-child { margin-top: 0; }

.voice-recorder__optional { font-weight: 400; color: var(--c-gray); }

.voice-recorder__input {
	display: block;
	width: 100%;
	padding: .6rem .85rem;
	font-family: var(--ff);
	font-size: .9rem;
	border: 1px solid var(--c-border);
	border-radius: var(--radius);
	transition: border-color var(--transition);
}
.voice-recorder__input:focus {
	outline: none;
	border-color: var(--c-teal);
	box-shadow: 0 0 0 3px rgba(45,105,122,.15);
}

.voice-recorder__controls {
	display: flex;
	gap: .75rem;
	margin-bottom: 1rem;
}

.voice-recorder__preview { margin-bottom: 1rem; }
.voice-recorder__preview audio { width: 100%; margin-bottom: .75rem; }

.voice-recorder__actions { display: flex; gap: .75rem; }

.voice-recorder__status {
	font-size: .85rem;
	min-height: 1.3em;
	margin-bottom: .5rem;
}
.voice-recorder__status--recording { color: var(--c-red); font-weight: 600; }
.voice-recorder__status--error   { color: var(--c-red); }
.voice-recorder__status--success { color: var(--c-green); font-weight: 600; }

.voice-recorder__alt {
	font-size: .82rem;
	color: var(--c-gray);
	margin: .75rem 0 0;
}

.voice-recorder__upload-label {
	color: var(--c-teal);
	font-weight: 500;
	cursor: pointer;
	text-decoration: underline;
	text-underline-offset: 2px;
}

/* ── Pagination ───────────────────────────────────────────────── */
.wdip-pagination,
.nav-links {
	display: flex;
	justify-content: center;
	gap: .4rem;
	padding: 2.5rem 0 0;
}

.wdip-pagination .page-numbers,
.nav-links .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 .5rem;
	border-radius: var(--radius);
	font-size: .88rem;
	font-weight: 500;
	color: var(--c-dark);
	background: var(--c-off);
	transition: all var(--transition);
}

.wdip-pagination .page-numbers.current,
.wdip-pagination .page-numbers:hover,
.nav-links .page-numbers.current,
.nav-links .page-numbers:hover {
	background: var(--c-teal);
	color: var(--c-white);
}

/* ── Footer ───────────────────────────────────────────────────── */
.site-footer {
	background: var(--c-dark);
	color: rgba(255,255,255,.7);
	padding: 4rem 0 2rem;
}

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

.site-footer__brand-row {
	display: flex;
	align-items: center;
	gap: .9rem;
	margin-bottom: .85rem;
}

.site-footer__brand {
	color: var(--c-white);
	font-size: 1.15rem;
	font-weight: 600;
	margin: 0;
}

/* WDIP tile mark — mirrors the podcast cover art palette. */
.wdip-mark {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	grid-template-rows: repeat(2, 1fr);
	gap: 3px;
	width: 64px;
	height: 64px;
	flex-shrink: 0;
	border-radius: 6px;
	overflow: hidden;
	background: rgba(255,255,255,.04);
	padding: 3px;
	perspective: 600px;
}

.wdip-mark__tile {
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--ff);
	font-weight: 800;
	font-size: 1.05rem;
	text-transform: uppercase;
	color: var(--c-white);
	line-height: 1;
	border-radius: 2px;
	transform-origin: center;
	animation: wdip-mark-flip 5s ease-in-out 1.5s 3;
}
/* Each flip lasts 0.6s; stagger by 0.7s so a letter fully resolves before the next starts. */
.wdip-mark__tile:nth-child(2) { animation-delay: 2.2s; }
.wdip-mark__tile:nth-child(3) { animation-delay: 2.9s; }
.wdip-mark__tile:nth-child(4) { animation-delay: 3.6s; }

.wdip-mark__tile--w { background: var(--c-red);   }
.wdip-mark__tile--d { background: var(--c-gold);  color: var(--c-dark); }
.wdip-mark__tile--i { background: var(--c-teal);  }
.wdip-mark__tile--p { background: var(--c-green); }

@keyframes wdip-mark-flip {
	0%   { transform: rotateY(0); }
	6%   { transform: rotateY(180deg); }
	12%  { transform: rotateY(0); }
	100% { transform: rotateY(0); }
}

/* Header variant — sized to sit in the 72px header bar. */
.wdip-mark--header {
	width: 42px;
	height: 42px;
	gap: 2px;
	padding: 2px;
	border-radius: 5px;
}
.wdip-mark--header .wdip-mark__tile {
	font-size: .72rem;
	border-radius: 2px;
}

@media (prefers-reduced-motion: reduce) {
	.wdip-mark__tile { animation: none; }
}

.site-footer__description {
	font-size: .88rem;
	line-height: 1.65;
	margin-bottom: 1rem;
}

.site-footer__email {
	display: inline-flex;
	align-items: center;
	gap: .4rem;
	color: var(--c-gold);
	font-size: .88rem;
	font-weight: 500;
}
.site-footer__email:hover { color: var(--c-white); }

.site-footer__heading {
	color: var(--c-white);
	font-size: .9rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .06em;
	margin-bottom: 1rem;
}

.site-footer__menu {
	list-style: none;
	padding: 0;
	margin: 0;
}
.site-footer__menu li { margin-bottom: .45rem; }
.site-footer__menu a { color: rgba(255,255,255,.7); font-size: .88rem; }
.site-footer__menu a:hover { color: var(--c-gold); }

.site-footer__subscribe {
	list-style: none;
	padding: 0;
	margin: 0;
}
.site-footer__subscribe li { margin-bottom: .5rem; }
.site-footer__subscribe a {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	color: rgba(255,255,255,.7);
	font-size: .88rem;
}
.site-footer__subscribe a:hover { color: var(--c-gold); }
.site-footer__subscribe-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 16px;
	height: 16px;
	flex-shrink: 0;
}
.site-footer__subscribe-icon svg { width: 100%; height: 100%; }

.site-footer__contact-line {
	font-size: .88rem;
	line-height: 1.65;
	margin: 0 0 1.25rem;
	color: rgba(255,255,255,.7);
}
.site-footer__contact-line a {
	color: var(--c-gold);
	font-weight: 500;
}
.site-footer__contact-line a:hover { color: var(--c-white); }

.site-footer__social {
	display: flex;
	gap: .75rem;
	flex-wrap: wrap;
}
.site-footer__social a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	background: rgba(255,255,255,.08);
	color: var(--c-white);
	border-radius: 50%;
	font-size: 1.05rem;
	transition: background var(--transition);
}
.site-footer__social a svg { width: 16px; height: 16px; }
.site-footer__social a:hover {
	background: var(--c-teal);
	color: var(--c-white);
}

.site-footer__awards {
	display: flex;
	gap: 1.5rem;
	flex-wrap: wrap;
	justify-content: center;
	padding: 2rem 0;
	border-top: 1px solid rgba(255,255,255,.08);
	border-bottom: 1px solid rgba(255,255,255,.08);
	margin-bottom: 2rem;
}
.site-footer__award-badge {
	width: 64px;
	height: 64px;
	object-fit: contain;
	opacity: .7;
	transition: opacity var(--transition);
}
.site-footer__award-badge:hover { opacity: 1; }

.site-footer__bottom {
	text-align: center;
	font-size: .82rem;
	color: rgba(255,255,255,.45);
}

/* ── Subscribe / Listen-On Page ───────────────────────────────── */
.subscribe-page {
	background: #0d1820;
	color: var(--c-white);
	min-height: calc(100vh - 72px);
}

.subscribe-page__inner {
	display: grid;
	grid-template-columns: minmax(320px, 40%) 1fr;
	min-height: calc(100vh - 72px);
	max-width: 1400px;
	margin: 0 auto;
}

.subscribe-page__aside {
	background: #213946;
	padding: 3rem 2.5rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}

.subscribe-page__artwork {
	width: 100%;
	max-width: 360px;
	aspect-ratio: 1;
	border-radius: var(--radius);
	box-shadow: 0 12px 40px rgba(0,0,0,.35);
	margin-bottom: 2rem;
}

.subscribe-page__title {
	color: var(--c-white);
	font-size: clamp(1.5rem, 3vw, 2rem);
	font-weight: 700;
	line-height: 1.2;
	margin: 0 0 .5rem;
}

.subscribe-page__host {
	color: var(--c-gold);
	font-weight: 600;
	font-size: .95rem;
	margin: 0 0 1.25rem;
}

.subscribe-page__blurb {
	color: rgba(255,255,255,.75);
	font-size: .95rem;
	line-height: 1.6;
	margin: 0 0 1.5rem;
}

.subscribe-page__trailer {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	background: var(--c-white);
	color: var(--c-dark);
	font-weight: 600;
	padding: .75rem 1.75rem;
	border-radius: 50px;
	font-size: .9rem;
	transition: background var(--transition), color var(--transition);
}
.subscribe-page__trailer:hover {
	background: var(--c-gold);
	color: var(--c-dark);
}

.subscribe-page__main {
	padding: 3rem 2.5rem;
	background: #0d1820;
}

.subscribe-page__apps-heading {
	color: var(--c-white);
	font-size: 1.15rem;
	font-weight: 600;
	margin: 0 0 1.5rem;
}

.subscribe-page__apps {
	list-style: none;
	padding: 0;
	margin: 0;
}

.subscribe-page__app + .subscribe-page__app {
	border-top: 1px solid rgba(255,255,255,.08);
}

.subscribe-page__app-link {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 1rem 0;
	color: var(--c-white);
	text-decoration: none;
	transition: background var(--transition);
	border-radius: 8px;
}
.subscribe-page__app-link:hover {
	background: rgba(255,255,255,.04);
	color: var(--c-white);
	padding-left: .75rem;
	padding-right: .75rem;
}

.subscribe-page__app-icon {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--c-white);
	flex-shrink: 0;
	margin-left: .25rem;
}

.subscribe-page__app-label {
	flex: 1;
	font-size: 1.05rem;
	font-weight: 500;
}

.subscribe-page__app-chevron {
	color: rgba(255,255,255,.3);
	font-size: .85rem;
	margin-right: .5rem;
}

@media (max-width: 768px) {
	.subscribe-page__inner {
		grid-template-columns: 1fr;
	}
	.subscribe-page__aside {
		padding: 2rem 1.5rem;
	}
	.subscribe-page__artwork {
		max-width: 240px;
	}
	.subscribe-page__main {
		padding: 2rem 1.5rem;
	}
}

/* ── 404 ──────────────────────────────────────────────────────── */
.error-page__code {
	font-size: clamp(5rem, 15vw, 10rem);
	font-weight: 700;
	color: var(--c-teal);
	line-height: 1;
	margin-bottom: .25rem;
}
.error-page__message {
	font-size: 1.1rem;
	color: var(--c-gray);
	margin-bottom: 2rem;
	max-width: 480px;
	margin-left: auto;
	margin-right: auto;
}
.error-page__actions { display: flex; gap: .75rem; justify-content: center; }

/* ── Single Post ──────────────────────────────────────────────── */
.single-post__hero {
	margin: 0 0 2rem;
}
.single-post__hero img {
	border-radius: var(--radius-lg);
	width: 100%;
}

.single-post__tags {
	margin-top: 2rem;
	padding-top: 1.5rem;
	border-top: 1px solid var(--c-border);
}
.single-post__tags a {
	display: inline-block;
	padding: .25rem .7rem;
	font-size: .8rem;
	font-weight: 500;
	background: var(--c-off);
	border-radius: 4px;
	color: var(--c-gray);
	margin-right: .35rem;
	margin-bottom: .35rem;
}
.single-post__tags a:hover { color: var(--c-teal); }

/* ── Page Hero ────────────────────────────────────────────────── */
.page-hero {
	margin: 0 0 2rem;
}
.page-hero img {
	border-radius: var(--radius-lg);
	width: 100%;
}

/* ── No Results ───────────────────────────────────────────────── */
.no-results {
	text-align: center;
	padding: 4rem 0;
	color: var(--c-gray);
	font-size: 1.05rem;
}

/* ── WordPress defaults ───────────────────────────────────────── */
.alignleft   { float: left;  margin: 0 1.5em 1em 0; }
.alignright  { float: right; margin: 0 0 1em 1.5em; }
.aligncenter { display: block; margin: 1.5em auto; }
.wp-caption  { max-width: 100%; }
.wp-caption-text { font-size: .82rem; color: var(--c-gray); margin-top: .5rem; }

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width: 1024px) {
	.site-footer__grid {
		grid-template-columns: 1fr 1fr;
	}

	.carousel__btn--prev { left: .25rem; }
	.carousel__btn--next { right: .25rem; }

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

@media (max-width: 768px) {
	/* Header. */
	.site-header__toggle { display: block; }
	.site-header__nav {
		display: none;
		position: absolute;
		top: 72px;
		left: 0;
		right: 0;
		background: var(--c-dark);
		flex-direction: column;
		padding: 1rem 1.5rem 1.5rem;
		border-top: 1px solid rgba(255,255,255,.08);
		box-shadow: var(--shadow-lg);
	}
	.site-header__nav.is-open { display: flex; }
	.site-header__menu { flex-direction: column; width: 100%; gap: 0; }
	.site-header__menu a { padding: .65rem 0; }
	.site-header__menu .sub-menu {
		position: static;
		box-shadow: none;
		border: none;
		padding-left: 1rem;
	}
	.site-header__menu li:hover > .sub-menu { display: block; }
	.btn--subscribe { margin-top: .75rem; align-self: flex-start; }

	/* Layout. */
	.section { padding: 3.5rem 0; }

	.host-intro__inner,
	.latest-episode__inner,
	.featured-episode__inner,
	.single-ep__header-inner,
	.host-bio__inner,
	.team-single,
	.guest-single,
	.contact-grid {
		grid-template-columns: 1fr;
		gap: 2rem;
	}

	.host-intro__photo-wrap { text-align: center; }
	.host-intro__photo {
		width: 200px;
		height: 200px;
	}

	.host-bio__photo-wrap { text-align: center; }
	.host-bio__photo {
		width: 200px;
		height: 200px;
	}

	.latest-episode__artwork { max-width: 280px; }

	.hero { padding: 3.5rem 0 4rem; }
	.hero--has-bg { min-height: 400px; }
	.hero__artwork { width: 160px; }

	.info-cards { margin-top: 0; }
	.info-cards__grid { grid-template-columns: 1fr; }

	.about-team__grid { grid-template-columns: 1fr; max-width: 360px; margin: 0 auto; }

	.site-footer__grid { grid-template-columns: 1fr; gap: 2rem; }

	.carousel__track > .card { flex: 0 0 280px; }
}

@media (max-width: 480px) {
	.container { padding: 0 1rem; }
	.hero__artwork { width: 130px; height: 130px; }
	.card__image { height: 180px; }
	.carousel__track > .card { flex: 0 0 260px; }
	.contact-grid { grid-template-columns: 1fr; }
}
