/* ===========================================================
   WINR v37 — COMMUNITIES PAGE
   Dedicated "Communities" page: joined + owned community cards.
   =========================================================== */

.communities-page{ width:100%; }

.cm-wrap{
  max-width: 1080px;
  margin: 0 auto;
  padding: 92px 24px 120px;
}

/* ── Header ── */
.cm-header{
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; margin-bottom: 22px;
}
.cm-header-left{ display:flex; align-items:center; gap:14px; }
.cm-header-icon{
  width:52px; height:52px; flex:0 0 auto;
  display:grid; place-items:center;
  background:#0a0a0c;
  border:1px solid rgba(255,255,255,0.15);
  border-radius:14px;
  color:#fff;
  box-shadow:0 4px 14px rgba(0,0,0,0.5);
}
.cm-title{
  font-size:32px; font-weight:900; letter-spacing:-0.8px; color:#fff; margin:0; line-height:1;
}
.cm-subtitle{
  font-size:14px; color:var(--text-lo); margin-top:6px; font-weight:600;
}
.cm-create-btn{
  display:inline-flex; align-items:center; gap:8px; flex:0 0 auto;
  height:42px; padding:0 18px;
  border-radius:999px;
  background:linear-gradient(180deg, #ffffff 0%, #ececef 100%);
  color:#0a0a0d; font-size:14px; font-weight:700;
  box-shadow:0 6px 18px rgba(0,0,0,0.35), inset 0 1px 0 rgba(255,255,255,0.7);
  transition:transform .18s ease, box-shadow .18s ease;
}
.cm-create-btn:hover{ transform:translateY(-1px); box-shadow:0 10px 26px rgba(0,0,0,0.45), inset 0 1px 0 rgba(255,255,255,0.85); }

/* ── Filter chips ── */
.cm-filters{
  display:flex; gap:8px; margin-bottom:22px; flex-wrap:wrap;
  border-bottom:1px solid rgba(255,255,255,0.06); padding-bottom:18px;
}
.cm-chip{
  display:inline-flex; align-items:center; gap:7px;
  height:34px; padding:0 14px;
  border-radius:999px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  color:rgba(255,255,255,0.6);
  font-size:13px; font-weight:700;
  transition:all .15s ease;
}
.cm-chip:hover{ color:#fff; border-color:rgba(255,255,255,0.2); }
.cm-chip.active{ background:#fff; color:#0a0a0d; border-color:#fff; }
.cm-chip-count{
  font-size:11px; font-weight:800;
  background:rgba(255,255,255,0.12); color:inherit;
  padding:1px 7px; border-radius:999px; min-width:18px; text-align:center;
}
.cm-chip.active .cm-chip-count{ background:rgba(0,0,0,0.12); }

/* ── Grid ── */
.cm-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(300px, 1fr));
  gap:18px;
}

/* ── Card ── */
.cm-card{
  display:flex; flex-direction:column;
  background:rgba(255,255,255,0.025);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:18px;
  overflow:hidden;
  cursor:pointer;
  transition:transform .25s var(--ease-out,cubic-bezier(0.16,1,0.3,1)), box-shadow .25s ease, border-color .25s ease;
}
.cm-card:hover{
  transform:translateY(-4px);
  border-color:rgba(255,255,255,0.18);
  box-shadow:0 18px 42px rgba(0,0,0,0.45);
}
.cm-card-banner{
  position:relative; height:104px;
  background-size:cover; background-position:center;
}
.cm-card-banner::after{
  content:''; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0.05) 0%, rgba(10,10,13,0.85) 100%);
}
.cm-card-emblem{
  position:absolute; left:16px; bottom:-18px; z-index:2;
  width:48px; height:48px;
  display:grid; place-items:center;
  border-radius:14px;
  background:#101014;
  border:2px solid rgba(255,255,255,0.9);
  color:#fff; font-size:16px; font-weight:900; letter-spacing:-0.5px;
  box-shadow:0 6px 16px rgba(0,0,0,0.5);
}
.cm-badge{
  position:absolute; top:12px; right:12px; z-index:2;
  font-size:10.5px; font-weight:800; letter-spacing:0.3px;
  padding:4px 9px; border-radius:999px;
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
}
.cm-badge.owner{ background:rgba(255,255,255,0.92); color:#0a0a0d; }
.cm-badge.free{ background:rgba(57,255,20,0.16); color:#7CFF5B; border:1px solid rgba(57,255,20,0.25); }
.cm-badge.paid{ background:rgba(255,255,255,0.12); color:#fff; border:1px solid rgba(255,255,255,0.2); }

.cm-card-body{ padding:26px 16px 14px; flex:1; }
.cm-card-name{
  font-size:16px; font-weight:800; color:#fff; letter-spacing:-0.3px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.cm-card-desc{
  font-size:12.5px; color:rgba(255,255,255,0.6); line-height:1.45;
  margin-top:5px;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
  min-height:36px;
}
.cm-card-desc.cm-muted{ color:rgba(255,255,255,0.32); font-style:italic; }
.cm-card-meta{
  display:flex; align-items:center; flex-wrap:wrap; gap:12px;
  margin-top:12px;
  font-size:11.5px; color:rgba(255,255,255,0.5); font-weight:600;
}
.cm-meta-item{ display:inline-flex; align-items:center; gap:5px; }
.cm-meta-item svg{ opacity:0.7; }
.cm-cat{
  padding:2px 8px; border-radius:6px;
  background:rgba(255,255,255,0.06); color:rgba(255,255,255,0.6);
  font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:0.4px;
}
.cm-dot{
  width:6px; height:6px; border-radius:50%;
  background:#39FF14; box-shadow:0 0 7px rgba(57,255,20,0.7);
}

.cm-card-foot{
  display:flex; gap:8px; padding:12px 16px 16px;
  border-top:1px solid rgba(255,255,255,0.05);
}
.cm-card-btn{
  flex:1; height:36px; border-radius:10px;
  font-size:13px; font-weight:700;
  transition:all .15s ease;
}
.cm-card-btn.primary{ background:#fafafa; color:#0a0a0d; }
.cm-card-btn.primary:hover{ filter:brightness(1.08); }
.cm-card-btn.ghost,
.cm-card-btn:not(.primary){
  background:transparent; color:rgba(255,255,255,0.7);
  border:1px solid rgba(255,255,255,0.12);
}
.cm-card-btn.ghost:hover,
.cm-card-btn:not(.primary):hover{ color:#fff; border-color:rgba(255,255,255,0.28); background:rgba(255,255,255,0.04); }

/* ── Empty state ── */
.cm-empty, .cm-gate{
  display:flex; flex-direction:column; align-items:center; text-align:center;
  padding:72px 24px;
  border:1px dashed rgba(255,255,255,0.10);
  border-radius:20px;
  background:rgba(255,255,255,0.015);
}
.cm-empty-icon, .cm-gate-icon{
  width:72px; height:72px; margin-bottom:18px;
  display:grid; place-items:center;
  border-radius:20px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  color:rgba(255,255,255,0.55);
}
.cm-empty-title, .cm-gate-title{
  font-size:19px; font-weight:800; color:#fff; letter-spacing:-0.3px;
}
.cm-empty-sub, .cm-gate-sub{
  font-size:13.5px; color:rgba(255,255,255,0.55); line-height:1.55;
  margin-top:8px; max-width:420px;
}
.cm-empty-actions{ display:flex; gap:10px; margin-top:22px; flex-wrap:wrap; justify-content:center; }
.cm-btn-primary{
  height:42px; padding:0 22px; border-radius:999px;
  background:#fafafa; color:#0a0a0d; font-size:14px; font-weight:700;
  box-shadow:0 6px 18px rgba(0,0,0,0.35);
  transition:transform .18s ease, filter .18s ease;
}
.cm-btn-primary:hover{ transform:translateY(-1px); filter:brightness(1.06); }
.cm-btn-ghost{
  height:42px; padding:0 22px; border-radius:999px;
  background:transparent; color:#fff; font-size:14px; font-weight:700;
  border:1px solid rgba(255,255,255,0.18);
  transition:all .18s ease;
}
.cm-btn-ghost:hover{ background:rgba(255,255,255,0.06); border-color:rgba(255,255,255,0.35); }
.cm-gate{ margin-top:8px; }
.cm-gate .cm-btn-primary{ margin-top:22px; }

/* ── Responsive ── */
@media (max-width:640px){
  .cm-wrap{ padding:80px 16px 110px; }
  .cm-title{ font-size:26px; }
  .cm-create-btn span{ display:none; }
  .cm-create-btn{ padding:0 14px; }
  .cm-grid{ grid-template-columns:1fr; }
}
