/* ==========================================================================
   Listener Portal — Styles
   Mobile-first, dark-mode-default
   ========================================================================== */

/* --------------------------------------------------------------------------
   CSS Custom Properties
   -------------------------------------------------------------------------- */

:root {
    /* Dark mode (default) */
    --listener-bg:              #0a0a0f;
    --listener-bg-elevated:     #12121a;
    --listener-bg-card:         #16161f;
    --listener-bg-card-hover:   #1c1c28;
    --listener-border:          rgba(255, 255, 255, 0.06);
    --listener-border-strong:   rgba(255, 255, 255, 0.12);

    --listener-text:            #e8e8e8;
    --listener-text-muted:      #8a8a9a;
    --listener-text-faint:      #555566;
    --listener-translation:     #8cb4ff;

    --listener-accent:          #f59e0b;
    --listener-accent-glow:     rgba(245, 158, 11, 0.25);
    --listener-accent-subtle:   rgba(245, 158, 11, 0.08);

    --listener-live-red:        #ef4444;
    --listener-success:         #22c55e;
    --listener-warning:         #f59e0b;
    --listener-danger:          #ef4444;

    --listener-verse-bg:        rgba(245, 158, 11, 0.12);
    --listener-verse-border:    rgba(245, 158, 11, 0.3);

    --listener-header-bg:       rgba(10, 10, 15, 0.85);
    --listener-header-blur:     20px;

    --listener-radius-sm:       8px;
    --listener-radius-md:       12px;
    --listener-radius-lg:       16px;
    --listener-radius-full:     9999px;

    --listener-shadow-sm:       0 1px 2px rgba(0, 0, 0, 0.3);
    --listener-shadow-md:       0 4px 12px rgba(0, 0, 0, 0.4);
    --listener-shadow-lg:       0 8px 32px rgba(0, 0, 0, 0.5);

    --listener-font:            'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --listener-font-size-xs:    0.75rem;
    --listener-font-size-sm:    0.8125rem;
    --listener-font-size-base:  1rem;
    --listener-font-size-lg:    1.125rem;
    --listener-font-size-xl:    1.25rem;
    --listener-font-size-2xl:   1.5rem;
    --listener-font-size-3xl:   1.875rem;

    --listener-transcript-size: 1.125rem;
    --listener-translation-size:1.25rem;
    --listener-line-height:     1.75;

    --listener-safe-top:        env(safe-area-inset-top, 0px);
    --listener-safe-bottom:     env(safe-area-inset-bottom, 0px);
    --listener-safe-left:       env(safe-area-inset-left, 0px);
    --listener-safe-right:      env(safe-area-inset-right, 0px);

    --listener-header-height:   56px;
    --listener-live-bar-height: 44px;
}

/* Light mode overrides */
[data-bs-theme="light"] {
    --listener-bg:              #f8f9fa;
    --listener-bg-elevated:     #ffffff;
    --listener-bg-card:         #ffffff;
    --listener-bg-card-hover:   #f0f0f5;
    --listener-border:          rgba(0, 0, 0, 0.06);
    --listener-border-strong:   rgba(0, 0, 0, 0.12);

    --listener-text:            #1a1a1a;
    --listener-text-muted:      #6b7280;
    --listener-text-faint:      #9ca3af;
    --listener-translation:     #2563eb;

    --listener-accent:          #d97706;
    --listener-accent-glow:     rgba(217, 119, 6, 0.2);
    --listener-accent-subtle:   rgba(217, 119, 6, 0.06);

    --listener-verse-bg:        rgba(217, 119, 6, 0.08);
    --listener-verse-border:    rgba(217, 119, 6, 0.25);

    --listener-header-bg:       rgba(248, 249, 250, 0.85);

    --listener-shadow-sm:       0 1px 2px rgba(0, 0, 0, 0.05);
    --listener-shadow-md:       0 4px 12px rgba(0, 0, 0, 0.08);
    --listener-shadow-lg:       0 8px 32px rgba(0, 0, 0, 0.1);
}

/* --------------------------------------------------------------------------
   Reset & Base
   -------------------------------------------------------------------------- */

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

html {
    height: 100%;
    -webkit-text-size-adjust: 100%;
}

body {
    margin: 0;
    padding: 0;
    font-family: var(--listener-font);
    font-size: var(--listener-font-size-base);
    color: var(--listener-text);
    background: var(--listener-bg);
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow: hidden;
    height: 100%;
    height: 100dvh;
}

/* --------------------------------------------------------------------------
   Particle Canvas
   -------------------------------------------------------------------------- */

#listener-particles {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 120px;
    z-index: 0;
    pointer-events: none;
    opacity: 0.7;
}

/* --------------------------------------------------------------------------
   Header
   -------------------------------------------------------------------------- */

#listener-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    height: calc(var(--listener-header-height) + var(--listener-safe-top));
    padding-top: var(--listener-safe-top);
    background: var(--listener-header-bg);
    -webkit-backdrop-filter: saturate(180%) blur(var(--listener-header-blur));
    backdrop-filter: saturate(180%) blur(var(--listener-header-blur));
    border-bottom: 1px solid var(--listener-border);
}

.listener-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: var(--listener-header-height);
    padding: 0 16px;
    max-width: 1200px;
    margin: 0 auto;
}

.listener-header__left {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
}

.listener-header__back {
    display: flex;
    align-items: center;
    color: var(--listener-text-faint);
    text-decoration: none;
    flex-shrink: 0;
    transition: color 0.15s;
}

.listener-header__back:hover {
    color: var(--listener-accent);
}

.listener-header__home {
    display: flex;
    align-items: center;
    gap: 8px;
    text-decoration: none;
    color: inherit;
    min-width: 0;
}

.listener-header__home:hover .listener-header__org {
    color: var(--listener-accent);
}

.listener-header__logo {
    height: 30px;
    width: auto;
    max-width: 120px;
    object-fit: contain;
    flex-shrink: 0;
}

/* UV branded logo in header (theme-aware) */
.listener-header__uv-logo {
    height: 28px;
    width: auto;
    object-fit: contain;
    flex-shrink: 0;
}

/* Dark theme: show light logo, hide dark logo */
[data-bs-theme="dark"] .listener-header__uv-logo--dark { display: none; }
[data-bs-theme="dark"] .listener-header__uv-logo--light { display: block; }
[data-bs-theme="light"] .listener-header__uv-logo--light { display: none; }
[data-bs-theme="light"] .listener-header__uv-logo--dark { display: block; }

/* About section logo (stacked, theme-aware) */
[data-bs-theme="dark"] .listener-discovery-about__logo--dark { display: none; }
[data-bs-theme="dark"] .listener-discovery-about__logo--light { display: inline-block; }
[data-bs-theme="light"] .listener-discovery-about__logo--light { display: none; }
[data-bs-theme="light"] .listener-discovery-about__logo--dark { display: inline-block; }

/* UI Language Switcher */
.listener-lang-switcher {
    position: relative;
}

.listener-lang-switcher__trigger {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.listener-lang-switcher__trigger span {
    font-weight: 600;
    font-size: 0.7rem;
    letter-spacing: 0.05em;
}

.listener-lang-switcher__dropdown {
    position: absolute;
    top: calc(100% + 6px);
    right: 0;
    z-index: 200;
    min-width: 160px;
    border-radius: 10px;
    background: var(--listener-bg-elevated);
    border: 1px solid var(--listener-border);
    box-shadow: 0 8px 30px rgba(0,0,0,0.3);
    overflow: hidden;
}

.listener-lang-switcher__option {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    text-decoration: none;
    color: var(--listener-text);
    font-size: 0.85rem;
    transition: background 0.1s;
}

.listener-lang-switcher__option:hover {
    background: rgba(99, 102, 241, 0.08);
}

.listener-lang-switcher__option.is-active {
    color: var(--listener-accent);
}

.listener-lang-switcher__native {
    font-weight: 600;
}

.listener-lang-switcher__name {
    color: var(--listener-text-faint);
    font-size: 0.75rem;
    margin-left: auto;
}

.listener-lang-switcher__option svg {
    color: var(--listener-accent);
    flex-shrink: 0;
}

.listener-header__text {
    min-width: 0;
}

.listener-header__org {
    font-size: var(--listener-font-size-sm);
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block;
    max-width: 180px;
    letter-spacing: -0.01em;
    transition: color 0.15s;
}

.listener-header__right {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
}

.listener-header__btn {
    display: flex;
    align-items: center;
    gap: 5px;
    padding: 6px 10px;
    border: 1px solid var(--listener-border-strong);
    border-radius: var(--listener-radius-full);
    background: transparent;
    color: var(--listener-text-muted);
    font-size: var(--listener-font-size-xs);
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
    line-height: 1;
    font-family: var(--listener-font);
}

.listener-header__btn:hover {
    color: var(--listener-text);
    border-color: var(--listener-text-faint);
    background: var(--listener-bg-elevated);
}

/* --------------------------------------------------------------------------
   Connection Status Dot
   -------------------------------------------------------------------------- */

.listener-status-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--listener-text-faint);
    flex-shrink: 0;
    transition: background 0.3s ease;
    display: none;
}

.listener-status-dot--connected {
    display: block;
    background: var(--listener-success);
    box-shadow: 0 0 6px rgba(34, 197, 94, 0.5);
}

.listener-status-dot--reconnecting {
    display: block;
    background: var(--listener-warning);
    animation: listener-pulse-dot 1.5s ease infinite;
}

.listener-status-dot--disconnected {
    display: block;
    background: var(--listener-danger);
}

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

/* --------------------------------------------------------------------------
   Live Bar
   -------------------------------------------------------------------------- */

#listener-live-bar {
    position: fixed;
    top: calc(var(--listener-header-height) + var(--listener-safe-top));
    left: 0;
    right: 0;
    z-index: 90;
    height: var(--listener-live-bar-height);
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 0 16px;
    background: var(--listener-bg-elevated);
    border-bottom: 1px solid var(--listener-border);
}

.listener-live-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 3px 10px;
    border-radius: var(--listener-radius-full);
    background: rgba(239, 68, 68, 0.15);
    color: var(--listener-live-red);
    font-size: var(--listener-font-size-xs);
    font-weight: 700;
    letter-spacing: 0.08em;
    flex-shrink: 0;
    position: relative;
}

.listener-live-badge::before {
    content: '';
    position: absolute;
    inset: -3px;
    border-radius: var(--listener-radius-full);
    border: 2px solid rgba(239, 68, 68, 0.3);
    animation: listener-live-ring 2s ease-out infinite;
}

@keyframes listener-live-ring {
    0%   { transform: scale(1); opacity: 0.6; }
    100% { transform: scale(1.3); opacity: 0; }
}

.listener-live-badge__dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--listener-live-red);
    animation: listener-pulse-dot 1s ease infinite;
}

