/* ===== OBN Desktop Community — light theme to match the website. All scoped under .cmty ===== */
.cmty{--cmty-bg:#f4f6f9;--cmty-card:#ffffff;--cmty-card2:#f1f3f6;--cmty-bd:#e6e8ec;--cmty-bd2:#d7dbe2;--cmty-accent:#2857b7;--cmty-accent2:#3b6fd9;--cmty-text:#111927;--cmty-muted:#5b6675;--cmty-dim:#5e6b7e;--cmty-live:#ef4444;--cmty-shadow:0 1px 2px rgba(16,24,40,.06),0 2px 6px rgba(16,24,40,.05);--cmty-accent-grad:#7c3aed;--cmty-hover:rgba(0,0,0,.04);--cmty-hover-strong:rgba(0,0,0,.1);--cmty-focus-bg:#fff;--cmty-accent-ring:rgba(40,87,183,.45);--cmty-av-bg:#dbe4f5;--cmty-online:#22c55e;--cmty-skel2:#e9edf3;--cmty-toast-bg:#111927;--cmty-shadow-pop:0 10px 30px rgba(16,24,40,.18);--cmty-scrollbar:rgba(0,0,0,.16);color:var(--cmty-text);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased}
[data-theme="dark"] .cmty{--cmty-bg:#0f1419;--cmty-card:#1a2027;--cmty-card2:#232b34;--cmty-bd:#2b3540;--cmty-bd2:#3a4654;--cmty-accent:#5b8def;--cmty-accent2:#74a2f5;--cmty-accent-grad:#a06bf0;--cmty-text:#e6e8ec;--cmty-muted:#9aa6b4;--cmty-dim:#7d8896;--cmty-live:#f0656a;--cmty-online:#2ee06a;--cmty-shadow:0 1px 2px rgba(0,0,0,.4),0 2px 6px rgba(0,0,0,.35);--cmty-shadow-pop:0 10px 30px rgba(0,0,0,.55);--cmty-hover:rgba(255,255,255,.06);--cmty-hover-strong:rgba(255,255,255,.12);--cmty-focus-bg:#11171e;--cmty-accent-ring:rgba(91,141,239,.55);--cmty-av-bg:#27344a;--cmty-skel2:#2c353f;--cmty-toast-bg:#2a323d;--cmty-scrollbar:rgba(255,255,255,.18)}
[data-theme="dark"] .cmty .cmty-role-staff{color:#82a8f7}
[data-theme="dark"] .cmty .cmty-role-pastor,[data-theme="dark"] .cmty .cmty-badge-bday,[data-theme="dark"] .cmty .cmty-composer-tool.on,[data-theme="dark"] .cmty .cmty-act.on-celebrate{color:#bd93f6}
[data-theme="dark"] .cmty .cmty-role-author,[data-theme="dark"] .cmty .cmty-role-leader,[data-theme="dark"] .cmty .cmty-act.on-pray{color:#2dd4bf}
[data-theme="dark"] .cmty .cmty-role-verified,[data-theme="dark"] .cmty .cmty-act.on-like,[data-theme="dark"] .cmty .cmty-notif-ic.comment{color:#7aa7f7}
[data-theme="dark"] .cmty .cmty-badge-party{color:#f6888c}
[data-theme="dark"] .cmty .cmty-badge-joined{color:#4ade80}
[data-theme="dark"] .cmty .cmty-act.on-amen,[data-theme="dark"] .cmty .cmty-notif-ic.amen{color:#f0a93c}
[data-theme="dark"] .cmty .cmty-act.on-love{color:#fb6f92}
.cmty *{box-sizing:border-box}
.cmty a{color:inherit;text-decoration:none}
.cmty ::-webkit-scrollbar{width:8px;height:8px}
.cmty ::-webkit-scrollbar-thumb{background:var(--cmty-scrollbar);border-radius:8px}

/* Sign-in gate */
.cmty-gate{min-height:60vh;display:flex;align-items:center;justify-content:center;padding:60px 20px}
.cmty-gate-card{max-width:460px;text-align:center;background:var(--cmty-card);border:1px solid var(--cmty-bd);border-radius:24px;padding:48px 36px;box-shadow:var(--cmty-shadow)}
.cmty-gate-icon{width:76px;height:76px;margin:0 auto 20px;border-radius:22px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--cmty-accent),var(--cmty-accent-grad));font-size:2rem;color:#fff;box-shadow:0 12px 32px rgba(40,87,183,.35)}
.cmty-gate-card h2{font-size:1.6rem;font-weight:800;margin:0 0 12px;letter-spacing:-.02em}
.cmty-gate-card p{color:var(--cmty-muted);line-height:1.6;margin:0 0 24px;font-size:.98rem}
.cmty-gate-btn{display:inline-block;padding:14px 32px;border-radius:999px;background:linear-gradient(135deg,var(--cmty-accent),var(--cmty-accent2));color:#fff;font-weight:700;box-shadow:0 8px 24px rgba(40,87,183,.28)}
.cmty-gate-note{margin-top:18px;font-size:.8rem;color:var(--cmty-dim)}

/* Boot loader */
.cmty-boot{min-height:50vh;display:flex;align-items:center;justify-content:center;gap:8px}
.cmty-boot-dot{width:10px;height:10px;border-radius:50%;background:var(--cmty-accent);animation:cmtyBoot 1s ease-in-out infinite}
.cmty-boot-dot:nth-child(2){animation-delay:.15s}.cmty-boot-dot:nth-child(3){animation-delay:.3s}
@keyframes cmtyBoot{0%,100%{opacity:.25;transform:translateY(0)}50%{opacity:1;transform:translateY(-6px)}}

/* App shell — 3 columns */
.cmty-app{max-width:1180px;margin:0 auto;padding:24px clamp(12px,3vw,28px) 80px;display:grid;grid-template-columns:230px minmax(0,1fr) 300px;gap:24px;align-items:start}
.cmty-nav{position:sticky;top:84px;display:flex;flex-direction:column;gap:4px}
.cmty-nav-item{display:flex;align-items:center;gap:14px;padding:12px 16px;border-radius:14px;color:var(--cmty-muted);font-weight:600;font-size:.96rem;cursor:pointer;transition:all .15s;border:1px solid transparent}
.cmty-nav-item i{font-size:1.25rem;width:24px;text-align:center}
.cmty-nav-item:hover{background:rgba(40,87,183,.06);color:var(--cmty-text)}
.cmty-nav-item.active{background:rgba(40,87,183,.1);color:var(--cmty-accent);font-weight:700}
.cmty-nav-badge{margin-left:auto;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--cmty-live);color:#fff;font-size:.7rem;font-weight:800;display:flex;align-items:center;justify-content:center}
.cmty-main{min-width:0;display:flex;flex-direction:column;gap:18px}
.cmty-side{position:sticky;top:84px;display:flex;flex-direction:column;gap:16px}

/* Cards / buttons */
.cmty-card{background:var(--cmty-card);border:1px solid var(--cmty-bd);border-radius:20px;padding:18px;box-shadow:var(--cmty-shadow)}
.cmty-card-title{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--cmty-dim);margin:0 0 12px}
.cmty-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;border-radius:999px;border:1px solid var(--cmty-bd);background:var(--cmty-card2);color:var(--cmty-text);font-weight:700;font-size:.9rem;cursor:pointer;transition:all .15s}
.cmty-btn:hover{background:var(--cmty-hover)}
.cmty-btn-primary{background:linear-gradient(135deg,var(--cmty-accent),var(--cmty-accent2));border-color:transparent;color:#fff;box-shadow:0 6px 18px rgba(40,87,183,.24)}
.cmty-btn-primary:hover{filter:brightness(1.06)}
.cmty-btn[disabled]{opacity:.5;cursor:default}
.cmty-btn-sm{padding:7px 14px;font-size:.82rem}

/* Avatars */
.cmty-av{border-radius:50%;object-fit:cover;background:var(--cmty-av-bg);flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;color:var(--cmty-accent);font-weight:800}
.cmty-av-wrap{position:relative;flex-shrink:0}
.cmty-av-dot{position:absolute;right:0;bottom:0;width:11px;height:11px;border-radius:50%;background:var(--cmty-online);border:2px solid var(--cmty-card)}
.cmty-av-live{box-shadow:0 0 0 2px var(--cmty-card),0 0 0 4px var(--cmty-live)}

/* Stories row */
.cmty-stories{display:flex;gap:14px;overflow-x:auto;padding:4px;scrollbar-width:none}
.cmty-stories::-webkit-scrollbar{display:none}
.cmty-story{flex:0 0 auto;width:74px;text-align:center;cursor:pointer}
.cmty-story-ring{width:66px;height:66px;border-radius:50%;padding:3px;margin:0 auto 6px;background:linear-gradient(135deg,var(--cmty-accent),var(--cmty-accent-grad))}
.cmty-story-ring.seen{background:var(--cmty-bd2)}
.cmty-story-ring img,.cmty-story-ring .cmty-av{width:100%;height:100%}
.cmty-story-add .cmty-story-ring{background:var(--cmty-card2);border:2px dashed var(--cmty-bd2);display:flex;align-items:center;justify-content:center;color:var(--cmty-accent);font-size:1.4rem}
.cmty-story-name{font-size:.72rem;color:var(--cmty-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Composer */
.cmty-composer-row{display:flex;gap:12px;align-items:flex-start}
.cmty-composer textarea{flex:1;min-height:46px;max-height:200px;background:var(--cmty-card2);border:1px solid var(--cmty-bd);border-radius:14px;padding:12px 14px;color:var(--cmty-text);font-size:.98rem;font-family:inherit;resize:none;outline:none}
.cmty-composer textarea:focus{border-color:var(--cmty-accent-ring);background:var(--cmty-focus-bg)}
.cmty-composer textarea::placeholder{color:var(--cmty-dim)}
.cmty-composer-actions{display:flex;align-items:center;gap:10px;margin-top:12px}
.cmty-composer-tool{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:10px;background:var(--cmty-card2);border:1px solid var(--cmty-bd);color:var(--cmty-muted);font-weight:600;font-size:.85rem;cursor:pointer}
.cmty-composer-tool:hover{color:var(--cmty-text);background:var(--cmty-hover)}
.cmty-composer-tool.on{color:#7c3aed;border-color:rgba(124,58,237,.35);background:rgba(124,58,237,.08)}
.cmty-composer-spacer{flex:1}
.cmty-composer-preview{position:relative;margin-top:12px;display:inline-block}
.cmty-composer-preview img{max-height:220px;border-radius:12px;border:1px solid var(--cmty-bd)}
.cmty-composer-preview button{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;border:none;background:rgba(0,0,0,.6);color:#fff;cursor:pointer}

/* Post */
.cmty-post{background:var(--cmty-card);border:1px solid var(--cmty-bd);border-radius:20px;padding:18px 20px;box-shadow:var(--cmty-shadow)}
.cmty-post-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.cmty-post-author{font-weight:700;font-size:.96rem;cursor:pointer}
.cmty-post-author:hover{text-decoration:underline}
.cmty-post-sub{font-size:.76rem;color:var(--cmty-dim)}
.cmty-post-menu{margin-left:auto;color:var(--cmty-dim);cursor:pointer;padding:4px 8px;border-radius:8px;position:relative}
.cmty-post-menu:hover{background:var(--cmty-hover);color:var(--cmty-text)}
.cmty-post-body{font-size:1rem;line-height:1.55;white-space:pre-wrap;word-break:break-word}
.cmty-post-media{margin-top:12px;border-radius:14px;overflow:hidden;border:1px solid var(--cmty-bd);max-height:560px}
.cmty-post-media img{width:100%;display:block;cursor:pointer}
.cmty-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;font-size:.66rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em}
.cmty-badge-bday{background:rgba(124,58,237,.12);color:#7c3aed}
.cmty-badge-role{vertical-align:middle;text-transform:none;letter-spacing:0;font-size:.62rem}
.cmty-badge-role i{font-size:.72rem}
.cmty-role-staff{background:rgba(40,87,183,.12);color:#2857b7}
.cmty-role-pastor{background:rgba(124,58,237,.12);color:#7c3aed}
.cmty-role-author{background:rgba(13,148,136,.12);color:#0d9488}
.cmty-role-leader{background:rgba(13,148,136,.12);color:#0d9488}
.cmty-role-verified{background:rgba(37,99,235,.12);color:#2563eb}
.cmty-badge-party{background:rgba(239,68,68,.12);color:#dc2626}
.cmty-post-stats{display:flex;align-items:center;gap:14px;margin-top:12px;font-size:.8rem;color:var(--cmty-dim)}
.cmty-post-actions{display:flex;gap:6px;margin-top:10px;padding-top:10px;border-top:1px solid var(--cmty-bd)}
.cmty-act{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:9px;border-radius:12px;background:transparent;border:none;color:var(--cmty-muted);font-weight:700;font-size:.88rem;cursor:pointer;transition:all .12s}
.cmty-act:hover{background:rgba(0,0,0,.04);color:var(--cmty-text)}
.cmty-act.on-amen{color:#d97706}.cmty-act.on-love{color:#e11d48}.cmty-act.on-celebrate{color:#7c3aed}.cmty-act.on-pray{color:#0d9488}.cmty-act.on-like{color:#2563eb}
.cmty-react-pop{position:absolute;bottom:100%;left:0;margin-bottom:8px;display:none;gap:4px;padding:6px 8px;background:var(--cmty-card);border:1px solid var(--cmty-bd2);border-radius:999px;box-shadow:var(--cmty-shadow-pop);z-index:5}
.cmty-react-pop.show{display:flex}
.cmty-react-pop span{font-size:1.4rem;cursor:pointer;transition:transform .12s}
.cmty-react-pop span:hover{transform:scale(1.3)}
.cmty-act-wrap{position:relative;flex:1;display:flex}

/* Comments */
.cmty-comments{margin-top:12px;display:flex;flex-direction:column;gap:10px}
.cmty-comment{display:flex;gap:10px}
.cmty-comment-bubble{background:var(--cmty-card2);border-radius:14px;padding:9px 13px;min-width:0}
.cmty-comment-author{font-weight:700;font-size:.82rem}
.cmty-comment-body{font-size:.9rem;line-height:1.45;color:var(--cmty-text);white-space:pre-wrap;word-break:break-word}
.cmty-comment-time{font-size:.7rem;color:var(--cmty-dim);margin:3px 0 0 13px}
.cmty-comment-form{display:flex;gap:10px;align-items:center;margin-top:4px}
.cmty-comment-form input{flex:1;background:var(--cmty-card2);border:1px solid var(--cmty-bd);border-radius:999px;padding:9px 15px;color:var(--cmty-text);outline:none;font-size:.9rem}

/* Sidebar widgets / lists */
.cmty-side-me{display:flex;align-items:center;gap:12px}
.cmty-side-me-name{font-weight:800}
.cmty-side-me-handle{font-size:.78rem;color:var(--cmty-accent)}
.cmty-row{display:flex;align-items:center;gap:12px;padding:9px;border-radius:12px;cursor:pointer;transition:background .12s}
.cmty-row:hover{background:var(--cmty-hover)}
.cmty-row-name{font-weight:700;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cmty-row-sub{font-size:.76rem;color:var(--cmty-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cmty-row-main{min-width:0;flex:1}
.cmty-empty{text-align:center;color:var(--cmty-dim);padding:32px 16px;font-size:.9rem}
.cmty-row-actions{display:flex;gap:8px;flex-shrink:0;align-items:center}

/* Friends — search + identity card */
.cmty-search{display:flex;align-items:center;gap:10px;background:var(--cmty-card2);border:1px solid var(--cmty-bd);border-radius:999px;padding:10px 16px;margin-bottom:12px}
.cmty-search i{color:var(--cmty-dim)}
.cmty-search input{flex:1;border:none;background:transparent;outline:none;color:var(--cmty-text);font-size:.95rem}
.cmty-id{display:flex;gap:16px;align-items:flex-start}
.cmty-id-av{position:relative;cursor:pointer;flex-shrink:0;display:inline-block}
.cmty-id-av-cam{position:absolute;right:-2px;bottom:-2px;width:26px;height:26px;border-radius:50%;background:var(--cmty-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.72rem;border:2px solid var(--cmty-card)}
.cmty-id-name{font-weight:800;font-size:1.1rem;overflow-wrap:anywhere;word-break:break-word}
.cmty-id-handle{color:var(--cmty-accent);font-weight:600;font-size:.9rem;margin-top:2px}
.cmty-id-bio{color:var(--cmty-muted);font-size:.9rem;margin-top:6px;line-height:1.45}
.cmty-id-handle i,.cmty-id-bio i{cursor:pointer;opacity:.55;font-size:.8rem;margin-left:4px}
.cmty-id-handle i:hover,.cmty-id-bio i:hover{opacity:1}
.cmty-id-toggle{display:flex;align-items:center;gap:9px;margin-top:16px;font-size:.88rem;color:var(--cmty-muted);cursor:pointer}
.cmty-id-toggle input{accent-color:var(--cmty-accent);width:16px;height:16px}
.cmty-invite{display:flex;gap:8px;margin-top:14px}
.cmty-invite input{flex:1;min-width:0;background:var(--cmty-card2);border:1px solid var(--cmty-bd);border-radius:999px;padding:9px 15px;color:var(--cmty-muted);font-size:.82rem;outline:none}

/* Section header */
.cmty-h{display:flex;align-items:center;gap:10px;margin:4px 2px;min-width:0}
.cmty-h h1{font-size:1.4rem;font-weight:800;margin:0;letter-spacing:-.02em;min-width:0;flex:1 1 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cmty-h-right{margin-left:auto;flex-shrink:0}
.cmty-h .cmty-badge{flex-shrink:0}

/* Modal + story viewer */
.cmty-modal{position:fixed;inset:0;z-index:9000;background:rgba(15,23,42,.55);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px}
.cmty-modal-card{width:100%;max-width:460px;background:var(--cmty-card);border:1px solid var(--cmty-bd);border-radius:22px;padding:24px;max-height:88vh;overflow:auto;box-shadow:0 30px 80px rgba(16,24,40,.35)}
.cmty-modal-close{position:absolute;top:18px;right:18px;width:38px;height:38px;border-radius:50%;border:none;background:var(--cmty-hover);color:var(--cmty-muted);cursor:pointer;font-size:1.1rem}
.cmty-modal-close:hover{background:var(--cmty-hover-strong)}
.cmty-viewer{position:fixed;inset:0;z-index:9500;background:#000;display:flex;align-items:center;justify-content:center;flex-direction:column}
.cmty-viewer-bars{position:absolute;top:14px;left:14px;right:14px;display:flex;gap:5px;z-index:2}
.cmty-viewer-bar{flex:1;height:3px;border-radius:2px;background:rgba(255,255,255,.25);overflow:hidden}
.cmty-viewer-bar>i{display:block;height:100%;width:0;background:#fff}
.cmty-viewer-content{max-width:480px;width:100%;text-align:center;padding:40px 20px;color:#fff}
.cmty-viewer-content img{max-width:100%;max-height:70vh;border-radius:14px}
.cmty-viewer-head{position:absolute;top:30px;left:18px;display:flex;align-items:center;gap:10px;color:#fff;z-index:2}
.cmty-viewer-x{position:absolute;top:28px;right:18px;width:40px;height:40px;border-radius:50%;border:none;background:rgba(255,255,255,.14);color:#fff;font-size:1.2rem;cursor:pointer;z-index:3}
.cmty-viewer-reply{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);display:flex;gap:8px;align-items:center;width:min(480px,calc(100% - 36px));z-index:4}
.cmty-viewer-reply input{flex:1;min-width:0;height:44px;padding:0 16px;border-radius:999px;border:1.5px solid rgba(255,255,255,.35);background:rgba(255,255,255,.12);color:#fff;font-size:.95rem;outline:none;transition:border-color .15s,background .15s}
.cmty-viewer-reply input::placeholder{color:rgba(255,255,255,.7)}
.cmty-viewer-reply input:focus{border-color:#fff;background:rgba(255,255,255,.2)}
.cmty-viewer-reply button{flex:0 0 auto;width:44px;height:44px;border-radius:50%;padding:0;display:inline-flex;align-items:center;justify-content:center}

/* Toast */
.cmty-toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%);background:var(--cmty-toast-bg);border:1px solid rgba(255,255,255,.1);color:#fff;padding:12px 22px;border-radius:999px;font-weight:600;font-size:.9rem;z-index:9999;box-shadow:0 14px 40px rgba(16,24,40,.3);opacity:0;transition:opacity .2s,transform .2s}
.cmty-toast.show{opacity:1;transform:translateX(-50%) translateY(-4px)}

/* Mobile top-nav */
.cmty-topnav{display:none}

@media(max-width:980px){
  .cmty-app{grid-template-columns:minmax(0,1fr);max-width:640px;padding-top:14px}
  .cmty-nav,.cmty-side{display:none}
  .cmty-topnav{display:flex;position:sticky;top:64px;z-index:50;background:var(--cmty-card);gap:4px;padding:8px 0;margin-bottom:6px;overflow-x:auto;scrollbar-width:none;border-bottom:1px solid var(--cmty-bd)}
  .cmty-topnav::-webkit-scrollbar{display:none}
  .cmty-topnav .cmty-nav-item{flex:0 0 auto;padding:9px 14px}
  .cmty-topnav .cmty-nav-item span{display:none}
  .cmty-topnav .cmty-nav-item i{font-size:1.3rem}
  .cmty-topnav .cmty-nav-item{position:relative}
  .cmty-topnav .cmty-nav-badge{margin-left:0;position:absolute;top:2px;right:4px;min-width:16px;height:16px;padding:0 4px;font-size:.62rem;border:2px solid var(--cmty-card)}
}

/* ---------------- Messages / chat ---------------- */
.cmty-chat{display:flex;height:70vh;min-height:440px;background:var(--cmty-card);border:1px solid var(--cmty-bd);border-radius:16px;box-shadow:var(--cmty-shadow);overflow:hidden;margin-top:8px}
.cmty-chat-list{flex:0 0 264px;border-right:1px solid var(--cmty-bd);overflow-y:auto;background:var(--cmty-card)}
.cmty-conv{display:flex;align-items:center;gap:11px;padding:11px 14px;cursor:pointer;position:relative;border-bottom:1px solid var(--cmty-bd)}
.cmty-conv:hover{background:var(--cmty-card2)}
.cmty-conv.active{background:rgba(40,87,183,.07)}
.cmty-conv-top{display:flex;align-items:baseline;gap:8px}
.cmty-conv-time{margin-left:auto;font-size:.72rem;color:var(--cmty-dim);white-space:nowrap}
.cmty-conv-last{font-size:.82rem;color:var(--cmty-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:170px}
.cmty-conv-last.unread{color:var(--cmty-text);font-weight:700}
.cmty-conv-badge{flex-shrink:0;min-width:19px;height:19px;padding:0 5px;border-radius:999px;background:var(--cmty-accent);color:#fff;font-size:.7rem;font-weight:800;display:inline-flex;align-items:center;justify-content:center}
.cmty-chat-thread{flex:1;display:flex;flex-direction:column;min-width:0}
.cmty-chat-blank{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--cmty-dim)}
.cmty-chat-blank i{font-size:2.4rem}
.cmty-chat-head{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--cmty-bd);background:var(--cmty-card)}
.cmty-chat-back{display:none;border:none;background:transparent;color:var(--cmty-text);font-size:1.2rem;cursor:pointer;padding:4px 6px}
.cmty-chat-head-main{display:flex;align-items:center;gap:10px;cursor:pointer;min-width:0}
.cmty-chat-title{font-weight:800;font-size:.98rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cmty-chat-sub{font-size:.76rem;color:var(--cmty-muted)}
.cmty-msgs{flex:1;overflow-y:auto;padding:16px 16px 6px;background:var(--cmty-card2);display:flex;flex-direction:column;gap:2px}
.cmty-msg{display:flex;align-items:flex-end;gap:8px;margin-top:8px;max-width:78%}
.cmty-msg.mine{margin-left:auto;flex-direction:row-reverse}
.cmty-msg-bubble{position:relative;background:var(--cmty-card);border:1px solid var(--cmty-bd);border-radius:16px;padding:8px 12px;font-size:.9rem;line-height:1.4;box-shadow:0 1px 1px rgba(16,24,40,.04)}
.cmty-msg-react-pop{position:absolute;bottom:100%;margin-bottom:6px;left:0;display:none;gap:4px;padding:5px 8px;background:var(--cmty-card);border:1px solid var(--cmty-bd2);border-radius:999px;box-shadow:var(--cmty-shadow-pop);z-index:6}
.cmty-msg.mine .cmty-msg-react-pop{right:0;left:auto}
.cmty-msg-react-pop.show{display:flex}
.cmty-msg-react-pop span{font-size:1.25rem;cursor:pointer;transition:transform .12s;line-height:1}
.cmty-msg-react-pop span:hover{transform:scale(1.3)}
.cmty-msg-reactchip{position:absolute;bottom:-9px;right:8px;background:var(--cmty-card);border:1px solid var(--cmty-bd);border-radius:999px;padding:0 6px;font-size:.72rem;line-height:18px;box-shadow:0 1px 3px rgba(16,24,40,.12);white-space:nowrap}
.cmty-msg.mine .cmty-msg-reactchip{left:8px;right:auto}
.cmty-msg.mine .cmty-msg-bubble{background:linear-gradient(135deg,var(--cmty-accent),var(--cmty-accent2));border-color:transparent;color:#fff}
.cmty-msg-name{font-size:.74rem;font-weight:800;color:var(--cmty-accent);margin-bottom:2px}
.cmty-msg-text{white-space:pre-wrap;word-break:break-word}
.cmty-msg-img{display:block;max-width:230px;max-height:280px;border-radius:10px;margin-top:2px;cursor:pointer}
.cmty-msg-time{font-size:.66rem;opacity:.6;margin-top:3px;text-align:right}
.cmty-msg.mine .cmty-msg-time{color:rgba(255,255,255,.85)}
.cmty-chat-input{display:flex;align-items:center;gap:8px;padding:10px 12px;border-top:1px solid var(--cmty-bd);background:var(--cmty-card)}
.cmty-chat-input input[type=text]{flex:1;border:1px solid var(--cmty-bd2);background:var(--cmty-card2);border-radius:999px;padding:10px 16px;font-size:.9rem;color:var(--cmty-text);outline:none}
.cmty-chat-input input[type=text]:focus{border-color:var(--cmty-accent)}
.cmty-chat-photo{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;cursor:pointer;color:var(--cmty-muted);font-size:1.2rem;flex-shrink:0}
.cmty-chat-photo:hover{background:var(--cmty-card2);color:var(--cmty-accent)}
.cmty-chat-input .cmty-btn{flex-shrink:0;width:40px;height:40px;padding:0}
.cmty-chat-readonly{padding:14px;text-align:center;font-size:.84rem;color:var(--cmty-muted);border-top:1px solid var(--cmty-bd);background:var(--cmty-card)}
.cmty-typing{max-width:78%}
.cmty-typing .cmty-msg-bubble{padding:11px 14px}
.cmty-typing-dots{display:inline-flex;gap:4px;align-items:center}
.cmty-typing-dots i{width:6px;height:6px;border-radius:50%;background:var(--cmty-dim);display:inline-block;animation:cmtyTyping 1s ease-in-out infinite}
.cmty-typing-dots i:nth-child(2){animation-delay:.15s}
.cmty-typing-dots i:nth-child(3){animation-delay:.3s}
@keyframes cmtyTyping{0%,100%{opacity:.3;transform:translateY(0)}50%{opacity:1;transform:translateY(-4px)}}
.cmty-seen-row{display:flex;align-items:center;justify-content:flex-end;gap:5px;margin:1px 2px 4px auto;font-size:.64rem;color:var(--cmty-dim);font-weight:600}
.cmty-seen-av{width:14px;height:14px;border-radius:50%;object-fit:cover}

@media(max-width:980px){
  .cmty-chat{height:calc(100vh - 200px)}
  .cmty-chat-list{flex-basis:100%}
  .cmty-chat-thread{display:none}
  .cmty-chat.thread-open .cmty-chat-list{display:none}
  .cmty-chat.thread-open .cmty-chat-thread{display:flex}
  .cmty-chat-back{display:inline-flex;align-items:center}
  .cmty-conv-last{max-width:60vw}
}

/* ---------------- Groups ---------------- */
.cmty-modal-title{font-size:1.2rem;font-weight:800;letter-spacing:-.01em;margin:0 0 16px;padding-right:36px}
.cmty-input{width:100%;background:var(--cmty-card2);border:1px solid var(--cmty-bd);border-radius:12px;padding:10px 14px;color:var(--cmty-text);font-size:.95rem;font-family:inherit;outline:none}
.cmty-input:focus{border-color:var(--cmty-accent-ring);background:var(--cmty-focus-bg)}
.cmty-seg{display:flex;gap:8px;margin-bottom:14px}
.cmty-seg-tile{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;border-radius:14px;border:1px solid var(--cmty-bd);background:var(--cmty-card2);color:var(--cmty-muted);cursor:pointer;text-align:center;transition:all .15s;font-family:inherit}
.cmty-seg-tile i{font-size:1.3rem}
.cmty-seg-tile:hover{background:var(--cmty-hover)}
.cmty-seg-tile.active{border-color:var(--cmty-accent);background:rgba(40,87,183,.08);color:var(--cmty-accent)}
.cmty-seg-label{font-weight:800;font-size:.86rem}
.cmty-seg-desc{font-size:.7rem;color:var(--cmty-dim);line-height:1.3;font-weight:500}
.cmty-pick{display:flex;align-items:center;gap:12px;padding:9px;border-radius:12px;cursor:pointer}
.cmty-pick:hover{background:var(--cmty-hover)}
.cmty-pick-check{margin-left:auto;width:24px;height:24px;border-radius:50%;border:2px solid var(--cmty-bd2);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .12s}
.cmty-pick.on .cmty-pick-check{background:var(--cmty-accent);border-color:var(--cmty-accent)}
.cmty-pick.on .cmty-pick-check::after{content:'✓';color:#fff;font-size:.8rem;font-weight:800}
.cmty-danger{width:100%;margin-top:16px;color:var(--cmty-live);border-color:rgba(239,68,68,.4);background:rgba(239,68,68,.06)}
.cmty-danger:hover{background:rgba(239,68,68,.12)}
.cmty-mmenu{position:absolute;right:0;top:100%;margin-top:4px;z-index:6;background:var(--cmty-card);border:1px solid var(--cmty-bd2);border-radius:12px;box-shadow:var(--cmty-shadow-pop);overflow:hidden;min-width:180px}
.cmty-mmenu button{display:block;width:100%;text-align:left;padding:10px 14px;border:none;background:transparent;color:var(--cmty-text);font-size:.88rem;cursor:pointer;font-family:inherit}
.cmty-mmenu button:hover{background:var(--cmty-card2)}
.cmty-mmenu button.danger{color:var(--cmty-live)}
.cmty-badge-joined{background:rgba(34,197,94,.14);color:#15803d}
.cmty-prev-head{text-align:center;margin-bottom:16px}
.cmty-prev-title{font-size:1.3rem;font-weight:800;letter-spacing:-.01em;margin:12px 0 8px}
.cmty-prev-pills{display:flex;gap:6px;justify-content:center;flex-wrap:wrap}
.cmty-prev-actions{display:flex;gap:8px;align-items:center;justify-content:center;flex-wrap:wrap}
.cmty-prev-members{display:flex;gap:14px;flex-wrap:wrap;margin-top:10px}
.cmty-prev-mem{display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer;width:56px}
.cmty-prev-name{font-size:.72rem;color:var(--cmty-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:56px}
.cmty-prev-more{align-self:center;font-size:.8rem;color:var(--cmty-dim);font-weight:700}
.cmty-feed-readonly{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;text-align:center;font-size:.86rem;color:var(--cmty-muted)}
.cmty-feed-readonly i{font-size:1.05rem;color:var(--cmty-accent)}

/* ---------------- Watch parties (live-now rail + Join button) ---------------- */
.cmty-parties{display:flex;gap:12px;overflow-x:auto;padding:4px 2px 6px;scrollbar-width:none}
.cmty-parties::-webkit-scrollbar{display:none}
.cmty-party-tile{flex:0 0 auto;width:172px;background:var(--cmty-card2);border:1px solid var(--cmty-bd);border-radius:14px;overflow:hidden;cursor:pointer;transition:all .15s;display:block}
.cmty-party-tile:hover{border-color:rgba(239,68,68,.5);box-shadow:0 6px 18px rgba(239,68,68,.18)}
.cmty-party-thumb{position:relative;height:84px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#7f1d1d,var(--cmty-live));color:#fff;font-size:2rem}
.cmty-party-livechip{display:inline-flex;align-items:center;gap:4px;background:var(--cmty-live);color:#fff;font-size:.6rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;padding:2px 7px;border-radius:999px}
.cmty-party-thumb .cmty-party-livechip{position:absolute;top:8px;left:8px}
.cmty-party-title{font-weight:700;font-size:.84rem;line-height:1.25;margin:9px 11px 2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cmty-party-meta{font-size:.72rem;color:var(--cmty-muted);margin:0 11px 11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cmty-post-party{margin-top:10px}
.cmty-act-party{width:100%;flex:none;justify-content:center;gap:9px;color:#fff !important;background:linear-gradient(135deg,#7f1d1d,var(--cmty-live));border-radius:12px;padding:11px;font-weight:800;font-size:.9rem;box-shadow:0 6px 16px rgba(239,68,68,.22)}
.cmty-act-party:hover{filter:brightness(1.06);background:linear-gradient(135deg,#7f1d1d,var(--cmty-live))}
.cmty-act-party .cmty-party-livechip{background:rgba(255,255,255,.22)}

/* ---------------- Notifications ---------------- */
.cmty-notif-ic{width:44px;height:44px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:var(--cmty-card2);color:var(--cmty-accent);font-size:1.1rem;flex-shrink:0}
.cmty-notif-ic.amen{color:#d97706}
.cmty-notif-ic.comment{color:#2563eb}
.cmty-notif-note{font-size:.74rem;color:var(--cmty-dim);margin:-6px 0 10px;line-height:1.4}

/* ---------------- Settings ---------------- */
.cmty-set-field{margin-top:16px}
.cmty-set-label{display:block;font-size:.78rem;font-weight:800;color:var(--cmty-muted);margin-bottom:6px}
.cmty-set-hint{font-size:.74rem;color:var(--cmty-dim);margin-top:6px;line-height:1.4}
.cmty-set-row{display:flex;gap:10px;align-items:flex-start}
.cmty-set-row .cmty-input{flex:1;min-width:0}
.cmty-set-count{font-size:.72rem;color:var(--cmty-dim);text-align:right;margin-top:4px}
.cmty-set-count.over{color:var(--cmty-live);font-weight:700}
.cmty-set-readonly-sub{font-size:.78rem;color:var(--cmty-dim);margin-top:2px}
.cmty-set-field textarea.cmty-input{min-height:84px;resize:vertical}

/* ---------------- In-app confirm / prompt dialogs ---------------- */
.cmty-confirm-body{font-size:.95rem;line-height:1.5;color:var(--cmty-text);margin:2px 0 4px}
.cmty-confirm-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:18px}
.cmty-btn-danger{background:var(--cmty-live);border-color:transparent;color:#fff}
.cmty-btn-danger:hover{filter:brightness(1.06);background:var(--cmty-live)}

/* ---------------- Premium polish: skeletons + motion ---------------- */
@keyframes cmtyShimmer{0%{background-position:-360px 0}100%{background-position:360px 0}}
.cmty-skel{background:linear-gradient(100deg,var(--cmty-card2) 30%,var(--cmty-skel2) 50%,var(--cmty-card2) 70%);background-size:720px 100%;animation:cmtyShimmer 1.25s ease-in-out infinite;border-radius:8px}
.cmty-skel-line{height:11px;margin:7px 0;border-radius:6px}
.cmty-skel-line.w40{width:40%}.cmty-skel-line.w60{width:60%}.cmty-skel-line.w80{width:80%}.cmty-skel-line.w100{width:100%}
.cmty-skel-av{width:44px;height:44px;border-radius:50%;flex-shrink:0}
.cmty-skel-row{display:flex;align-items:center;gap:12px;padding:9px}
.cmty-skel-post{padding:18px 20px}
.cmty-skel-post .cmty-skel-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.cmty-skel-media{height:200px;border-radius:14px;margin-top:12px}
@keyframes cmtyIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.cmty-in{animation:cmtyIn .28s cubic-bezier(.22,.61,.36,1) both}
@media(prefers-reduced-motion:reduce){.cmty-skel{animation:none}.cmty-in{animation:none}}
