/* ============================================================
   RBBC Sermons Plugin — Frontend Styles
   ============================================================ */
:root {
    --rbbc-navy:      #1a2a4a;
    --rbbc-navy-dark: #111e35;
    --rbbc-gold:      #c9a84c;
    --rbbc-gold-d:    #a8862e;
    --rbbc-white:     #ffffff;
    --rbbc-off:       #f8f6f2;
    --rbbc-grey:      #e8e6e2;
    --rbbc-text:      #2a2a2a;
    --rbbc-muted:     #666;
    --rbbc-radius:    6px;
    --rbbc-shadow:    0 2px 12px rgba(0,0,0,.1);
    --rbbc-max:       1140px;
}

/* ── Shared utilities ─────────────────────────────────────── */
.rbbc-container { max-width: var(--rbbc-max); margin: 0 auto; padding: 0 1.5rem; }

.rbbc-btn {
    display: inline-block;
    padding: .6rem 1.4rem;
    border-radius: var(--rbbc-radius);
    font-weight: 700;
    font-size: .85rem;
    letter-spacing: .03em;
    text-transform: uppercase;
    cursor: pointer;
    border: 2px solid transparent;
    text-decoration: none;
    transition: all .2s;
}
.rbbc-btn-gold    { background: var(--rbbc-gold);  color: var(--rbbc-navy);  border-color: var(--rbbc-gold); }
.rbbc-btn-gold:hover { background: var(--rbbc-gold-d); border-color: var(--rbbc-gold-d); color: #fff; }
.rbbc-btn-navy    { background: var(--rbbc-navy);  color: var(--rbbc-white); }
.rbbc-btn-navy:hover { background: var(--rbbc-navy-dark); color: #fff; }
.rbbc-btn-outline { background: transparent; border-color: var(--rbbc-navy); color: var(--rbbc-navy); }
.rbbc-btn-outline:hover { background: var(--rbbc-navy); color: #fff; }
.rbbc-btn-outline-sm {
    font-size: .78rem; padding: .4rem .9rem;
    border: 1.5px solid rgba(255,255,255,.4); color: rgba(255,255,255,.85);
    border-radius: var(--rbbc-radius); background: transparent;
    text-decoration: none; transition: all .2s;
}
.rbbc-btn-outline-sm:hover { background: rgba(255,255,255,.15); color: #fff; border-color: #fff; }

/* ── Page banner ──────────────────────────────────────────── */
.rbbc-page-banner {
    background: linear-gradient(to right, #111e35, #243660);
    padding: 2rem 1.5rem;
    text-align: center;
}
.rbbc-page-banner h1 { color: #fff; margin-bottom: .25rem; font-size: 2rem; font-family: 'Merriweather', Georgia, serif; }
.rbbc-breadcrumb { font-size: .82rem; color: rgba(255,255,255,.6); }
.rbbc-breadcrumb a { color: var(--rbbc-gold); text-decoration: none; }
.rbbc-breadcrumb a:hover { text-decoration: underline; }

/* ── Sermon archive wrap ──────────────────────────────────── */
.rbbc-sermons-wrap { padding: 2.5rem 0 4rem; }

/* ── Filter Bar ───────────────────────────────────────────── */
.rbbc-filters {
    background: var(--rbbc-off);
    border: 1px solid var(--rbbc-grey);
    border-radius: var(--rbbc-radius);
    padding: 1.25rem 1.5rem;
    margin-bottom: 2rem;
}
.rbbc-filter-row {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    align-items: flex-end;
}
.rbbc-filter-group { display: flex; flex-direction: column; gap: .3rem; min-width: 140px; flex: 1; }
.rbbc-filter-group label { font-size: .78rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--rbbc-navy); }
.rbbc-filter-group input,
.rbbc-filter-group select {
    padding: .55rem .75rem;
    border: 1.5px solid var(--rbbc-grey);
    border-radius: var(--rbbc-radius);
    background: #fff;
    font-size: .9rem;
    color: var(--rbbc-text);
    width: 100%;
}
.rbbc-filter-group input:focus,
.rbbc-filter-group select:focus { outline: none; border-color: var(--rbbc-gold); }
.rbbc-filter-actions { flex-direction: row; align-items: flex-end; gap: .5rem; flex: 0; min-width: unset; }

.rbbc-results-meta { margin-top: .75rem; font-size: .82rem; color: var(--rbbc-muted); }

/* ── Sermon Grid ──────────────────────────────────────────── */
.rbbc-sermon-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1.5rem;
    min-height: 200px;
    position: relative;
}
.rbbc-sermon-grid.rbbc-loading::after {
    content: 'Loading…';
    position: absolute;
    inset: 0;
    background: rgba(255,255,255,.85);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    color: var(--rbbc-muted);
    border-radius: var(--rbbc-radius);
}
.rbbc-no-results { grid-column: 1/-1; text-align: center; color: var(--rbbc-muted); padding: 3rem 1rem; }

/* ── Sermon Card ──────────────────────────────────────────── */
.rbbc-sermon-card {
    background: var(--rbbc-white);
    border-radius: var(--rbbc-radius);
    box-shadow: var(--rbbc-shadow);
    overflow: hidden;
    transition: transform .2s, box-shadow .2s;
    display: flex;
    flex-direction: column;
}
.rbbc-sermon-card:hover { transform: translateY(-3px); box-shadow: 0 6px 24px rgba(0,0,0,.14); }

.rbbc-card-thumb { position: relative; aspect-ratio: 16/9; overflow: hidden; background: var(--rbbc-navy); }
.rbbc-card-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .3s; }
.rbbc-sermon-card:hover .rbbc-card-thumb img { transform: scale(1.04); }
.rbbc-thumb-placeholder {
    width: 100%; height: 100%; display: flex; align-items: center; justify-content: center;
    color: rgba(255,255,255,.15); font-size: 3.5rem;
}
.rbbc-play-overlay {
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    background: rgba(0,0,0,.35);
    opacity: 0; transition: opacity .2s;
}
.rbbc-sermon-card:hover .rbbc-play-overlay { opacity: 1; }
.rbbc-play-overlay span {
    width: 52px; height: 52px;
    background: var(--rbbc-gold);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.2rem;
    color: var(--rbbc-navy);
}

.rbbc-card-body { padding: 1.1rem 1.25rem 1.4rem; flex: 1; display: flex; flex-direction: column; }
.rbbc-card-service {
    font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
    color: var(--rbbc-gold-d); margin: 0 0 .3rem;
}
.rbbc-card-title { font-size: 1rem; line-height: 1.35; margin: 0 0 .6rem; }
.rbbc-card-title a { color: var(--rbbc-navy); text-decoration: none; }
.rbbc-card-title a:hover { color: var(--rbbc-gold-d); }
.rbbc-card-meta { display: flex; flex-wrap: wrap; gap: .35rem; margin-top: auto; font-size: .78rem; color: var(--rbbc-muted); }
.rbbc-card-meta span { white-space: nowrap; }

/* ── Pagination ───────────────────────────────────────────── */
.rbbc-pagination-wrap { margin-top: 2.5rem; text-align: center; }
.rbbc-pagination {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    flex-wrap: wrap;
    justify-content: center;
    max-width: 100%;
}
.rbbc-page-btn {
    min-width: 38px; height: 38px;
    padding: 0 .5rem;
    background: var(--rbbc-off); border: 1.5px solid var(--rbbc-grey);
    border-radius: var(--rbbc-radius);
    font-size: .88rem; font-weight: 600;
    cursor: pointer; transition: all .15s;
    color: var(--rbbc-navy);
    display: inline-flex; align-items: center; justify-content: center;
}
.rbbc-page-btn:hover:not(:disabled) { background: var(--rbbc-navy); color: #fff; border-color: var(--rbbc-navy); }
.rbbc-page-btn.active { background: var(--rbbc-gold); border-color: var(--rbbc-gold); color: var(--rbbc-navy); cursor: default; }
.rbbc-page-btn:disabled { opacity: .35; cursor: default; }

/* Prev / Next arrows — slightly wider, larger glyph */
.rbbc-page-prev,
.rbbc-page-next { font-size: 1.3rem; min-width: 42px; }

/* Ellipsis */
.rbbc-page-ellipsis {
    min-width: 28px; height: 38px;
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--rbbc-muted); font-size: .9rem; pointer-events: none;
}

@media (max-width: 480px) {
    .rbbc-page-btn { min-width: 34px; height: 34px; font-size: .82rem; }
    .rbbc-page-prev, .rbbc-page-next { min-width: 38px; }
    .rbbc-pagination { gap: .2rem; }
}

/* ── Single Sermon ────────────────────────────────────────── */
.rbbc-single-wrap { padding: 2.5rem 0 4rem; }
.rbbc-single-inner {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 2.5rem;
    align-items: start;
}
@media (max-width: 900px) { .rbbc-single-inner { grid-template-columns: 1fr; } }

.rbbc-sermon-header { margin-bottom: 1.5rem; }
.rbbc-sermon-title { font-size: clamp(1.4rem, 3vw, 2rem); color: var(--rbbc-navy); margin-bottom: .75rem; }
.rbbc-sermon-meta-bar { display: flex; flex-wrap: wrap; gap: .5rem; align-items: center; }
.rbbc-meta-date { font-size: .85rem; color: var(--rbbc-muted); }
.rbbc-meta-tag {
    font-size: .78rem; font-weight: 700;
    background: var(--rbbc-off); border: 1px solid var(--rbbc-grey);
    padding: .2rem .65rem; border-radius: 20px;
    color: var(--rbbc-navy); text-decoration: none; transition: background .15s;
}
a.rbbc-meta-tag:hover { background: var(--rbbc-navy); color: #fff; border-color: var(--rbbc-navy); }
.rbbc-scripture { font-style: italic; background: #eef2f8 !important; border-color: #c4d0e8 !important; }

/* Video embed */
.rbbc-video-wrap { margin-bottom: 1.75rem; }
.rbbc-video-container {
    position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden;
    background: #000; border-radius: var(--rbbc-radius);
}
.rbbc-video-container iframe {
    position: absolute; top: 0; left: 0;
    width: 100%; height: 100%; border: none;
}
.rbbc-video-actions {
    display: flex; flex-wrap: wrap; gap: .5rem;
    margin-top: .75rem; padding: .75rem;
    background: var(--rbbc-navy-dark); border-radius: 0 0 var(--rbbc-radius) var(--rbbc-radius);
}
.rbbc-audio-wrap {
    background: var(--rbbc-off); border-radius: var(--rbbc-radius);
    padding: 1.5rem; margin-bottom: 1.75rem;
}
.rbbc-sermon-content { line-height: 1.8; font-size: .98rem; }

/* Prev / Next */
.rbbc-sermon-nav {
    display: flex; justify-content: space-between; gap: 1rem;
    margin-top: 2.5rem; padding-top: 1.5rem;
    border-top: 1px solid var(--rbbc-grey);
}
.rbbc-nav-prev, .rbbc-nav-next {
    max-width: 48%; font-size: .82rem;
    white-space: normal; text-align: inherit;
}

/* Sidebar */
.rbbc-sermon-sidebar { position: sticky; top: 90px; }
.rbbc-sidebar-widget {
    background: var(--rbbc-off); border-radius: var(--rbbc-radius);
    padding: 1.25rem 1.25rem; margin-bottom: 1.25rem;
}
.rbbc-sidebar-widget h4 {
    font-size: .82rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
    color: var(--rbbc-navy); margin-bottom: 1rem;
    padding-bottom: .5rem; border-bottom: 2px solid var(--rbbc-gold);
}
.rbbc-sidebar-list { list-style: none; padding: 0; margin: 0; }
.rbbc-sidebar-list li { border-bottom: 1px solid var(--rbbc-grey); }
.rbbc-sidebar-list li:last-child { border-bottom: none; }
.rbbc-sidebar-list li a {
    display: flex; flex-direction: column; padding: .6rem 0;
    text-decoration: none; color: var(--rbbc-text); transition: color .15s;
}
.rbbc-sidebar-list li a:hover { color: var(--rbbc-gold-d); }
.rbbc-sidebar-title { font-size: .88rem; font-weight: 600; line-height: 1.3; }
.rbbc-sidebar-date { font-size: .75rem; color: var(--rbbc-muted); margin-top: .15rem; }
.rbbc-all-link { display:block; margin-top:.75rem; font-size:.82rem; color:var(--rbbc-gold-d); font-weight:700; text-decoration:none; }
.rbbc-all-link:hover { text-decoration: underline; }

.rbbc-sidebar-terms { list-style: none; padding: 0; margin: 0; }
.rbbc-sidebar-terms li { border-bottom: 1px solid var(--rbbc-grey); }
.rbbc-sidebar-terms li:last-child { border-bottom: none; }
.rbbc-sidebar-terms li a {
    display: flex; justify-content: space-between; align-items: center;
    padding: .55rem 0; text-decoration: none; color: var(--rbbc-text);
    font-size: .88rem; transition: color .15s;
}
.rbbc-sidebar-terms li a:hover { color: var(--rbbc-gold-d); }
.rbbc-sidebar-terms li.active a { color: var(--rbbc-gold-d); font-weight: 600; }
.rbbc-sidebar-terms li.active .rbbc-term-count { background: var(--rbbc-navy); color: #fff; }
.rbbc-term-count {
    background: var(--rbbc-grey); border-radius: 10px;
    padding: .1rem .5rem; font-size: .72rem; color: var(--rbbc-muted);
}

/* Responsive */
@media (max-width: 600px) {
    .rbbc-filter-row { flex-direction: column; }
    .rbbc-filter-actions { flex-direction: row; width: 100%; }
    .rbbc-sermon-nav { flex-direction: column; }
    .rbbc-nav-prev, .rbbc-nav-next { max-width: 100%; }
    .rbbc-video-actions { flex-direction: column; }
}