/* ── Live Now CTA on landing page ── */
.listener-live-cta {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 20px 24px;
    margin-bottom: 24px;
    border-radius: var(--listener-radius-lg);
    background: linear-gradient(135deg, rgba(239, 68, 68, 0.12) 0%, rgba(239, 68, 68, 0.04) 100%);
    border: 1px solid rgba(239, 68, 68, 0.25);
    text-decoration: none;
    color: inherit;
    transition: all 0.25s ease;
    position: relative;
    overflow: hidden;
}
.listener-live-cta:hover {
    background: linear-gradient(135deg, rgba(239, 68, 68, 0.18) 0%, rgba(239, 68, 68, 0.08) 100%);
    border-color: rgba(239, 68, 68, 0.4);
    transform: translateY(-1px);
    box-shadow: 0 8px 32px rgba(239, 68, 68, 0.15);
    color: inherit;
    text-decoration: none;
}
.listener-live-cta__play {
    flex-shrink: 0;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--listener-live-red);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 0 20px rgba(239, 68, 68, 0.35);
    animation: listener-play-pulse 2s ease-in-out infinite;
}
.listener-live-cta__play svg {
    width: 24px;
    height: 24px;
    fill: #fff;
    margin-left: 3px;
}
@keyframes listener-play-pulse {
    0%, 100% { box-shadow: 0 0 20px rgba(239, 68, 68, 0.35); }
    50% { box-shadow: 0 0 32px rgba(239, 68, 68, 0.55); }
}
.listener-live-cta__content {
    flex: 1;
    min-width: 0;
}
.listener-live-cta__header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 4px;
}
.listener-live-cta .listener-live-badge {
    font-size: 0.8rem;
    padding: 4px 14px;
}
.listener-live-cta__title {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--listener-text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.listener-live-cta__subtitle {
    margin: 0;
    font-size: var(--listener-font-size-sm);
    color: var(--listener-text-muted);
}
.listener-live-cta__arrow {
    flex-shrink: 0;
    color: var(--listener-text-muted);
    transition: transform 0.2s ease;
}
.listener-live-cta:hover .listener-live-cta__arrow {
    transform: translateX(4px);
}
@media (max-width: 480px) {
    .listener-live-cta {
        padding: 16px;
        gap: 12px;
    }
    .listener-live-cta__play {
        width: 48px;
        height: 48px;
    }
    .listener-live-cta__title {
        font-size: 1rem;
    }
}

.listener-live-bar__title {
    font-size: var(--listener-font-size-sm);
    color: var(--listener-text-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 0;
}
.listener-live-bar__actions {
    margin-left: auto;
    display: flex;
    align-items: center;
}
.listener-audio-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 1px solid var(--listener-border);
    background: transparent;
    color: var(--listener-text-muted);
    cursor: pointer;
    transition: all 0.2s ease;
    padding: 0;
}
.listener-audio-toggle:hover {
    background: rgba(255,255,255,0.1);
    color: var(--listener-text-primary);
}
.listener-audio-toggle.is-active {
    background: rgba(245, 158, 11, 0.15);
    border-color: var(--listener-accent);
    color: var(--listener-accent);
}
.listener-audio-toggle .is-playing {
    animation: listener-audio-pulse 1s ease infinite;
}
@keyframes listener-audio-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}

/* --------------------------------------------------------------------------
   Reconnecting Overlay
   -------------------------------------------------------------------------- */

#listener-reconnecting {
    position: fixed;
    bottom: calc(20px + var(--listener-safe-bottom));
    left: 50%;
    transform: translateX(-50%);
    z-index: 200;
}

.listener-reconnecting__inner {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 20px;
    border-radius: var(--listener-radius-full);
    background: var(--listener-bg-card);
    border: 1px solid var(--listener-border-strong);
    box-shadow: var(--listener-shadow-lg);
    font-size: var(--listener-font-size-sm);
    color: var(--listener-text-muted);
    white-space: nowrap;
}

.listener-reconnecting__spinner {
    width: 16px;
    height: 16px;
    border: 2px solid var(--listener-border-strong);
    border-top-color: var(--listener-accent);
    border-radius: 50%;
    animation: listener-spin 0.8s linear infinite;
}

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

/* --------------------------------------------------------------------------
   Main Content Area
   -------------------------------------------------------------------------- */

#listener-main {
    position: fixed;
    top: calc(var(--listener-header-height) + var(--listener-safe-top));
    left: 0;
    right: 0;
    bottom: 0;
    overflow: hidden;
    padding-left: var(--listener-safe-left);
    padding-right: var(--listener-safe-right);
}

#listener-main.has-live-bar {
    top: calc(var(--listener-header-height) + var(--listener-safe-top) + var(--listener-live-bar-height));
}

.listener-page {
    height: 100%;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    scroll-behavior: smooth;
}

/* --------------------------------------------------------------------------
   Discovery Landing — Hero
   -------------------------------------------------------------------------- */

.listener-discovery-hero {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    min-height: 65vh;
    padding: 80px 20px 48px;
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%);
    background-size: cover;
    background-position: center;
    overflow: hidden;
    margin-top: calc(-1 * var(--listener-header-height));
    padding-top: calc(var(--listener-header-height) + 60px);
}

.listener-discovery-hero.has-image {
    min-height: 70vh;
}

.listener-discovery-hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, rgba(0,0,0,0.4) 0%, rgba(0,0,0,0.65) 60%, rgba(10,10,15,0.95) 100%);
    z-index: 1;
}

.listener-discovery-hero__content {
    position: relative;
    z-index: 2;
    max-width: 640px;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.listener-discovery-hero__title {
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: -0.03em;
    line-height: 1.2;
    margin: 0 0 12px;
    color: #fff;
    text-shadow: 0 2px 12px rgba(0,0,0,0.4);
}

.listener-discovery-hero__subtitle {
    font-size: 1rem;
    color: rgba(255,255,255,0.75);
    margin: 0 0 28px;
    max-width: 420px;
    line-height: 1.5;
}

.listener-discovery-hero__nearme {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 16px;
    padding: 10px 24px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,0.25);
    background: rgba(255,255,255,0.08);
    color: rgba(255,255,255,0.9);
    font-size: 0.85rem;
    font-weight: 500;
    cursor: pointer;
    transition: background 0.2s, border-color 0.2s;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}

.listener-discovery-hero__nearme:hover {
    background: rgba(255,255,255,0.15);
    border-color: rgba(255,255,255,0.4);
}

.listener-discovery-hero__credit {
    position: absolute;
    bottom: 8px;
    right: 12px;
    z-index: 2;
    font-size: 0.6rem;
    color: rgba(255,255,255,0.3);
}

.listener-discovery-hero__credit a {
    color: rgba(255,255,255,0.4);
    text-decoration: none;
}

.listener-discovery-hero__credit a:hover {
    color: rgba(255,255,255,0.6);
}

[data-bs-theme="light"] .listener-discovery-hero:not(.has-image) {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 50%, #f093fb 100%);
}

@media (min-width: 768px) {
    .listener-discovery-hero {
        min-height: 60vh;
        padding: 100px 24px 60px;
        padding-top: calc(var(--listener-header-height) + 80px);
    }
    .listener-discovery-hero__title {
        font-size: 3rem;
    }
    .listener-discovery-hero__subtitle {
        font-size: 1.15rem;
    }
}

/* Featured Churches Grid */
.listener-featured-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}

@media (min-width: 640px) {
    .listener-featured-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

.listener-featured-card {
    position: relative;
    display: block;
    border-radius: 12px;
    overflow: hidden;
    min-height: 180px;
    text-decoration: none;
    color: #fff;
    background: linear-gradient(135deg, #1e1e3a 0%, #2a2a4a 100%);
    border: 1px solid var(--listener-border);
    transition: transform 0.2s, box-shadow 0.2s;
}

.listener-featured-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 30px rgba(0,0,0,0.3);
}

.listener-featured-card__bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
}

.listener-featured-card__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.3) 50%, rgba(0,0,0,0.1) 100%);
}

.listener-featured-card__content {
    position: relative;
    z-index: 1;
    padding: 16px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    min-height: 180px;
}

.listener-featured-card__logo {
    height: 36px;
    width: auto;
    max-width: 120px;
    object-fit: contain;
    margin-bottom: 8px;
    filter: drop-shadow(0 1px 4px rgba(0,0,0,0.5));
}

.listener-featured-card__name {
    font-size: 1.25rem;
    font-weight: 700;
    margin: 0 0 4px;
    text-shadow: 0 1px 6px rgba(0,0,0,0.4);
}

.listener-featured-card__location {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 0.8rem;
    color: rgba(255,255,255,0.7);
    margin: 0 0 8px;
}

.listener-featured-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    font-size: 0.7rem;
    color: rgba(255,255,255,0.6);
}

.listener-featured-card__meta span {
    background: rgba(255,255,255,0.1);
    padding: 2px 8px;
    border-radius: 999px;
}

.listener-featured-card__live {
    position: absolute;
    top: 12px;
    right: 12px;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    border-radius: 999px;
    background: rgba(220, 38, 38, 0.9);
    color: #fff;
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.05em;
}

/* Global Sermon Cards */
.listener-sermon-card--global {
    display: block;
    text-decoration: none;
    color: var(--listener-text);
    padding: 14px 16px;
    border-radius: 10px;
    background: var(--listener-bg-card, rgba(255,255,255,0.04));
    border: 1px solid var(--listener-border);
    transition: border-color 0.15s, transform 0.15s;
}

.listener-sermon-card--global:hover {
    border-color: var(--listener-accent);
    transform: translateY(-1px);
}

.listener-sermon-card__header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 8px;
}

.listener-sermon-card__org-logo {
    width: 28px;
    height: 28px;
    border-radius: 6px;
    object-fit: contain;
    flex-shrink: 0;
}

.listener-sermon-card__org-name {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--listener-accent);
}

.listener-sermon-card__header .listener-sermon-card__play-btn {
    margin-left: auto;
}

/* About UnityVerse */
.listener-discovery-about {
    padding: 40px 16px;
    border-top: 1px solid var(--listener-border);
}

.listener-discovery-about__inner {
    max-width: 640px;
    margin: 0 auto;
    text-align: center;
}

.listener-discovery-about__logo {
    height: 80px;
    width: auto;
    margin-bottom: 16px;
}

.listener-discovery-about__title {
    font-size: 1.25rem;
    font-weight: 700;
    margin: 0 0 16px;
    color: var(--listener-text);
}

.listener-discovery-about__text {
    font-size: 0.9rem;
    line-height: 1.7;
    color: var(--listener-text-faint);
    margin: 0 0 12px;
    text-align: left;
}

.listener-discovery-about__text:last-child {
    margin-bottom: 0;
}

/* Discovery Footer CTA */
.listener-discovery-footer {
    text-align: center;
    padding: 32px 16px 48px;
    border-top: 1px solid var(--listener-border);
}

.listener-discovery-footer__heading {
    font-size: 1.1rem;
    font-weight: 700;
    margin: 0 0 8px;
    color: var(--listener-text);
}

