/**
 * BB Community Manager — Frontend CSS
 * Directory card buttons + shortcode grid.
 * Purchase gate overlay CSS is injected inline by PHP.
 */

/* ============================================================
   DIRECTORY CARDS / SHORTCODE GRID
   ============================================================ */
.bcm-communities-grid{display:grid;grid-template-columns:repeat(var(--bcm-cols,3),1fr);gap:var(--bcm-gap,24px);list-style:none;padding:0;margin:0}
.bcm-card{border-radius:var(--bcm-card-radius,12px);box-shadow:var(--bcm-card-shadow);overflow:hidden;display:flex;flex-direction:column;transition:var(--bcm-transition);border:1px solid rgba(0,0,0,.08)}
.bcm-card:hover{box-shadow:0 8px 40px rgba(0,0,0,.12);transform:translateY(-4px)}
.bcm-card-cover{position:relative;overflow:hidden;aspect-ratio:16/9;background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}
.bcm-card-cover img{width:100%;height:100%;object-fit:cover;transition:var(--bcm-transition);display:block}
.bcm-card:hover .bcm-card-cover img{transform:scale(1.05)}
.bcm-card-body{padding:20px;flex:1}
.bcm-card-title{margin:0 0 8px;font-size:1.125rem;font-weight:700;line-height:1.3}
.bcm-card-title a{text-decoration:none;transition:color .2s}
.bcm-card-title a:hover{color:var(--bcm-accent,#e94560)!important}
.bcm-card-meta{display:flex;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap}
.bcm-meta-tag{display:inline-flex;padding:2px 10px;border-radius:50px;font-size:.75rem;font-weight:600;text-transform:uppercase}
.bcm-tag-public{background:rgba(46,125,50,.15);color:#2e7d32}
.bcm-tag-private{background:rgba(230,81,0,.15);color:#e65100}
.bcm-tag-hidden{background:rgba(198,40,40,.15);color:#c62828}
.bcm-card-footer,.bcm-card-actions{display:flex;align-items:center;gap:10px;padding:16px 20px;border-top:1px solid rgba(0,0,0,.06);flex-wrap:wrap}

/* Buttons */
.bcm-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;font-size:.875rem;font-weight:600;line-height:1;text-decoration:none!important;border:none;cursor:pointer;transition:var(--bcm-transition);user-select:none;white-space:nowrap;border-radius:var(--bcm-btn-radius,8px);box-sizing:border-box}
.bcm-btn:focus-visible{outline:2px solid var(--bcm-accent);outline-offset:2px}

/* Dark */
.bcm-btn-style-dark .bcm-btn-see{background:var(--bcm-primary,#1a1a2e)!important;color:#fff!important}
.bcm-btn-style-dark .bcm-btn-see:hover{background:var(--bcm-secondary,#16213e)!important;box-shadow:0 4px 12px rgba(26,26,46,.3);transform:translateY(-1px)}
.bcm-btn-style-dark .bcm-btn-buy{background:var(--bcm-accent,#e94560)!important;color:#fff!important}
.bcm-btn-style-dark .bcm-btn-buy:hover{background:#d63750!important;box-shadow:0 4px 12px rgba(233,69,96,.3);transform:translateY(-1px)}
/* Outline */
.bcm-btn-style-outline .bcm-btn-see{background:transparent!important;color:var(--bcm-primary)!important;border:2px solid var(--bcm-primary)}
.bcm-btn-style-outline .bcm-btn-see:hover{background:var(--bcm-primary)!important;color:#fff!important}
.bcm-btn-style-outline .bcm-btn-buy{background:transparent!important;color:var(--bcm-accent)!important;border:2px solid var(--bcm-accent)}
.bcm-btn-style-outline .bcm-btn-buy:hover{background:var(--bcm-accent)!important;color:#fff!important}
/* Gradient */
.bcm-btn-style-gradient .bcm-btn-see{background:linear-gradient(135deg,var(--bcm-primary),var(--bcm-secondary))!important;color:#fff!important}
.bcm-btn-style-gradient .bcm-btn-buy{background:linear-gradient(135deg,var(--bcm-accent),#ff6b81)!important;color:#fff!important}
/* Rounded */
.bcm-btn-style-rounded .bcm-btn{border-radius:50px;padding:10px 24px}
.bcm-btn-style-rounded .bcm-btn-see{background:var(--bcm-primary)!important;color:#fff!important}
.bcm-btn-style-rounded .bcm-btn-buy{background:var(--bcm-accent)!important;color:#fff!important}

/* Badges & Price */
.bcm-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:50px;font-size:.75rem;font-weight:600}
.bcm-badge-member{background:rgba(46,125,50,.15);color:#2e7d32}
.bcm-price{font-size:.75rem;font-weight:700;background:rgba(255,255,255,.25);padding:2px 8px;border-radius:50px;margin-left:4px}

/* Hide BB native buttons when ours are present */
.bcm-card-actions~.groups-loop-buttons,.bcm-card-actions~.footer-button-wrap,#groups-list .bcm-card-actions~*[class*="button"]{display:none!important}

.bcm-empty,.bcm-error{text-align:center;padding:48px 24px;color:#64748b;background:#f8fafc;border-radius:12px;border:1px dashed #cbd5e1}
.bcm-error{border-color:#fca5a5;background:#fef2f2;color:#991b1b}

/* ============================================================
   GLOBAL POPUP (from modal handler)
   ============================================================ */
.bcm-popup-overlay{position:fixed;inset:0;z-index:100000;display:flex;align-items:flex-end;justify-content:center;padding:0 20px 20px;opacity:0;visibility:hidden;transition:all .3s ease}
.bcm-popup-overlay.bcm-popup-visible{opacity:1;visibility:visible}
.bcm-popup-bg{position:absolute;inset:0;background:rgba(0,0,0,var(--bcm-popup-overlay,.4));backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:background .3s}
.bcm-popup-card{position:relative;background:var(--bcm-popup-bg,#fff);border-radius:20px;box-shadow:0 -8px 60px rgba(0,0,0,.15);max-width:520px;width:100%;padding:32px 36px;text-align:center;transform:translateY(100%);transition:transform .4s ease-out;z-index:1}
.bcm-popup-visible .bcm-popup-card{transform:translateY(0)}
.bcm-popup-close{position:absolute;top:12px;right:16px;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--bcm-popup-text,#1e293b);opacity:.5;transition:opacity .2s}
.bcm-popup-close:hover{opacity:1}
.bcm-popup-lock{margin-bottom:12px}
.bcm-popup-lock svg{stroke:var(--bcm-popup-btn,var(--bcm-accent,#e94560))}
.bcm-popup-title{font-size:1.25rem;font-weight:800;color:var(--bcm-popup-text,#1e293b);margin:0 0 6px}
.bcm-popup-text{font-size:.9rem;color:var(--bcm-popup-text,#1e293b);opacity:.7;margin:0 0 16px;line-height:1.5}
.bcm-popup-price{font-size:1.35rem;font-weight:700;color:var(--bcm-popup-text,#1e293b);margin-bottom:16px}
.bcm-popup-buy-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 40px;font-size:1rem;font-weight:700;background:var(--bcm-popup-btn,var(--bcm-accent,#e94560));color:var(--bcm-popup-btn-text,#fff)!important;border-radius:12px;text-decoration:none!important;box-shadow:0 4px 16px rgba(0,0,0,.15);transition:all .3s;border:none;cursor:pointer}
.bcm-popup-buy-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.25);filter:brightness(1.1)}
.bcm-popup-login{margin:12px 0 0;font-size:.85rem;color:var(--bcm-popup-text,#1e293b);opacity:.5}
.bcm-popup-login a{color:var(--bcm-popup-text,#1e293b);font-weight:600;text-decoration:underline}
.bcm-popup-cancel{background:none;border:none;color:var(--bcm-popup-text,#1e293b);opacity:.5;font-size:.85rem;cursor:pointer;margin-top:12px;transition:opacity .2s}
.bcm-popup-cancel:hover{opacity:1}

/* Guest modal */
.bcm-guest-modal-overlay .bcm-guest-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:16px;padding:32px;box-shadow:0 8px 40px rgba(0,0,0,.15);max-width:400px;width:90%;z-index:100001;text-align:center}
.bcm-guest-modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:100000}

/* Responsive */
@media(max-width:768px){
    .bcm-popup-card{padding:24px 20px;border-radius:16px 16px 0 0}
    .bcm-popup-buy-btn{width:100%;padding:14px 24px}
    .bcm-popup-overlay{padding:0}
	.bb-rl-left-panel-menu .bb-readylaunchpanel-menu li:last-child {
        display: inline-block !important;
    }
	.bcm-points-tooltip { display: none !important}
}
@media(max-width:640px){
    .bcm-communities-grid{gap:16px!important}
    .bcm-card-footer,.bcm-card-actions{flex-direction:column;align-items:stretch}
    .bcm-btn{width:100%;justify-content:center}
}
@media(prefers-reduced-motion:reduce){.bcm-card,.bcm-btn,.bcm-popup-card,.bcm-popup-overlay{transition:none!important}.bcm-card:hover{transform:none!important}}
@media print{.bcm-card-actions,.bcm-popup-overlay{display:none!important}}
@media(forced-colors:active){.bcm-btn{border:1px solid ButtonText}.bcm-card{border:1px solid CanvasText}}
.user-link {
	display: flex;
	gap: 10px;
}
.bcm-points-badge {
	position: relative !important;
	left: 0 !important;
    top: 0 !important;
    right: 0 !important;
}
.bcm-upgrade-btn-wrap {display: none !important}