/* ============================================================
   Community Page — glassmorphism design (v1)
   Follows the same glass tokens as gospel-card.css
   ============================================================ */

.comm-page {
    
    margin: 0 auto;
    padding: 0 var(--space-3) 0px;
}
.pl-list,.prp-list {
    
    padding: 0px  !important;
}
 /* ── Session card (community page) ─────────────────────────────────── */
    .comm-sessions-wrap { margin-bottom: 15px; }
    .comm-sessions-title {
        font-size: 15px; font-weight: 800;
        color: var(--color-text);
        margin: 20px 0 12px;
        display: flex; align-items: center; gap: 7px;
    }
    .comm-sessions-empty {
        text-align: center; padding: 28px 0;
        font-size: 14px; color: var(--color-text-muted, #888);
    }
    .comm-sessions-list { display: flex; flex-direction: column; gap: 12px; }
    .ps-card {
        text-decoration: none; color: inherit; display: block;
        border-radius: 16px; overflow: hidden;
        background: var(--color-card-bg, #fff);
        box-shadow: 0 1px 6px rgba(0,0,40,.06), 0 3px 14px rgba(0,0,40,.04);
        border: 1px solid var(--color-border, #eef0f5);
        transition: transform .15s, box-shadow .15s; position: relative;
    }
    .ps-card:active { transform: scale(.985); }
    @media (hover: hover) {
        .ps-card:hover { transform: translateY(-3px); box-shadow: 0 6px 24px rgba(0,0,40,.1); border-color: rgba(0,85,165,.15); }
    }
    .ps-card.has-cover .ps-card-banner { display: block; }
    .ps-card-banner {
        display: none; width: 100%; aspect-ratio: 16/7;
        object-fit: cover;
    }
    .ps-card-inner { display: flex; gap: 14px; padding: 14px 15px; align-items: center; }
    .ps-card-no{
        width: 52px; height: 52px; border-radius: 50%;
        display: inline-flex; align-items: center; justify-content: center;
        flex-shrink: 0; font-size: 1.45rem; font-weight: 900; line-height: 1;
        color: #fff;
        background: radial-gradient(circle at 30% 25%, #a86bdb 0%, #6a1b9a 58%, #4a148c 100%);
        border: 2px solid rgba(255,255,255,.6);
        box-shadow: 0 6px 16px rgba(106,27,154,.35), inset 0 2px 4px rgba(255,255,255,.25);
    }
    .ps-card-thumb {
        width: 52px; height: 52px; border-radius: 12px;
        background: linear-gradient(145deg, #003d80 0%, #1ab8d4 100%);
        display: flex; align-items: center; justify-content: center;
        flex-shrink: 0; font-size: 22px;
        box-shadow: 0 2px 8px rgba(0,85,165,.2);
    }
    .ps-card.has-cover .ps-card-thumb { display: none; }
    .ps-card-body { flex: 1; min-width: 0; }
    .ps-card-title {
        font-size: 15.5px; font-weight: 700; color: var(--color-text);
        margin: 0 0 6px; line-height: 1.3;
        display: -webkit-box; -webkit-line-clamp: 2;
        -webkit-box-orient: vertical; overflow: hidden;
    }
    .ps-card-pills { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 2px; }
    .ps-card-pill {
        display: inline-flex; align-items: center; gap: 3px;
        font-size: 11.5px; color: var(--color-text-muted, #888);
        background: var(--color-bg, #f5f7fb);
        border-radius: 6px; padding: 2px 7px; font-weight: 500;
    }
    [data-theme="dark"] .ps-card-pill { background: rgba(255,255,255,.06); }
    .ps-card-pill--countdown{
        color:#7a2f9d;
        border:1px solid rgba(122,47,157,.28);
        background:rgba(122,47,157,.10);
        font-weight:700;
    }
    .ps-card.is-live{
        border-color: rgba(220,38,38,.38);
        box-shadow: 0 10px 26px rgba(220,38,38,.16), 0 2px 10px rgba(0,0,40,.08);
        background:
            linear-gradient(120deg, rgba(220,38,38,.06), rgba(239,68,68,.02) 35%, rgba(255,255,255,.9));
    }
    .ps-card.is-live .ps-card-title{
        color:#b91c1c;
    }
    .ps-card.is-live .ps-card-pill{
        border:1px solid rgba(220,38,38,.25);
        background:rgba(220,38,38,.12);
        color:#b91c1c;
        font-weight:700;
    }
    .ps-card.is-upcoming-soon{
        border-color: rgba(37,99,235,.32);
        box-shadow: 0 8px 24px rgba(37,99,235,.14), 0 2px 8px rgba(0,0,40,.08);
        background:
            linear-gradient(120deg, rgba(37,99,235,.06), rgba(99,102,241,.03) 40%, rgba(255,255,255,.92));
    }
    .ps-card.is-upcoming-soon .ps-card-title{
        color:#1d4ed8;
    }
    [data-theme="dark"] .ps-card-no{
        border-color: rgba(255,255,255,.34);
        box-shadow: 0 8px 18px rgba(18,10,36,.6), inset 0 2px 5px rgba(255,255,255,.18);
    }
    [data-theme="dark"] .ps-card-pill--countdown{
        color:#c4b5fd;
        border-color: rgba(196,181,253,.35);
        background: rgba(124,58,237,.18);
    }
    [data-theme="dark"] .ps-card.is-live{
        background: linear-gradient(120deg, rgba(220,38,38,.16), rgba(31,41,55,.86) 45%, rgba(17,24,39,.9));
    }
    [data-theme="dark"] .ps-card.is-live .ps-card-title,
    [data-theme="dark"] .ps-card.is-live .ps-card-pill{
        color:#fecaca;
    }
    [data-theme="dark"] .ps-card.is-upcoming-soon{
        background: linear-gradient(120deg, rgba(37,99,235,.22), rgba(30,41,59,.84) 45%, rgba(15,23,42,.9));
    }
    [data-theme="dark"] .ps-card.is-upcoming-soon .ps-card-title{
        color:#bfdbfe;
    }
    .ps-card-arrow { color: var(--color-text-muted, #ccc); flex-shrink: 0; margin-left: 2px; }
    .comm-sessions-load-more {
        width: 100%; padding: 12px; border-radius: 14px; margin-top: 10px;
        border: 1.5px solid var(--color-border, #dde2ea);
        background: var(--color-card-bg, #fff);
        color: var(--color-primary, #0055a5);
        font-size: 14px; font-weight: 600; cursor: pointer; transition: all .18s;
    }
    .comm-sessions-load-more:hover { background: var(--color-primary, #0055a5); color: #fff; }
    .comm-sessions-load-more:disabled { opacity: .45; cursor: not-allowed; }
/* ── Hero card ─────────────────────────────────────────────── */
.comm-hero {
    background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border-radius: var(--radius-lg);
    margin: var(--space-3) 0 var(--space-4);
    border: 1px solid var(--glass-border);
    box-shadow: var(--glass-shadow-heavy);
    overflow: hidden;
}
.comm-sga{
    background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border-radius: var(--radius-lg);
    margin: var(--space-3) 0 var(--space-4);
    border: 1px solid var(--glass-border);
    padding: 0px var(--space-3);
    box-shadow: var(--glass-shadow-heavy);
    overflow: hidden;
     
    }
    .comm-sga1{display: none;}
/* ── Identity row ─────────────────────────────────────────── */
.comm-hero-top {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    padding: var(--space-5) var(--space-5) var(--space-3);
}

.comm-avatar {
    width: 60px;
    height: 60px;
    flex-shrink: 0;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.9rem;
    background: linear-gradient(135deg, var(--color-primary-light, #e0f0ff), var(--color-primary, #0055a5));
    border: 3px solid rgba(255, 255, 255, 0.4);
    box-shadow: 0 4px 18px rgba(0, 85, 165, 0.22);
    overflow: hidden;
}

.comm-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
}

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

.comm-name {
    font-size: 1.18rem;
    font-weight: 800;
    color: var(--color-text);
    margin: 0 0 5px;
    line-height: 1.3;
}

.comm-parish {
    font-size: 0.8rem;
    color: var(--color-muted);
    margin: 0;
    display: flex;
    align-items: center;
    gap: 4px;
    line-height: 1.4;
}

/* ── Description ──────────────────────────────────────────── */
.comm-desc {
    font-size: 0.875rem;
    color: var(--color-text-secondary, var(--color-muted));
    line-height: 1.7;
    margin: 0;
    padding: var(--space-3) var(--space-5) var(--space-4);
    border-top: 1px solid var(--glass-border-dim, rgba(0,0,0,.06));
}

/* ── Stats row ────────────────────────────────────────────── */
.comm-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    border-top: 1px solid var(--glass-border-dim, rgba(0,0,0,.06));
}

.comm-stat-box {
    padding: var(--space-3) var(--space-2);
    text-align: center;
    transition: background var(--transition-fast, .15s);
    cursor: default;
}

.comm-stat-box + .comm-stat-box {
    border-left: 1px solid var(--glass-border-dim, rgba(0,0,0,.06));
}

.comm-stat-box:hover {
    background: var(--glass-bg-subtle, rgba(255,255,255,.35));
}

.comm-stat-icon {
    font-size: 1.05rem;
    display: block;
    margin-bottom: 2px;
    line-height: 1;
}

.comm-stat-value {
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--color-primary);
    display: block;
    line-height: 1.15;
    font-variant-numeric: tabular-nums;
}

.comm-stat-label {
    font-size: 0.67rem;
    color: var(--color-muted);
    margin-top: 3px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    display: block;
}

/* ── Section title ────────────────────────────────────────── */
.comm-section-title {
    font-size: 0.88rem;
    font-weight: 700;
    color: var(--color-text);
    margin: var(--space-5) 0 var(--space-3);
    display: flex;
    align-items: center;
    gap: var(--space-2);
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

/* ── Sort tabs ────────────────────────────────────────────── */
.comm-sort-tabs {
    display: flex;
    gap: 3px;
    margin-bottom: var(--space-3);
    background: var(--glass-bg-subtle, rgba(255,255,255,.3));
    border: 1px solid var(--glass-border, rgba(255,255,255,.5));
    border-radius: var(--radius-full, 999px);
    padding: 3px;
    width: max-content;
    max-width: 100%;
    backdrop-filter: var(--glass-blur-light);
    -webkit-backdrop-filter: var(--glass-blur-light);
}

.comm-sort-tab {
    padding: 6px 16px;
    border-radius: var(--radius-full, 999px);
    border: none;
    background: transparent;
    color: var(--color-muted);
    font-size: 0.81rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
    white-space: nowrap;
}

.comm-sort-tab.active {
    background: var(--color-primary);
    color: #fff;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.comm-sort-tab:not(.active):hover {
    color: var(--color-primary);
    background: rgba(255,255,255,.4);
}

/* ── Members list card ────────────────────────────────────── */
.comm-member-list {
    background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border-radius: var(--radius-lg);
    border: 1px solid var(--glass-border);
    box-shadow: var(--glass-shadow, 0 4px 24px rgba(0,0,0,.08));
    overflow: hidden;
    margin-bottom: var(--space-5);
}

.comm-member-table {
    width: 100%;
    border-collapse: collapse;
}

.comm-member-table thead tr {
    background: var(--glass-bg-subtle, rgba(255,255,255,.25));
    border-bottom: 1px solid var(--glass-border);
}

.comm-member-table thead th {
    padding: var(--space-2) var(--space-3);
    text-align: left;
    color: var(--color-muted);
    font-weight: 700;
    font-size: 0.71rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    white-space: nowrap;
}

.comm-member-table tbody tr {
    border-bottom: 1px solid var(--glass-border-dim, rgba(0,0,0,.04));
    transition: background 0.1s;
}

.comm-member-table tbody tr:last-child {
    border-bottom: none;
}

.comm-member-table tbody tr:hover td {
    background: var(--glass-bg-subtle, rgba(255,255,255,.25));
}

.comm-member-table tbody td {
    padding: var(--space-2) var(--space-3);
    font-size: 0.855rem;
    vertical-align: middle;
}

.comm-member-rank {
    font-weight: 700;
    color: var(--color-muted);
    width: 30px;
    font-size: 0.78rem;
    text-align: center;
}

.comm-rank-1 { color: #f59e0b !important; }
.comm-rank-2 { color: #94a3b8 !important; }
.comm-rank-3 { color: #b45309 !important; }

.comm-member-name {
    font-weight: 600;
    color: var(--color-text);
}

.comm-member-streak {
    color: var(--color-primary);
    font-weight: 700;
    white-space: nowrap;
}

.comm-member-score {
    color: var(--color-muted);
    font-size: 0.82rem;
}

#comm-members-loading {
    text-align: center;
    padding: var(--space-6) var(--space-4);
    color: var(--color-muted);
    font-size: 0.875rem;
}