.listener-discovery-footer__text {
    font-size: 0.85rem;
    color: var(--listener-text-faint);
    margin: 0 0 20px;
    max-width: 420px;
    margin-left: auto;
    margin-right: auto;
}

.listener-discovery-footer__actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
    margin-bottom: 24px;
}

.listener-discovery-footer__btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    border-radius: 999px;
    font-size: 0.85rem;
    font-weight: 600;
    text-decoration: none;
    transition: transform 0.15s, background 0.15s;
    background: var(--listener-accent);
    color: #fff;
}

.listener-discovery-footer__btn:hover {
    transform: translateY(-1px);
}

.listener-discovery-footer__btn--outline {
    background: transparent;
    border: 1px solid var(--listener-border);
    color: var(--listener-text);
}

.listener-discovery-footer__btn--outline:hover {
    border-color: var(--listener-accent);
    color: var(--listener-accent);
}

.listener-discovery-footer__copyright {
    font-size: 0.7rem;
    color: var(--listener-text-faint);
    opacity: 0.5;
    margin: 0;
}

/* Section subtitle */
.listener-section__subtitle {
    font-size: 0.85rem;
    color: var(--listener-text-faint);
    margin: -8px 0 16px;
}

/* Sermon Quotes Carousel */
.listener-quotes-carousel {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 8px;
    scrollbar-width: none;
}

.listener-quotes-carousel::-webkit-scrollbar {
    display: none;
}

.listener-quote-card {
    flex: 0 0 280px;
    scroll-snap-align: start;
    display: flex;
    flex-direction: column;
    padding: 20px;
    border-radius: 12px;
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.08) 0%, rgba(168, 85, 247, 0.05) 100%);
    border: 1px solid rgba(99, 102, 241, 0.15);
    text-decoration: none;
    color: var(--listener-text);
    transition: transform 0.2s, border-color 0.2s;
    min-height: 160px;
}

.listener-quote-card:hover {
    transform: translateY(-2px);
    border-color: var(--listener-accent);
}

.listener-quote-card__mark {
    font-size: 2.5rem;
    line-height: 1;
    color: var(--listener-accent);
    opacity: 0.4;
    font-family: Georgia, serif;
    margin-bottom: 4px;
}

.listener-quote-card__text {
    font-size: 0.95rem;
    line-height: 1.5;
    font-style: italic;
    color: var(--listener-text);
    margin: 0 0 auto;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.listener-quote-card__source {
    margin-top: 12px;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.listener-quote-card__sermon {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--listener-accent);
}

.listener-quote-card__org {
    font-size: 0.7rem;
    color: var(--listener-text-faint);
}

@media (min-width: 768px) {
    .listener-quote-card {
        flex: 0 0 320px;
    }
}

/* Needs Grid (What Are You Going Through?) */
.listener-needs-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
}

@media (min-width: 480px) {
    .listener-needs-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (min-width: 768px) {
    .listener-needs-grid {
        grid-template-columns: repeat(5, 1fr);
    }
}

.listener-need-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    padding: 16px 8px;
    border-radius: 12px;
    border: 1px solid var(--listener-border);
    background: var(--listener-bg-card, rgba(255,255,255,0.04));
    cursor: pointer;
    transition: transform 0.15s, border-color 0.15s, background 0.15s;
}

.listener-need-card:hover {
    transform: translateY(-2px);
    border-color: var(--listener-accent);
    background: rgba(99, 102, 241, 0.08);
}

.listener-need-card__icon {
    font-size: 1.5rem;
}

.listener-need-card__label {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--listener-text);
}

/* Listener World Map */
.listener-world-map {
    width: 100%;
    height: 220px;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid var(--listener-border);
}

@media (min-width: 768px) {
    .listener-world-map {
        height: 300px;
    }
}

.listener-world-map-locations {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
    justify-content: center;
}

.listener-world-map-loc {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    border-radius: 999px;
    background: var(--listener-bg-card, rgba(255,255,255,0.04));
    border: 1px solid var(--listener-border);
    font-size: 0.75rem;
    color: var(--listener-text);
}

.listener-world-map-loc__cc {
    color: var(--listener-text-faint);
    font-weight: 500;
}

.listener-world-map-loc__count {
    display: inline-block;
    min-width: 18px;
    text-align: center;
    padding: 0 4px;
    border-radius: 999px;
    background: var(--listener-accent);
    color: #fff;
    font-size: 0.65rem;
    font-weight: 700;
}

.listener-search-wrapper {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    max-width: 520px;
}

.listener-search-input-group {
    flex: 1;
    position: relative;
    display: flex;
    align-items: center;
}

.listener-search-icon {
    position: absolute;
    left: 14px;
    color: var(--listener-text-faint);
    pointer-events: none;
    flex-shrink: 0;
}

.listener-search-bar {
    width: 100%;
    padding: 14px 40px 14px 44px;
    border-radius: var(--listener-radius-full);
    border: 1px solid var(--listener-border-strong);
    background: var(--listener-bg-card);
    color: var(--listener-text);
    font-family: var(--listener-font);
    font-size: var(--listener-font-size-base);
    outline: none;
    transition: all 0.2s ease;
}

.listener-search-bar::placeholder {
    color: var(--listener-text-faint);
}

.listener-search-bar:focus {
    border-color: var(--listener-accent);
    box-shadow: 0 0 0 3px var(--listener-accent-glow);
    background: var(--listener-bg-elevated);
}

.listener-search-clear {
    position: absolute;
    right: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border: none;
    border-radius: 50%;
    background: var(--listener-bg-elevated);
    color: var(--listener-text-muted);
    cursor: pointer;
    transition: all 0.15s ease;
}

.listener-search-clear:hover {
    background: var(--listener-border-strong);
    color: var(--listener-text);
}

.listener-btn-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    border: 1px solid var(--listener-border-strong);
    background: var(--listener-bg-card);
    color: var(--listener-text-muted);
    cursor: pointer;
    transition: all 0.2s ease;
    flex-shrink: 0;
}

.listener-btn-icon:hover {
    color: var(--listener-accent);
    border-color: var(--listener-accent);
    background: var(--listener-accent-subtle);
}

/* --------------------------------------------------------------------------
   Discovery Landing — Sections
   -------------------------------------------------------------------------- */

.listener-section {
    padding: 0 16px 24px;
    max-width: 640px;
    margin: 0 auto;
}

.listener-section__title {
    font-size: var(--listener-font-size-lg);
    font-weight: 600;
    margin: 16px 0 12px;
    letter-spacing: -0.01em;
    display: flex;
    align-items: center;
    gap: 8px;
}

.listener-section__live-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--listener-live-red);
    animation: listener-pulse-dot 1s ease infinite;
    flex-shrink: 0;
}

.listener-card-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.listener-card-grid {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

/* --------------------------------------------------------------------------
   Discovery Landing — Broadcasting Card
   -------------------------------------------------------------------------- */

.listener-broadcasting-card {
    padding: 16px;
    border-radius: var(--listener-radius-lg);
    background: linear-gradient(135deg, rgba(239, 68, 68, 0.06), rgba(245, 158, 11, 0.04));
    border: 1px solid rgba(239, 68, 68, 0.15);
    cursor: pointer;
    transition: all 0.25s ease;
    position: relative;
    overflow: hidden;
}

.listener-broadcasting-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--listener-live-red), var(--listener-accent));
    opacity: 0.7;
}

.listener-broadcasting-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(239, 68, 68, 0.12);
    border-color: rgba(239, 68, 68, 0.3);
}

.listener-broadcasting-card__header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
}

.listener-broadcasting-card__logo {
    width: 36px;
    height: 36px;
    border-radius: var(--listener-radius-sm);
    object-fit: cover;
    flex-shrink: 0;
    background: var(--listener-bg-elevated);
}

.listener-broadcasting-card__logo--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    font-weight: 700;
    color: var(--listener-text-faint);
    background: var(--listener-bg-elevated);
    border-radius: var(--listener-radius-sm);
    width: 36px;
    height: 36px;
}

.listener-broadcasting-card__org {
    flex: 1;
    min-width: 0;
}

.listener-broadcasting-card__org-name {
    font-size: var(--listener-font-size-sm);
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.listener-broadcasting-card__location {
    font-size: var(--listener-font-size-xs);
    color: var(--listener-text-muted);
}

.listener-live-badge--sm {
    font-size: 0.625rem;
    padding: 2px 8px;
}

.listener-live-badge--sm::before {
    display: none;
}

.listener-broadcasting-card__title {
    font-size: var(--listener-font-size-base);
    font-weight: 500;
    margin-bottom: 10px;
    line-height: 1.3;
}

.listener-broadcasting-card__footer {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.listener-broadcasting-card__langs {
    display: flex;
    gap: 4px;
}

.listener-listener-count {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: var(--listener-font-size-xs);
    color: var(--listener-text-muted);
}

.listener-broadcasting-card__join {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 6px 16px;
    border-radius: var(--listener-radius-full);
    background: var(--listener-accent);
    color: #000;
    font-size: var(--listener-font-size-sm);
    font-weight: 600;
    margin-top: 10px;
    transition: all 0.2s ease;
}

.listener-broadcasting-card:hover .listener-broadcasting-card__join {
    background: #e8920a;
    box-shadow: 0 4px 12px var(--listener-accent-glow);
}

/* --------------------------------------------------------------------------
   Discovery Landing — Topic Pills
   -------------------------------------------------------------------------- */

.listener-topic-pills {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.listener-topic-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    border-radius: var(--listener-radius-full);
    border: 1px solid var(--listener-border-strong);
    background: var(--listener-bg-card);
    color: var(--listener-text);
    font-family: var(--listener-font);
    font-size: var(--listener-font-size-sm);
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

.listener-topic-pill:hover {
    border-color: var(--listener-accent);
    background: var(--listener-accent-subtle);
    color: var(--listener-accent);
}

.listener-topic-pill__count {
    font-size: var(--listener-font-size-xs);
    color: var(--listener-text-faint);
    font-weight: 400;
}

.listener-topic-pill:hover .listener-topic-pill__count {
    color: var(--listener-accent);
    opacity: 0.7;
}

/* --------------------------------------------------------------------------
   Discovery Landing — History Scroll
   -------------------------------------------------------------------------- */

.listener-history-scroll {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    padding-bottom: 8px;
    scrollbar-width: thin;
}

.listener-history-scroll::-webkit-scrollbar {
    height: 3px;
}

.listener-history-scroll::-webkit-scrollbar-track {
    background: transparent;
}

.listener-history-scroll::-webkit-scrollbar-thumb {
    background: var(--listener-border-strong);
    border-radius: 3px;
}

.listener-history-card {
    display: flex;
    flex-direction: column;
    min-width: 160px;
    max-width: 200px;
    padding: 14px;
    border-radius: var(--listener-radius-md);
    background: var(--listener-bg-card);
    border: 1px solid var(--listener-border);
    text-decoration: none;
    color: var(--listener-text);
    transition: all 0.2s ease;
    scroll-snap-align: start;
    flex-shrink: 0;
}

.listener-history-card:hover {
    background: var(--listener-bg-card-hover);
    border-color: var(--listener-border-strong);
    transform: translateY(-1px);
}

.listener-history-card__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--listener-accent-subtle);
    color: var(--listener-accent);
    margin-bottom: 10px;
}

.listener-history-card__title {
    font-size: var(--listener-font-size-sm);
    font-weight: 600;
    line-height: 1.3;
    margin-bottom: 4px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.listener-history-card__church {
    font-size: var(--listener-font-size-xs);
    color: var(--listener-text-muted);
    margin-bottom: 6px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.listener-history-card__date {
    font-size: 0.625rem;
    color: var(--listener-text-faint);
    font-weight: 500;
}

/* --------------------------------------------------------------------------
   Discovery Landing — Home Church Card
   -------------------------------------------------------------------------- */

.listener-home-church-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px;
    border-radius: var(--listener-radius-md);
    background: var(--listener-bg-card);
    border: 1px solid var(--listener-border);
    text-decoration: none;
    color: var(--listener-text);
    transition: all 0.2s ease;
}

.listener-home-church-card:hover {
    background: var(--listener-bg-card-hover);
    border-color: var(--listener-border-strong);
}

.listener-home-church-card__info {
    flex: 1;
    min-width: 0;
}

.listener-home-church-card__name {
    font-size: var(--listener-font-size-base);
    font-weight: 600;
    margin-bottom: 2px;
}

.listener-home-church-card__meta {
    font-size: var(--listener-font-size-xs);
    color: var(--listener-text-muted);
}

.listener-btn--sm {
    padding: 8px 16px;
    font-size: var(--listener-font-size-sm);
    margin-top: 10px;
}

/* --------------------------------------------------------------------------
   Near Me Page
   -------------------------------------------------------------------------- */

.listener-nearme-hero {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 48px 24px 32px;
}

.listener-nearme-hero__title {
    font-size: var(--listener-font-size-3xl);
    font-weight: 700;
    letter-spacing: -0.03em;
    margin: 0 0 8px;
}

.listener-nearme-hero__subtitle {
    font-size: var(--listener-font-size-lg);
    color: var(--listener-text-muted);
    margin: 0 0 32px;
    max-width: 360px;
}

.listener-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px;
    border-radius: var(--listener-radius-full);
    border: none;
    font-family: var(--listener-font);
    font-size: var(--listener-font-size-base);
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
    text-decoration: none;
}

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

.listener-btn--primary:hover {
    background: #e8920a;
    transform: translateY(-1px);
    box-shadow: 0 4px 16px var(--listener-accent-glow);
}

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

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

.listener-nearme-loading {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 24px;
    font-size: var(--listener-font-size-sm);
    color: var(--listener-text-muted);
}

.listener-nearme-error {
    margin-top: 16px;
    padding: 12px 20px;
    border-radius: var(--listener-radius-md);
    background: rgba(239, 68, 68, 0.1);
    color: var(--listener-danger);
    font-size: var(--listener-font-size-sm);
}

.listener-nearme-results {
    padding: 0 16px 32px;
    max-width: 640px;
    margin: 0 auto;
}

/* Church card */
.listener-church-card {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 16px;
    margin-bottom: 8px;
    border-radius: var(--listener-radius-md);
    background: var(--listener-bg-card);
    border: 1px solid var(--listener-border);
    text-decoration: none;
    color: var(--listener-text);
    transition: all 0.2s ease;
    cursor: pointer;
}

.listener-church-card:hover {
    background: var(--listener-bg-card-hover);
    border-color: var(--listener-border-strong);
    transform: translateY(-1px);
    box-shadow: var(--listener-shadow-md);
}

.listener-church-card__logo {
    width: 44px;
    height: 44px;
    border-radius: var(--listener-radius-sm);
    object-fit: cover;
    flex-shrink: 0;
    background: var(--listener-bg-elevated);
}

.listener-church-card__logo--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--listener-text-faint);
    background: var(--listener-bg-elevated);
}

.listener-church-card__body {
    flex: 1;
    min-width: 0;
}

.listener-church-card__name {
    font-size: var(--listener-font-size-base);
    font-weight: 600;
    margin: 0 0 2px;
    letter-spacing: -0.01em;
}

.listener-church-card__location {
    font-size: var(--listener-font-size-xs);
    color: var(--listener-text-muted);
    margin: 0 0 6px;
}

.listener-church-card__meta {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.listener-church-card__distance {
    font-size: var(--listener-font-size-xs);
    color: var(--listener-text-faint);
}

.listener-church-card__live-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    border-radius: var(--listener-radius-full);
    background: rgba(239, 68, 68, 0.15);
    color: var(--listener-live-red);
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.listener-church-card__live-dot {
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: var(--listener-live-red);
    animation: listener-pulse-dot 1s ease infinite;
}

.listener-church-card__langs {
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
}

.listener-lang-chip {
    padding: 1px 6px;
    border-radius: var(--listener-radius-full);
    background: var(--listener-accent-subtle);
    color: var(--listener-accent);
    font-size: 0.625rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

/* --------------------------------------------------------------------------
   Landing Page
   -------------------------------------------------------------------------- */

/* -- Hero Banner -- */

.listener-hero-banner {
    position: relative;
    padding: 80px 20px 60px;
    text-align: center;
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%);
    background-size: cover;
    background-position: center;
    overflow: hidden;
    margin-top: calc(-1 * var(--listener-header-height));
    padding-top: calc(var(--listener-header-height) + 60px);
}

[data-bs-theme="light"] .listener-hero-banner:not(.has-cover) {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 50%, #f093fb 100%);
}

.listener-hero-banner.has-cover {
    padding: 100px 20px 80px;
    padding-top: calc(var(--listener-header-height) + 80px);
}

.listener-hero-banner__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to bottom,
        rgba(0, 0, 0, 0.3) 0%,
        rgba(0, 0, 0, 0.5) 50%,
        rgba(0, 0, 0, 0.75) 100%
    );
    z-index: 1;
}

.listener-hero-banner:not(.has-cover) .listener-hero-banner__overlay {
    background: linear-gradient(
        to bottom,
        rgba(0, 0, 0, 0) 0%,
        rgba(0, 0, 0, 0.25) 100%
    );
}

.listener-hero-banner__content {
    position: relative;
    z-index: 2;
    max-width: 640px;
    margin: 0 auto;
}

.listener-hero-banner__logo {
    height: 60px;
    width: auto;
    max-width: 200px;
    object-fit: contain;
    margin-bottom: 16px;
    filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.4));
}

.listener-hero-banner__name {
    font-size: 2rem;
    font-weight: 700;
    color: #ffffff;
    margin: 0 0 8px;
    letter-spacing: -0.02em;
    line-height: 1.2;
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.listener-hero-banner__tagline {
    font-size: var(--listener-font-size-lg);
    color: rgba(255, 255, 255, 0.85);
    margin: 0 0 12px;
    font-weight: 400;
    letter-spacing: 0.02em;
}

.listener-hero-banner__location {
    font-size: var(--listener-font-size-sm);
    color: rgba(255, 255, 255, 0.65);
    margin: 0;
}

.listener-hero-banner__location i {
    margin-right: 4px;
}

@media (min-width: 768px) {
    .listener-hero-banner {
        padding: 100px 24px 80px;
        padding-top: calc(var(--listener-header-height) + 80px);
    }

    .listener-hero-banner.has-cover {
        padding: 120px 24px 100px;
        padding-top: calc(var(--listener-header-height) + 100px);
    }

    .listener-hero-banner__logo {
        height: 80px;
        max-width: 260px;
    }

    .listener-hero-banner__name {
        font-size: 2.5rem;
    }
}

/* -- Stats Bar -- */

.listener-landing-stats {
    max-width: 640px;
    margin: 0 auto;
    padding: 0 16px;
    margin-bottom: -8px;
}

.listener-stats-bar {
    display: flex;
    justify-content: center;
    gap: 8px;
    padding: 16px 12px;
    background: var(--listener-bg-elevated);
    border-radius: var(--listener-radius-lg);
    border: 1px solid var(--listener-border);
    margin-top: -28px;
    position: relative;
    z-index: 3;
    box-shadow: var(--listener-shadow-md);
    flex-wrap: wrap;
}

.listener-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    padding: 6px 14px;
    min-width: 70px;
}

.listener-stat i {
    font-size: 1rem;
    color: var(--listener-accent);
    margin-bottom: 2px;
}

.listener-stat__number {
    font-size: var(--listener-font-size-xl);
    font-weight: 700;
    color: var(--listener-text);
    line-height: 1.2;
}

.listener-stat__label {
    font-size: var(--listener-font-size-xs);
    color: var(--listener-text-muted);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

@media (min-width: 768px) {
    .listener-stats-bar {
        gap: 16px;
        padding: 20px 24px;
        margin-top: -32px;
    }

    .listener-stat {
        padding: 8px 20px;
        min-width: 90px;
    }
}

/* -- Shared content wrap -- */

.listener-landing-content-wrap {
    max-width: 640px;
    margin: 0 auto;
    padding: 0 16px;
}

/* -- Live CTA -- */

.listener-landing-live {
    padding: 20px 16px;
    max-width: 640px;
    margin: 0 auto;
}

.listener-live-cta {
    display: block;
    padding: 20px;
    border-radius: var(--listener-radius-lg);
    background: linear-gradient(135deg, rgba(239, 68, 68, 0.12), rgba(245, 158, 11, 0.08));
    border: 1px solid rgba(239, 68, 68, 0.2);
    text-decoration: none;
    color: var(--listener-text);
    transition: all 0.25s ease;
    position: relative;
    overflow: hidden;
}

.listener-live-cta:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(239, 68, 68, 0.15);
    border-color: rgba(239, 68, 68, 0.35);
}

.listener-live-cta__header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 8px;
}

.listener-live-cta__title {
    font-size: var(--listener-font-size-lg);
    font-weight: 600;
    letter-spacing: -0.01em;
}

.listener-live-cta__subtitle {
    font-size: var(--listener-font-size-sm);
    color: var(--listener-text-muted);
    margin: 0;
}

.listener-live-cta__arrow {
    margin-left: auto;
    color: var(--listener-text-faint);
    transition: transform 0.2s ease;
}

.listener-live-cta:hover .listener-live-cta__arrow {
    transform: translateX(4px);
}

/* -- About Section -- */

.listener-landing-about {
    padding-top: 32px;
}

.listener-denomination-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 12px;
    border-radius: var(--listener-radius-full);
    background: var(--listener-accent-subtle);
    color: var(--listener-accent);
    font-size: var(--listener-font-size-xs);
    font-weight: 600;
    margin-bottom: 16px;
}

.listener-about-text {
    line-height: 1.8;
    color: var(--listener-text-muted);
    font-size: var(--listener-font-size-base);
}

.listener-about-text p {
    margin: 0 0 16px;
}

.listener-about-text p:last-child {
    margin-bottom: 0;
}

/* -- Service Times -- */

.listener-landing-services {
    padding-top: 32px;
}

.listener-services-card {
    background: var(--listener-bg-card);
    border: 1px solid var(--listener-border);
    border-radius: var(--listener-radius-lg);
    overflow: hidden;
}

.listener-service-row {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    border-bottom: 1px solid var(--listener-border);
}

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

.listener-service-row__icon {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--listener-accent-subtle);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.listener-service-row__icon i {
    color: var(--listener-accent);
    font-size: 0.875rem;
}

.listener-service-row__name {
    font-weight: 600;
    font-size: var(--listener-font-size-sm);
    color: var(--listener-text);
    line-height: 1.3;
}

.listener-service-row__time {
    font-size: var(--listener-font-size-sm);
    color: var(--listener-text-muted);
}

/* -- Church Topics -- */

.listener-landing-topics-section {
    padding-top: 32px;
}

.listener-church-topics-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.listener-church-topic-pill {
    padding: 6px 14px;
    border-radius: var(--listener-radius-full);
    border: 1px solid;
    font-size: var(--listener-font-size-sm);
    font-weight: 500;
    text-transform: capitalize;
}

/* -- Section Title (shared) -- */

.listener-landing-section {
    padding: 0 16px 32px;
    max-width: 640px;
    margin: 0 auto;
}

.listener-landing-section__title {
    font-size: var(--listener-font-size-lg);
    font-weight: 600;
    margin: 24px 0 16px;
    letter-spacing: -0.01em;
    color: var(--listener-text);
}

.listener-landing-section__title i {
    margin-right: 6px;
    color: var(--listener-accent);
}

/* -- Sermon Filter Bar -- */

.listener-sermon-filter-bar {
    display: flex;
    gap: 6px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 0 0 12px;
    margin-bottom: 4px;
}

.listener-sermon-filter-bar::-webkit-scrollbar {
    display: none;
}

.listener-sermon-filter-pill {
    display: inline-flex;
    align-items: center;
    padding: 6px 14px;
    border-radius: var(--listener-radius-full);
    border: 1px solid var(--listener-border-strong);
    background: transparent;
    color: var(--listener-text-muted);
    font-family: var(--listener-font);
    font-size: var(--listener-font-size-xs);
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
    white-space: nowrap;
    flex-shrink: 0;
    text-transform: capitalize;
}

.listener-sermon-filter-pill:hover {
    border-color: var(--listener-accent);
    color: var(--listener-accent);
    background: var(--listener-accent-subtle);
}

.listener-sermon-filter-pill.active {
    background: var(--listener-accent);
    color: #000;
    border-color: var(--listener-accent);
    font-weight: 600;
}

/* -- Sermon Search -- */

.listener-sermon-search-wrap {
    margin-bottom: 12px;
}

.listener-sermon-search-group {
    position: relative;
    display: flex;
    align-items: center;
}

.listener-sermon-search-icon {
    position: absolute;
    left: 12px;
    color: var(--listener-text-faint);
    pointer-events: none;
}

.listener-sermon-search-input {
    width: 100%;
    padding: 10px 36px 10px 36px;
    border-radius: var(--listener-radius-full);
    border: 1px solid var(--listener-border);
    background: var(--listener-bg-card);
    color: var(--listener-text);
    font-family: var(--listener-font);
    font-size: var(--listener-font-size-sm);
    outline: none;
    transition: all 0.2s ease;
}

.listener-sermon-search-input::placeholder {
    color: var(--listener-text-faint);
}

.listener-sermon-search-input:focus {
    border-color: var(--listener-accent);
    box-shadow: 0 0 0 2px var(--listener-accent-glow);
    background: var(--listener-bg-elevated);
}

.listener-sermon-search-clear {
    position: absolute;
    right: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    border: none;
    border-radius: 50%;
    background: var(--listener-bg-elevated);
    color: var(--listener-text-muted);
    cursor: pointer;
    transition: all 0.15s ease;
}

.listener-sermon-search-clear:hover {
    background: var(--listener-border-strong);
    color: var(--listener-text);
}

.listener-sermon-empty-filter {
    text-align: center;
    padding: 32px 16px;
    color: var(--listener-text-faint);
    font-size: var(--listener-font-size-sm);
}

/* -- Sermon Grid + Cards (Enhanced) -- */

.listener-sermon-grid {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.listener-sermon-card {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 14px 16px;
    border-radius: var(--listener-radius-md);
    background: var(--listener-bg-card);
    border: 1px solid var(--listener-border);
    border-left: 3px solid var(--listener-accent);
    color: var(--listener-text);
    transition: all 0.25s ease;
    position: relative;
}

.listener-sermon-card:hover {
    background: var(--listener-bg-card-hover);
    border-color: var(--listener-border-strong);
    transform: translateY(-1px);
    box-shadow: var(--listener-shadow-md);
}

.listener-sermon-card__play-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    min-width: 40px;
    border-radius: 50%;
    border: none;
    background: var(--listener-accent);
    color: #000;
    cursor: pointer;
    transition: all 0.2s ease;
    flex-shrink: 0;
    margin-top: 2px;
    position: relative;
}

.listener-sermon-card__play-btn:hover {
    transform: scale(1.1);
    box-shadow: 0 4px 12px var(--listener-accent-glow);
}

.listener-sermon-card__play-btn .listener-sermon-card__pause-icon {
    display: none;
}

.listener-sermon-card__play-btn.is-playing .listener-sermon-card__play-icon {
    display: none;
}

.listener-sermon-card__play-btn.is-playing .listener-sermon-card__pause-icon {
    display: block;
}

.listener-sermon-card__content {
    flex: 1;
    min-width: 0;
    text-decoration: none;
    color: inherit;
    display: block;
}

.listener-sermon-card__content:hover {
    color: inherit;
}

.listener-sermon-card__header-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 4px;
}

.listener-sermon-card__date {
    font-size: var(--listener-font-size-xs);
    color: var(--listener-text-faint);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.listener-sermon-card__title {
    font-size: var(--listener-font-size-base);
    font-weight: 600;
    margin: 0 0 4px;
    letter-spacing: -0.01em;
    line-height: 1.3;
}

.listener-sermon-card__summary {
    font-size: var(--listener-font-size-sm);
    color: var(--listener-text-muted);
    margin: 0 0 8px;
    line-height: 1.5;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.listener-sermon-card__topics {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 4px;
}

.listener-sermon-card__topic {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 0.65rem;
    font-weight: 500;
    letter-spacing: 0.02em;
    color: var(--listener-accent);
    background: rgba(99, 102, 241, 0.1);
    border: 1px solid rgba(99, 102, 241, 0.15);
}

.listener-sermon-card__topic::before {
    content: '#';
    opacity: 0.5;
    margin-right: 1px;
}

.listener-sermon-card__footer-row {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.listener-sermon-card__badges {
    display: flex;
    gap: 5px;
    flex-wrap: wrap;
}

.listener-topic-badge {
    padding: 2px 10px;
    border-radius: var(--listener-radius-full);
    background: var(--listener-accent-subtle);
    color: var(--listener-accent);
    font-size: var(--listener-font-size-xs);
    font-weight: 500;
    text-transform: capitalize;
}

.listener-sermon-card__scriptures {
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
}

.listener-scripture-badge {
    padding: 2px 8px;
    border-radius: var(--listener-radius-full);
    background: rgba(99, 102, 241, 0.08);
    color: #818cf8;
    font-size: var(--listener-font-size-xs);
    font-weight: 500;
}

[data-bs-theme="light"] .listener-scripture-badge {
    background: rgba(99, 102, 241, 0.08);
    color: #6366f1;
}

.listener-sermon-card__meta {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 6px;
}

.listener-sermon-card__meta-item {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: var(--listener-font-size-xs);
    color: var(--listener-text-faint);
}

.listener-sermon-card__meta-item svg {
    flex-shrink: 0;
}

/* --------------------------------------------------------------------------
   Mini Audio Player (fixed bottom bar)
   -------------------------------------------------------------------------- */

.listener-mini-player {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 150;
    background: var(--listener-bg-elevated);
    border-top: 1px solid var(--listener-border);
    -webkit-backdrop-filter: saturate(180%) blur(20px);
    backdrop-filter: saturate(180%) blur(20px);
    cursor: pointer;
    padding-bottom: var(--listener-safe-bottom);
}

.listener-mini-player__progress {
    position: absolute;
    top: 0;
    left: 0;
    height: 2px;
    background: var(--listener-accent);
    width: 0;
    transition: width 0.3s linear;
    z-index: 1;
}

.listener-mini-player__inner {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 16px;
    max-width: 1200px;
    margin: 0 auto;
}

.listener-mini-player__play {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    min-width: 36px;
    border-radius: 50%;
    border: none;
    background: var(--listener-accent);
    color: #000;
    cursor: pointer;
    transition: all 0.2s ease;
    flex-shrink: 0;
}

.listener-mini-player__play:hover {
    transform: scale(1.05);
}

.listener-mini-player__info {
    flex: 1;
    min-width: 0;
}

.listener-mini-player__title {
    font-size: var(--listener-font-size-sm);
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.3;
}

.listener-mini-player__time {
    font-size: var(--listener-font-size-xs);
    color: var(--listener-text-faint);
    margin-top: 1px;
}

.listener-mini-player__close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border: none;
    border-radius: 50%;
    background: transparent;
    color: var(--listener-text-muted);
    cursor: pointer;
    transition: all 0.15s ease;
    flex-shrink: 0;
}

.listener-mini-player__close:hover {
    color: var(--listener-text);
    background: var(--listener-bg-card);
}

/* Body padding when mini player visible */
body.has-mini-player .listener-page {
    padding-bottom: 64px;
}

/* --------------------------------------------------------------------------
   Expanded Audio Player
   -------------------------------------------------------------------------- */

.listener-expanded-player {
    position: fixed;
    inset: 0;
    z-index: 200;
    background: var(--listener-bg);
    opacity: 0;
    transform: translateY(100%);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    overflow-y: auto;
}

.listener-expanded-player.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.listener-expanded-player__inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 24px 24px calc(24px + var(--listener-safe-bottom));
    max-width: 480px;
    margin: 0 auto;
    min-height: 100%;
    justify-content: center;
    gap: 20px;
}

.listener-expanded-player__collapse {
    position: absolute;
    top: calc(var(--listener-header-height) + var(--listener-safe-top) + 8px);
    left: 50%;
    transform: translateX(-50%);
    z-index: 210;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 32px;
    border: none;
    border-radius: var(--listener-radius-full);
    background: var(--listener-bg-card);
    color: var(--listener-text-muted);
    cursor: pointer;
    transition: all 0.15s ease;
}

.listener-expanded-player__collapse:hover {
    background: var(--listener-bg-card-hover);
    color: var(--listener-text);
}

.listener-expanded-player__art {
    width: 180px;
    height: 180px;
    border-radius: var(--listener-radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--listener-bg-card);
    box-shadow: var(--listener-shadow-lg);
}

.listener-expanded-player__title {
    font-size: var(--listener-font-size-xl);
    font-weight: 700;
    text-align: center;
    margin: 0;
    letter-spacing: -0.02em;
    line-height: 1.3;
}

.listener-expanded-player__date {
    font-size: var(--listener-font-size-sm);
    color: var(--listener-text-muted);
}

.listener-expanded-player__seek {
    width: 100%;
}

.listener-expanded-player__range {
    width: 100%;
    height: 4px;
    -webkit-appearance: none;
    appearance: none;
    background: var(--listener-border-strong);
    border-radius: 2px;
    outline: none;
    cursor: pointer;
}

.listener-expanded-player__range::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--listener-accent);
    cursor: pointer;
    border: none;
    box-shadow: 0 1px 4px rgba(0,0,0,0.3);
}

.listener-expanded-player__range::-moz-range-thumb {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--listener-accent);
    cursor: pointer;
    border: none;
}

.listener-expanded-player__times {
    display: flex;
    justify-content: space-between;
    font-size: var(--listener-font-size-xs);
    color: var(--listener-text-faint);
    margin-top: 6px;
}

.listener-expanded-player__controls {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 28px;
}

.listener-expanded-player__skip {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border: none;
    border-radius: 50%;
    background: transparent;
    color: var(--listener-text-muted);
    cursor: pointer;
    transition: all 0.15s ease;
    position: relative;
}

.listener-expanded-player__skip:hover {
    color: var(--listener-text);
    background: var(--listener-bg-card);
}

.listener-expanded-player__skip-label {
    position: absolute;
    font-size: 0.5rem;
    font-weight: 700;
    bottom: 6px;
}

.listener-expanded-player__play-lg {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    border-radius: 50%;
    border: none;
    background: var(--listener-accent);
    color: #000;
    cursor: pointer;
    transition: all 0.2s ease;
}

.listener-expanded-player__play-lg:hover {
    transform: scale(1.05);
    box-shadow: 0 8px 24px var(--listener-accent-glow);
}

.listener-expanded-player__speed {
    display: flex;
    gap: 8px;
}

.listener-expanded-player__speed-btn {
    padding: 6px 14px;
    border-radius: var(--listener-radius-full);
    border: 1px solid var(--listener-border-strong);
    background: transparent;
    color: var(--listener-text-muted);
    font-family: var(--listener-font);
    font-size: var(--listener-font-size-xs);
    font-weight: 500;
    cursor: pointer;
    transition: all 0.15s ease;
}

.listener-expanded-player__speed-btn:hover {
    border-color: var(--listener-accent);
    color: var(--listener-accent);
}

.listener-expanded-player__speed-btn.active {
    background: var(--listener-accent);
    color: #000;
    border-color: var(--listener-accent);
    font-weight: 600;
}

.listener-expanded-player__read-along {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    border-radius: var(--listener-radius-full);
    background: var(--listener-bg-card);
    border: 1px solid var(--listener-border-strong);
    color: var(--listener-text);
    text-decoration: none;
    font-size: var(--listener-font-size-sm);
    font-weight: 500;
    transition: all 0.2s ease;
}

.listener-expanded-player__read-along:hover {
    background: var(--listener-bg-card-hover);
    border-color: var(--listener-accent);
    color: var(--listener-accent);
}

/* -- FAQs Accordion -- */

.listener-landing-faqs {
    padding-top: 32px;
}

.listener-faq-list {
    border-radius: var(--listener-radius-lg);
    background: var(--listener-bg-card);
    border: 1px solid var(--listener-border);
    overflow: hidden;
}

.listener-faq-item {
    border-bottom: 1px solid var(--listener-border);
}

.listener-faq-item:last-child {
    border-bottom: none;
}

.listener-faq-question {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 16px 18px;
    background: none;
    border: none;
    color: var(--listener-text);
    font-size: var(--listener-font-size-base);
    font-weight: 600;
    text-align: left;
    cursor: pointer;
    gap: 12px;
    transition: background 0.2s ease;
    font-family: var(--listener-font);
}

.listener-faq-question:hover {
    background: var(--listener-bg-card-hover);
}

.listener-faq-chevron {
    font-size: 0.75rem;
    color: var(--listener-text-faint);
    transition: transform 0.3s ease;
    flex-shrink: 0;
}

.listener-faq-question.open .listener-faq-chevron {
    transform: rotate(180deg);
}

.listener-faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.35s ease, padding 0.35s ease;
    padding: 0 18px;
}

.listener-faq-answer.open {
    max-height: 300px;
    padding: 0 18px 16px;
}

.listener-faq-answer p {
    margin: 0;
    font-size: var(--listener-font-size-sm);
    color: var(--listener-text-muted);
    line-height: 1.7;
}

/* -- Social Links -- */

.listener-landing-social {
    padding-top: 32px;
}

.listener-social-icons {
    display: flex;
    gap: 12px;
    justify-content: center;
    margin-bottom: 16px;
}

.listener-social-icon {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    color: #ffffff;
    font-size: 1.1rem;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.listener-social-icon:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
    color: #ffffff;
}

.listener-social-icon--facebook {
    background: #1877f2;
}

.listener-social-icon--instagram {
    background: linear-gradient(135deg, #833ab4, #fd1d1d, #fcb045);
}

.listener-social-icon--youtube {
    background: #ff0000;
}

.listener-website-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 24px;
    border-radius: var(--listener-radius-full);
    background: var(--listener-bg-card);
    border: 1px solid var(--listener-border-strong);
    color: var(--listener-text);
    text-decoration: none;
    font-size: var(--listener-font-size-sm);
    font-weight: 500;
    transition: all 0.2s ease;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    max-width: 200px;
}

.listener-website-btn:hover {
    background: var(--listener-bg-card-hover);
    color: var(--listener-accent);
    border-color: var(--listener-accent);
}

/* -- Footer CTAs -- */

.listener-landing-footer-cta {
    padding: 32px 0 48px;
}

.listener-footer-ctas {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
}

.listener-cta-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px;
    border-radius: var(--listener-radius-full);
    font-size: var(--listener-font-size-sm);
    font-weight: 600;
    text-decoration: none;
    border: none;
    cursor: pointer;
    transition: all 0.25s ease;
    font-family: var(--listener-font);
}

.listener-cta-btn--podcast {
    background: var(--listener-accent);
    color: #000000;
}

.listener-cta-btn--podcast:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 16px var(--listener-accent-glow);
    color: #000000;
}

.listener-cta-btn--share {
    background: var(--listener-bg-card);
    color: var(--listener-text);
    border: 1px solid var(--listener-border-strong);
}

.listener-cta-btn--share:hover {
    background: var(--listener-bg-card-hover);
    transform: translateY(-1px);
}

/* --------------------------------------------------------------------------
   Language Selector
   -------------------------------------------------------------------------- */

.listener-lang-selector {
    position: absolute;
    inset: 0;
    z-index: 50;
    background: var(--listener-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.listener-lang-selector__inner {
    width: 100%;
    max-width: 480px;
    padding: 32px 24px;
    text-align: center;
}

.listener-lang-selector__title {
    font-size: var(--listener-font-size-2xl);
    font-weight: 700;
    letter-spacing: -0.03em;
    margin: 0 0 8px;
}

.listener-lang-selector__subtitle {
    font-size: var(--listener-font-size-base);
    color: var(--listener-text-muted);
    margin: 0 0 32px;
}

.listener-lang-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 10px;
    margin-bottom: 24px;
}

.listener-lang-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 20px 12px;
    border-radius: var(--listener-radius-md);
    background: var(--listener-bg-card);
    border: 2px solid var(--listener-border);
    cursor: pointer;
    transition: all 0.2s ease;
    text-align: center;
}

.listener-lang-card:hover {
    border-color: var(--listener-accent);
    background: var(--listener-bg-card-hover);
    transform: translateY(-2px);
    box-shadow: var(--listener-shadow-md);
}

.listener-lang-card__flag {
    font-size: 2rem;
    line-height: 1;
}

.listener-lang-card__name {
    font-size: var(--listener-font-size-sm);
    font-weight: 600;
    color: var(--listener-text);
}

.listener-lang-card__native {
    font-size: var(--listener-font-size-xs);
    color: var(--listener-text-muted);
    margin-top: -4px;
}

.listener-lang-original-btn {
    display: inline-block;
    padding: 10px 20px;
    border: 1px solid var(--listener-border-strong);
    border-radius: var(--listener-radius-full);
    background: transparent;
    color: var(--listener-text-muted);
    font-family: var(--listener-font);
    font-size: var(--listener-font-size-sm);
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

.listener-lang-original-btn:hover {
    color: var(--listener-text);
    border-color: var(--listener-text-faint);
}

/* --------------------------------------------------------------------------
   Mobile Tabs (Event View, < 768px)
   -------------------------------------------------------------------------- */

.listener-mobile-tabs {
    display: flex;
    padding: 4px;
    margin: 8px 16px;
    background: var(--listener-bg-elevated);
    border-radius: var(--listener-radius-full);
    border: 1px solid var(--listener-border);
}

.listener-mobile-tab {
    flex: 1;
    padding: 8px;
    border: none;
    border-radius: var(--listener-radius-full);
    background: transparent;
    color: var(--listener-text-muted);
    font-family: var(--listener-font);
    font-size: var(--listener-font-size-sm);
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

.listener-mobile-tab.active {
    background: var(--listener-bg-card);
    color: var(--listener-text);
    box-shadow: var(--listener-shadow-sm);
}

/* --------------------------------------------------------------------------
   Transcript Panels
   -------------------------------------------------------------------------- */

.listener-panels {
    display: flex;
    height: 100%;
    gap: 0;
}

.listener-panel {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-width: 0;
    height: 100%;
    position: relative;
}

.listener-panel + .listener-panel {
    border-left: 1px solid var(--listener-border);
}

.listener-panel__label {
    padding: 8px 20px;
    font-size: var(--listener-font-size-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--listener-text-faint);
    background: var(--listener-bg-elevated);
    border-bottom: 1px solid var(--listener-border);
    flex-shrink: 0;
}

.listener-transcript {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    padding: 16px 20px;
    padding-bottom: calc(40vh + var(--listener-safe-bottom));
    scroll-behavior: smooth;
}

/* Transcript segments */
.listener-segment {
    margin-bottom: 12px;
    animation: listener-segment-in 0.4s ease;
}

@keyframes listener-segment-in {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

.listener-segment__speaker {
    font-size: var(--listener-font-size-xs);
    font-weight: 600;
    color: var(--listener-accent);
    margin-bottom: 2px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.listener-segment__text {
    font-size: var(--listener-transcript-size);
    line-height: var(--listener-line-height);
    color: var(--listener-text);
    word-wrap: break-word;
}

.listener-segment__text--translation {
    font-size: var(--listener-translation-size);
    color: var(--listener-translation);
}

.listener-segment__time {
    font-size: 0.625rem;
    color: var(--listener-text-faint);
    margin-top: 2px;
}

/* Word reveal animation */
.listener-word {
    display: inline;
    animation: listener-word-in 0.3s ease;
}

@keyframes listener-word-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}

/* --------------------------------------------------------------------------
   Verse Overlay
   -------------------------------------------------------------------------- */

.listener-verse-overlay {
    position: fixed;
    bottom: calc(24px + var(--listener-safe-bottom));
    left: 16px;
    right: 16px;
    z-index: 80;
    max-width: 560px;
    margin: 0 auto;
    padding: 16px 20px;
    border-radius: var(--listener-radius-lg);
    background: var(--listener-verse-bg);
    border: 1px solid var(--listener-verse-border);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    animation: listener-verse-in 0.4s ease;
    box-shadow: var(--listener-shadow-lg);
}

@keyframes listener-verse-in {
    from { opacity: 0; transform: translateY(16px) scale(0.96); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

.listener-verse-overlay__ref {
    font-size: var(--listener-font-size-sm);
    font-weight: 700;
    color: var(--listener-accent);
    margin-bottom: 6px;
    letter-spacing: 0.02em;
}

.listener-verse-overlay__text {
    font-size: var(--listener-font-size-base);
    line-height: 1.6;
    color: var(--listener-text);
    font-style: italic;
}

/* --------------------------------------------------------------------------
   Archive Bar & Sections
   -------------------------------------------------------------------------- */

.listener-archive-bar {
    border-bottom: 1px solid var(--listener-border);
    background: var(--listener-bg-elevated);
}

.listener-archive-bar__inner {
    display: flex;
    padding: 0 16px;
    gap: 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.listener-archive-tab {
    padding: 12px 16px;
    border: none;
    border-bottom: 2px solid transparent;
    background: transparent;
    color: var(--listener-text-muted);
    font-family: var(--listener-font);
    font-size: var(--listener-font-size-sm);
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
    white-space: nowrap;
    flex-shrink: 0;
}

.listener-archive-tab.active {
    color: var(--listener-text);
    border-bottom-color: var(--listener-accent);
}

.listener-archive-tab:hover {
    color: var(--listener-text);
}

.listener-summary-section,
.listener-audio-section {
    padding: 24px 20px;
    padding-bottom: calc(32px + var(--listener-safe-bottom));
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.listener-summary-content {
    font-size: var(--listener-font-size-lg);
    line-height: 1.8;
    color: var(--listener-text);
    margin-bottom: 24px;
    max-width: 640px;
}

.listener-scriptures-content {
    margin-bottom: 24px;
}

.listener-scripture-item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    margin: 0 6px 6px 0;
    border-radius: var(--listener-radius-full);
    background: var(--listener-verse-bg);
    border: 1px solid var(--listener-verse-border);
    font-size: var(--listener-font-size-sm);
    color: var(--listener-accent);
    font-weight: 500;
}

.listener-topics-content {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.listener-audio-section audio {
    width: 100%;
    max-width: 480px;
    border-radius: var(--listener-radius-md);
}

/* --------------------------------------------------------------------------
   Empty State
   -------------------------------------------------------------------------- */

.listener-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 64px 24px;
    color: var(--listener-text-muted);
    gap: 12px;
}

.listener-empty h2 {
    font-size: var(--listener-font-size-xl);
    font-weight: 600;
    color: var(--listener-text);
    margin: 0;
}

.listener-empty p {
    margin: 0;
    max-width: 320px;
}

/* --------------------------------------------------------------------------
   Toast Notifications
   -------------------------------------------------------------------------- */

.listener-toast-container {
    position: fixed;
    bottom: calc(24px + var(--listener-safe-bottom));
    left: 50%;
    transform: translateX(-50%);
    z-index: 300;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    pointer-events: none;
}

.listener-toast {
    padding: 10px 20px;
    border-radius: var(--listener-radius-full);
    background: var(--listener-bg-card);
    border: 1px solid var(--listener-border-strong);
    color: var(--listener-text);
    font-size: var(--listener-font-size-sm);
    box-shadow: var(--listener-shadow-lg);
    animation: listener-toast-in 0.3s ease, listener-toast-out 0.3s ease 3.7s forwards;
    pointer-events: auto;
    white-space: nowrap;
}

.listener-toast--success { border-color: rgba(34, 197, 94, 0.3); }
.listener-toast--danger  { border-color: rgba(239, 68, 68, 0.3); }
.listener-toast--warning { border-color: rgba(245, 158, 11, 0.3); }

@keyframes listener-toast-in {
    from { opacity: 0; transform: translateY(12px); }
    to   { opacity: 1; transform: translateY(0); }
}

@keyframes listener-toast-out {
    from { opacity: 1; }
    to   { opacity: 0; transform: translateY(-8px); }
}

/* --------------------------------------------------------------------------
   Responsive — Desktop (>= 768px)
   -------------------------------------------------------------------------- */

@media (min-width: 768px) {
    .listener-header__org {
        max-width: 300px;
        font-size: var(--listener-font-size-base);
    }

    .listener-panels {
        display: flex;
    }

    .listener-panel {
        flex: 1;
    }

    .listener-mobile-tabs {
        display: none !important;
    }

    .listener-nearme-hero {
        padding: 72px 24px 40px;
    }

    .listener-nearme-hero__title {
        font-size: 2.5rem;
    }

    .listener-hero {
        padding: 52px 24px 32px;
    }

    .listener-hero__title {
        font-size: 2.5rem;
    }

    .listener-section {
        max-width: 720px;
    }

    .listener-card-grid {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
        gap: 12px;
    }

    .listener-history-card {
        min-width: 190px;
        max-width: 220px;
    }

    .listener-transcript {
        padding: 20px 32px;
    }

    /* Single-panel desktop: center the transcript for readability */
    .listener-panel:only-child .listener-transcript,
    .listener-panel + .listener-panel[style*="display: none"] ~ .listener-panel:first-child .listener-transcript {
        max-width: 800px;
        margin-left: auto;
        margin-right: auto;
    }

    /* When translation panel is hidden, center the original */
    .listener-transcript--centered {
        max-width: 800px;
        margin-left: auto;
        margin-right: auto;
    }

    .listener-segment__text {
        font-size: 1.25rem;
    }

    .listener-segment__text--translation {
        font-size: 1.375rem;
    }
}

/* Mobile: single panel at a time */
@media (max-width: 767.98px) {
    .listener-panels {
        display: block;
        position: relative;
    }

    .listener-panel {
        position: absolute;
        inset: 0;
        height: 100%;
    }

    .listener-panel + .listener-panel {
        border-left: none;
    }

    .listener-panel.hidden-mobile {
        display: none;
    }

    #listener-panels.has-mobile-tabs {
        top: 48px;
    }
}

/* --------------------------------------------------------------------------
   Reduced Motion
   -------------------------------------------------------------------------- */

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }

    .listener-transcript {
        scroll-behavior: auto;
    }

    #listener-particles {
        display: none;
    }
}

/* --------------------------------------------------------------------------
   Globe Map (Landing — near hero, zoomed out)
   -------------------------------------------------------------------------- */

.listener-landing-globe {
    position: relative;
    width: 100%;
    height: 140px;
    overflow: hidden;
    border-bottom: 1px solid var(--listener-border);
}

.listener-globe-label {
    position: absolute;
    bottom: 8px;
    left: 12px;
    z-index: 500;
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 3px 10px;
    border-radius: 999px;
    background: rgba(0,0,0,0.6);
    color: #fff;
    font-size: 0.75rem;
    font-weight: 500;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}

.listener-globe-link {
    position: absolute;
    bottom: 8px;
    right: 12px;
    z-index: 500;
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 3px 10px;
    border-radius: 999px;
    background: rgba(0,0,0,0.6);
    color: rgba(255,255,255,0.8);
    font-size: 0.7rem;
    font-weight: 500;
    text-decoration: none;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    transition: color 0.15s;
}

.listener-globe-link:hover {
    color: #fff;
}

@media (min-width: 768px) {
    .listener-landing-globe {
        height: 180px;
    }
}

/* --------------------------------------------------------------------------
   Location Map (Landing — near bottom, zoomed in)
   -------------------------------------------------------------------------- */

.listener-landing-map {
    width: 100%;
    height: 200px;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid var(--listener-border);
}

.listener-landing-map-label {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    margin-top: 0.5rem;
    font-size: 0.85rem;
    color: var(--listener-text-faint);
    justify-content: center;
}

.listener-map-popup .leaflet-popup-content-wrapper {
    background: var(--listener-bg-elevated, #1a1a2e);
    color: var(--listener-text, #fff);
    border-radius: 8px;
    box-shadow: 0 4px 16px rgba(0,0,0,0.3);
    font-size: 0.8rem;
}

.listener-map-popup .leaflet-popup-tip {
    background: var(--listener-bg-elevated, #1a1a2e);
}

@media (min-width: 768px) {
    .listener-landing-map {
        height: 250px;
    }
}

/* --------------------------------------------------------------------------
   Scrollbar styling (Webkit)
   -------------------------------------------------------------------------- */

.listener-transcript::-webkit-scrollbar,
.listener-page::-webkit-scrollbar {
    width: 4px;
}

.listener-transcript::-webkit-scrollbar-track,
.listener-page::-webkit-scrollbar-track {
    background: transparent;
}

.listener-transcript::-webkit-scrollbar-thumb,
.listener-page::-webkit-scrollbar-thumb {
    background: var(--listener-border-strong);
    border-radius: 4px;
}

.listener-transcript::-webkit-scrollbar-thumb:hover,
.listener-page::-webkit-scrollbar-thumb:hover {
    background: var(--listener-text-faint);
}

/* Control strip — unified toolbar for language + audio controls */
.listener-language-bar {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 10px 20px;
    background: var(--listener-bg-elevated);
    border-bottom: 1px solid var(--listener-border);
    flex-shrink: 0;
    flex-wrap: wrap;
}

.listener-control-group {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 6px 14px;
    border-radius: 999px;
    background: var(--listener-bg-card, rgba(255,255,255,0.06));
    border: 1px solid var(--listener-border);
    cursor: pointer;
    transition: border-color 0.15s, background 0.15s;
    font-size: 0.8rem;
    color: var(--listener-text);
    user-select: none;
}

.listener-control-group:hover {
    border-color: var(--listener-accent);
    background: rgba(99, 102, 241, 0.08);
}

.listener-control-group--active {
    border-color: var(--listener-accent);
    background: rgba(99, 102, 241, 0.12);
}

.listener-control-group--cta {
    border-color: var(--listener-accent);
    background: rgba(99, 102, 241, 0.15);
    color: var(--listener-accent);
    font-weight: 600;
    animation: listener-cta-glow 3s ease-in-out infinite;
}

@keyframes listener-cta-glow {
    0%, 100% { box-shadow: 0 0 0 0 rgba(99, 102, 241, 0); }
    50% { box-shadow: 0 0 12px 2px rgba(99, 102, 241, 0.25); }
}

.listener-control-group__icon {
    display: flex;
    align-items: center;
    opacity: 0.7;
}

.listener-control-group__label {
    font-weight: 500;
    white-space: nowrap;
}

.listener-control-group__badge {
    display: inline-block;
    padding: 1px 6px;
    border-radius: 999px;
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    background: var(--listener-accent);
    color: #fff;
}

.listener-control-divider {
    width: 1px;
    height: 20px;
    background: var(--listener-border);
    margin: 0 0.25rem;
}

@media (max-width: 480px) {
    .listener-language-bar {
        padding: 8px 12px;
        gap: 0.35rem;
    }
    .listener-control-group {
        padding: 5px 10px;
        font-size: 0.75rem;
    }
    .listener-control-divider {
        display: none;
    }
}

/* Jump to live button */
.listener-jump-to-live {
    position: fixed;
    bottom: 1.5rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 100;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.5rem 1.25rem;
    border-radius: 999px;
    border: none;
    background: var(--listener-accent);
    color: #fff;
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    box-shadow: 0 4px 20px rgba(0,0,0,0.4);
    transition: transform 0.15s, opacity 0.15s;
    animation: listener-jump-pulse 2s ease-in-out infinite;
}

.listener-jump-to-live:hover {
    transform: translateX(-50%) scale(1.05);
}

@keyframes listener-jump-pulse {
    0%, 100% { box-shadow: 0 4px 20px rgba(0,0,0,0.4); }
    50% { box-shadow: 0 4px 30px rgba(99, 102, 241, 0.5); }
}

/* Word-by-word reveal animation for new segments */
.listener-segment--revealing .listener-segment__text span {
    opacity: 0;
    animation: listener-word-reveal 0.15s ease forwards;
}

@keyframes listener-word-reveal {
    from { opacity: 0; transform: translateY(4px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ================================================================= */
/* SERMON DETAIL PAGE (Archive)                                       */
/* ================================================================= */

/* Hero */
.listener-sermon-hero {
    padding: 2rem 1.25rem 1.5rem;
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.12) 0%, rgba(168, 85, 247, 0.08) 100%);
    border-bottom: 1px solid var(--listener-border);
}

.listener-sermon-hero__inner {
    max-width: 800px;
    margin: 0 auto;
}

.listener-sermon-hero__back {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    color: var(--listener-text-faint);
    text-decoration: none;
    font-size: 0.85rem;
    margin-bottom: 0.75rem;
    transition: color 0.15s;
}

.listener-sermon-hero__back:hover {
    color: var(--listener-accent);
}

.listener-sermon-hero__meta {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.5rem;
    font-size: 0.85rem;
    color: var(--listener-text-faint);
}

.listener-sermon-hero__org {
    font-weight: 600;
    color: var(--listener-accent);
}

.listener-sermon-hero__date {
    opacity: 0.7;
}

.listener-sermon-hero__title {
    font-size: 1.75rem;
    font-weight: 700;
    line-height: 1.25;
    margin: 0.25rem 0 0.75rem;
    color: var(--listener-text);
}

.listener-sermon-hero__topics {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    margin-bottom: 0.75rem;
}

.listener-sermon-hero__topic {
    display: inline-block;
    padding: 0.2rem 0.65rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 500;
    text-transform: capitalize;
    background: rgba(99, 102, 241, 0.15);
    color: var(--listener-accent);
    border: 1px solid rgba(99, 102, 241, 0.25);
}

.listener-sermon-hero__stats {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    font-size: 0.8rem;
    color: var(--listener-text-faint);
}

.listener-sermon-hero__stats span {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.listener-sermon-hero__stats svg {
    opacity: 0.6;
}

/* Sermon Audio Player */
.listener-sermon-player {
    position: sticky;
    top: 0;
    z-index: 50;
    background: var(--listener-bg);
    border-bottom: 1px solid var(--listener-border);
    padding: 0.75rem 1.25rem;
}

.listener-sermon-player__inner {
    max-width: 800px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.listener-sermon-player__play {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: none;
    background: var(--listener-accent);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: transform 0.15s, background 0.15s;
}

.listener-sermon-player__play:hover {
    transform: scale(1.08);
    background: var(--listener-accent-hover, #7c3aed);
}

.listener-sermon-player__track {
    flex: 1;
    min-width: 0;
}

.listener-sermon-player__range {
    width: 100%;
    height: 6px;
    -webkit-appearance: none;
    appearance: none;
    border-radius: 3px;
    background: var(--listener-border);
    outline: none;
    cursor: pointer;
}

.listener-sermon-player__range::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--listener-accent);
    cursor: pointer;
}

.listener-sermon-player__range::-moz-range-thumb {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--listener-accent);
    cursor: pointer;
    border: none;
}

.listener-sermon-player__times {
    display: flex;
    justify-content: space-between;
    font-size: 0.7rem;
    color: var(--listener-text-faint);
    margin-top: 0.2rem;
}

.listener-sermon-player__speed {
    flex-shrink: 0;
}

.listener-sermon-player__speed-btn {
    background: var(--listener-border);
    color: var(--listener-text-faint);
    border: none;
    border-radius: 6px;
    padding: 0.25rem 0.5rem;
    font-size: 0.75rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s;
}

.listener-sermon-player__speed-btn:hover {
    background: var(--listener-border-strong);
    color: var(--listener-text);
}

/* Sermon Tabs */
.listener-sermon-tabs {
    display: flex;
    justify-content: center;
    gap: 0;
    padding: 0 1.25rem;
    border-bottom: 1px solid var(--listener-border);
    background: var(--listener-bg);
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    z-index: 49;
}

.listener-sermon-player ~ .listener-sermon-tabs {
    top: 76px;
}

.listener-sermon-tab {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.75rem 1rem;
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    color: var(--listener-text-faint);
    font-size: 0.85rem;
    font-weight: 500;
    cursor: pointer;
    transition: color 0.15s, border-color 0.15s;
}

.listener-sermon-tab:hover {
    color: var(--listener-text);
}

.listener-sermon-tab.active {
    color: var(--listener-accent);
    border-bottom-color: var(--listener-accent);
}

.listener-sermon-tab svg {
    opacity: 0.6;
}

.listener-sermon-tab.active svg {
    opacity: 1;
}

/* Tab Content */
.listener-sermon-tab-content {
    max-width: 800px;
    margin: 0 auto;
    padding: 1.5rem 1.25rem 6rem;
}

/* Language toggle */
.listener-sermon-transcript-lang {
    margin-bottom: 1rem;
}

.listener-sermon-lang-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.4rem 0.85rem;
    border-radius: 999px;
    border: 1px solid var(--listener-border);
    background: var(--listener-bg-raised, rgba(255,255,255,0.04));
    color: var(--listener-text-faint);
    font-size: 0.8rem;
    cursor: pointer;
    transition: border-color 0.15s, color 0.15s;
}

.listener-sermon-lang-toggle:hover {
    border-color: var(--listener-accent);
    color: var(--listener-accent);
}

/* Formatted transcript (HTML from QWEN) */
.listener-sermon-formatted {
    font-size: 1.05rem;
    line-height: 1.8;
    color: var(--listener-text);
}

.listener-sermon-formatted p {
    margin-bottom: 1.25rem;
}

.listener-sermon-formatted p:last-child {
    margin-bottom: 0;
}

/* Segment fallback */
.listener-sermon-segments .listener-segment {
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--listener-border);
}

.listener-sermon-segments .listener-segment:last-child {
    border-bottom: none;
}

.listener-sermon-empty {
    color: var(--listener-text-faint);
    font-style: italic;
    text-align: center;
    padding: 2rem 0;
}

/* Summary tab */
.listener-sermon-summary__text {
    margin-bottom: 2rem;
}

.listener-sermon-summary__text h3,
.listener-sermon-summary__outline h3,
.listener-sermon-summary__scriptures h3 {
    font-size: 1.1rem;
    font-weight: 600;
    margin-bottom: 0.75rem;
    color: var(--listener-text);
}

.listener-sermon-summary__text p {
    font-size: 1rem;
    line-height: 1.7;
    color: var(--listener-text);
    opacity: 0.9;
}

/* Outline */
.listener-sermon-outline-section {
    margin-bottom: 1.25rem;
}

.listener-sermon-outline-section h4 {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--listener-accent);
    margin-bottom: 0.4rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.listener-sermon-outline-section ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.listener-sermon-outline-section li {
    position: relative;
    padding: 0.4rem 0 0.4rem 1.25rem;
    font-size: 0.95rem;
    line-height: 1.5;
    color: var(--listener-text);
    opacity: 0.9;
}

.listener-sermon-outline-section li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.85rem;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--listener-accent);
    opacity: 0.5;
}

/* Scripture cards */
.listener-sermon-summary__scriptures {
    margin-top: 2rem;
}

.listener-sermon-scripture-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.listener-sermon-scripture-card {
    padding: 1rem 1.25rem;
    border-radius: 10px;
    background: var(--listener-bg-raised, rgba(255,255,255,0.04));
    border-left: 3px solid var(--listener-accent);
}

.listener-sermon-scripture-card__ref {
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--listener-accent);
    margin-bottom: 0.3rem;
}

.listener-sermon-scripture-card__text {
    font-size: 0.9rem;
    line-height: 1.6;
    color: var(--listener-text);
    opacity: 0.85;
    font-style: italic;
}

/* Key quotes */
.listener-sermon-quotes-list {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.listener-sermon-quote {
    position: relative;
    margin: 0;
    padding: 1.25rem 1.5rem 1.25rem 1.5rem;
    border-radius: 12px;
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.08) 0%, rgba(168, 85, 247, 0.05) 100%);
    border: 1px solid rgba(99, 102, 241, 0.15);
}

.listener-sermon-quote__icon {
    position: absolute;
    top: 0.75rem;
    left: 1rem;
    color: var(--listener-accent);
}

.listener-sermon-quote p {
    margin: 0;
    font-size: 1.05rem;
    line-height: 1.7;
    color: var(--listener-text);
    padding-left: 1.5rem;
    font-style: italic;
}

/* Light mode overrides */
[data-bs-theme="light"] .listener-sermon-hero {
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.06) 0%, rgba(168, 85, 247, 0.04) 100%);
}

[data-bs-theme="light"] .listener-sermon-quote {
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.04) 0%, rgba(168, 85, 247, 0.02) 100%);
}

/* Mobile responsiveness */
@media (max-width: 640px) {
    .listener-sermon-hero__title {
        font-size: 1.35rem;
    }

    .listener-sermon-player__inner {
        gap: 0.5rem;
    }

    .listener-sermon-tab {
        padding: 0.65rem 0.65rem;
        font-size: 0.8rem;
    }

    .listener-sermon-tab-content {
        padding: 1rem 1rem 6rem;
    }

    .listener-sermon-formatted {
        font-size: 0.95rem;
    }
}
