/* ═══════════════════════════════════════════════════════
   fragster.gg — Hubs CSS (v3.5.2)
   Clean rewrite — no duplicate definitions
═══════════════════════════════════════════════════════ */

/* ─────────────────────────────────────────────────────
   DIRECTORY — Hero + Stats + Controls + Grid
───────────────────────────────────────────────────── */
.hub-dir { display:flex; flex-direction:column; gap:0; }

/* Hero */
.hub-dir-hero {
  position:relative; padding:52px 0 44px; overflow:hidden;
  border-bottom:1px solid var(--border);
}
.hub-dir-hero-bg {
  position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(ellipse 60% 80% at 80% 50%, rgba(170,255,0,.06) 0%, transparent 65%),
    radial-gradient(ellipse 40% 60% at 10% 30%, rgba(25,229,255,.03) 0%, transparent 65%);
}
.hub-dir-hero-inner { position:relative; z-index:1; }
.hub-dir-eyebrow {
  font-size:10px; font-weight:800; color:var(--lime);
  text-transform:uppercase; letter-spacing:.14em;
  margin-bottom:12px; display:flex; align-items:center; gap:10px;
}
.hub-dir-eyebrow::after {
  content:''; flex:0 0 60px; height:1px;
  background:var(--lime); opacity:.35;
}
.hub-dir-title {
  font-family:var(--font-cond,'Barlow Condensed',sans-serif);
  font-size:64px; font-weight:900; text-transform:uppercase;
  line-height:.88; letter-spacing:-.5px;
  color:var(--t1); margin-bottom:16px;
}
.hub-dir-title em {
  color:var(--lime); font-style:normal; display:block;
}
.hub-dir-desc {
  font-size:14px; color:var(--t2); max-width:520px;
  line-height:1.65; margin-bottom:28px;
}
.hub-dir-hero-actions { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }

/* Stats bar — full bleed */
.hub-stats-bar {
  display:flex; gap:0; align-items:stretch;
  background:var(--bg2);
  border-top:1px solid var(--border); border-bottom:1px solid var(--border);
  margin-left:-32px; margin-right:-32px;
  padding:0 32px; margin-bottom:0;
}
.hub-stat-item {
  display:flex; flex-direction:column; justify-content:center;
  padding:16px 24px 14px;
  border-right:1px solid var(--border);
}
.hub-stat-item:first-child { padding-left:0; }
.hub-stat-item:last-child { border-right:none; }
.hub-stat-v {
  font-family:var(--mono,'JetBrains Mono',monospace);
  font-size:22px; font-weight:700; color:var(--lime); line-height:1;
}
.hub-stat-l {
  font-size:9px; color:var(--t3); text-transform:uppercase;
  letter-spacing:.07em; margin-top:3px;
}
.hub-stat-div { width:1px; background:var(--border); }
.hub-stats-spacer { flex:1; }
.hub-stats-cta { display:flex; align-items:center; padding-left:24px; }

/* Controls row */
.hub-dir-controls {
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
  padding-top:20px; padding-bottom:0; margin-bottom:16px;
}
.hub-dir-search {
  display:flex; align-items:center; gap:9px; padding:9px 14px;
  background:var(--bg3); border:1px solid var(--border); border-radius:8px;
  flex:1; max-width:280px; transition:.15s;
}
.hub-dir-search:focus-within { border-color:rgba(170,255,0,.3); }
.hub-dir-search input {
  background:none; border:none; outline:none;
  color:var(--t1); font-family:var(--font,sans-serif); font-size:13px; flex:1;
}
.hub-dir-search input::placeholder { color:var(--t3); }
.hub-dir-search svg { color:var(--t3); flex-shrink:0; }
.hub-dir-cats { display:flex; gap:6px; flex-wrap:wrap; }
.hub-dir-cat {
  padding:6px 14px; border-radius:20px; font-size:11px; font-weight:800;
  cursor:pointer; border:1px solid var(--border); background:var(--bg3);
  color:var(--t2); letter-spacing:.04em; text-transform:uppercase;
  transition:.15s; font-family:var(--font,sans-serif);
}
.hub-dir-cat:hover { border-color:var(--border2); color:var(--t1); }
.hub-dir-cat.active {
  border-color:rgba(170,255,0,.3); color:var(--lime);
  background:rgba(170,255,0,.07);
}
.hub-dir-cat-live { color:#FF3C5A !important; }
.hub-dir-cat-live.active {
  border-color:rgba(255,60,90,.3) !important;
  background:rgba(255,60,90,.07) !important;
  color:#FF3C5A !important;
}
.hub-dir-sort {
  margin-left:auto;
  background:var(--bg3); border:1px solid var(--border); border-radius:8px;
  padding:7px 12px; color:var(--t2); font-family:var(--font,sans-serif);
  font-size:12px; font-weight:600; outline:none; cursor:pointer;
}

/* Trending tags */
.hub-trending-row {
  display:flex; align-items:center; gap:8px; flex-wrap:wrap;
  margin-bottom:20px;
}
.hub-trending-lbl {
  font-size:10px; font-weight:800; color:var(--t3);
  text-transform:uppercase; letter-spacing:.08em; flex-shrink:0;
}
.hub-trend-tag {
  padding:4px 12px; border-radius:20px; font-size:11px; font-weight:700;
  cursor:pointer; border:1px solid var(--border); background:var(--bg3);
  color:var(--t2); transition:.15s; letter-spacing:.02em;
}
.hub-trend-tag:hover { border-color:rgba(170,255,0,.25); color:var(--lime); }

/* Featured card */
.hub-feat-card {
  display:block; position:relative; border-radius:16px; overflow:hidden;
  border:1px solid var(--border); min-height:220px;
  text-decoration:none; transition:border-color .2s; margin-bottom:16px;
}
.hub-feat-card:hover { border-color:rgba(170,255,0,.3); }
.hub-feat-bg {
  position:absolute; inset:0;
  background:linear-gradient(120deg,#080E28,#0E1040,#060C22);
}
.hub-feat-overlay {
  position:absolute; inset:0;
  background:
    linear-gradient(to right, rgba(7,8,15,.9) 30%, transparent 75%),
    linear-gradient(to top, rgba(7,8,15,.6) 0%, transparent 60%);
}
.hub-feat-accent {
  position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--lime),var(--teal,#19e5ff),transparent 65%);
}
.hub-feat-body { position:relative; z-index:1; padding:28px 28px 24px; }
.hub-feat-top { display:flex; align-items:flex-start; gap:16px; margin-bottom:14px; }
.hub-feat-logo {
  width:64px; height:64px; border-radius:14px; flex-shrink:0;
  background:linear-gradient(135deg,#1a2050,#0a1530);
  border:2px solid rgba(170,255,0,.3);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-cond,'Barlow Condensed',sans-serif);
  font-size:22px; font-weight:900; color:var(--lime);
  background-size:cover; background-position:center;
}
.hub-feat-name {
  font-family:var(--font-cond,'Barlow Condensed',sans-serif);
  font-size:36px; font-weight:900; color:var(--t1); line-height:1; margin-bottom:8px;
}
.hub-feat-meta { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.hub-feat-stats { display:flex; gap:20px; font-size:13px; color:var(--t2); }
.hub-feat-stats b { color:var(--t1); font-family:var(--mono,'JetBrains Mono',monospace); }
.hub-feat-cta {
  position:absolute; bottom:20px; right:24px; z-index:2;
  font-size:12px; font-weight:800; color:var(--lime);
  letter-spacing:.04em; text-transform:uppercase; opacity:.7; transition:.2s;
}
.hub-feat-card:hover .hub-feat-cta { opacity:1; transform:translateX(4px); }

/* Grid */
.hub-dir-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:14px;
}
.hub-dir-card {
  background:var(--bg3); border:1px solid var(--border); border-radius:14px;
  overflow:hidden; transition:all .2s; display:flex; flex-direction:column;
}
.hub-dir-card:hover {
  border-color:rgba(170,255,0,.2); transform:translateY(-3px);
  box-shadow:0 12px 40px rgba(0,0,0,.4);
}
.hub-dir-card-banner {
  height:80px; position:relative; overflow:hidden;
  background:linear-gradient(135deg,#0a1530,#1a0530);
  background-size:cover; background-position:center;
}
.hub-dir-card-banner-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to bottom,transparent 40%,var(--bg3) 100%);
}
.hub-dir-card-body { padding:14px 16px 12px; flex:1; }
.hub-dir-card-logo-row {
  display:flex; align-items:flex-end; gap:10px;
  margin-top:-24px; margin-bottom:10px;
}
.hub-dir-card-logo {
  width:46px; height:46px; border-radius:10px; overflow:hidden;
  position:relative; z-index:1; border:2px solid var(--bg3); flex-shrink:0;
  background:var(--bg4); display:flex; align-items:center; justify-content:center;
  font-family:var(--font-cond,'Barlow Condensed',sans-serif);
  font-size:16px; font-weight:900; color:var(--lime);
  background-size:cover; background-position:center;
}
.hub-verified-badge {
  font-size:9px; font-weight:800; color:var(--lime);
  background:rgba(170,255,0,.08); border:1px solid rgba(170,255,0,.2);
  padding:2px 8px; border-radius:20px; margin-bottom:4px;
  letter-spacing:.04em; text-transform:uppercase;
}
.hub-dir-card-name {
  font-family:var(--font-cond,'Barlow Condensed',sans-serif);
  font-size:16px; font-weight:900; color:var(--t1); margin-bottom:4px;
}
.hub-dir-card-sub  { font-size:11px; color:var(--t3); margin-bottom:8px; line-height:1.4; }
.hub-dir-card-stats { font-size:11px; color:var(--t3); }
.hub-dir-card-stats b { color:var(--t2); font-family:var(--mono,monospace); }
.hub-dir-card-foot {
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 16px; border-top:1px solid var(--border); margin-top:auto;
}
.hub-dir-view-btn {
  font-size:11px; font-weight:700; color:var(--lime);
  text-decoration:none; transition:.15s;
}
.hub-dir-view-btn:hover { color:var(--t1); }
.hub-dir-join-btn {
  padding:5px 14px; border-radius:6px; font-size:10px; font-weight:800;
  cursor:pointer; border:1px solid rgba(170,255,0,.25);
  background:rgba(170,255,0,.07); color:var(--lime);
  letter-spacing:.04em; text-transform:uppercase; transition:.15s;
  font-family:var(--font,sans-serif);
}
.hub-dir-join-btn:hover { background:rgba(170,255,0,.15); }
.hub-dir-member-badge { font-size:11px; font-weight:700; color:var(--lime); }
.hub-dir-empty {
  grid-column:1/-1; padding:60px; text-align:center; color:var(--t3);
  background:var(--bg3); border:1px dashed var(--border); border-radius:14px;
}

/* Tags */
.hub-tag-list { display:flex; gap:5px; flex-wrap:wrap; }
.hub-pill {
  display:inline-flex; padding:3px 9px; border-radius:20px;
  font-size:10px; font-weight:700; background:var(--bg4);
  border:1px solid var(--border); color:var(--t3); text-transform:lowercase;
}

/* Badges (shared) */
.hub-badge {
  display:inline-flex; align-items:center; gap:4px; padding:3px 9px;
  border-radius:20px; font-size:10px; font-weight:800;
  letter-spacing:.04em; text-transform:uppercase;
}
.hub-badge-verified { background:rgba(170,255,0,.1); border:1px solid rgba(170,255,0,.25); color:var(--lime); }
.hub-badge-cat      { background:var(--bg4); border:1px solid var(--border); color:var(--t3); }
.hub-badge-members  { background:rgba(25,229,255,.08); border:1px solid rgba(25,229,255,.2); color:var(--teal,#19e5ff); }
.hub-badge-twitch   { background:rgba(145,70,255,.08); border:1px solid rgba(145,70,255,.2); color:#9146ff; }

/* ─────────────────────────────────────────────────────
   SINGLE HUB PAGE
───────────────────────────────────────────────────── */
.hub-page {}

/* Banner */
.hub-banner {
  height:260px; position:relative; overflow:hidden;
  background:linear-gradient(135deg,#050B1A,#0F0520,#050B1A);
}
.hub-banner-img {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 80% 100% at 70% 50%,rgba(25,229,255,.12) 0%,transparent 60%),
    radial-gradient(ellipse 60% 80% at 20% 60%,rgba(170,255,0,.08) 0%,transparent 50%);
  background-size:cover; background-position:center; opacity:.7;
}
.hub-banner-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to bottom,transparent 40%,rgba(7,8,15,.85) 100%);
}
.hub-banner-accent {
  position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--lime),var(--teal,#19e5ff),transparent 70%);
}
.hub-banner-live-pill {
  position:absolute; top:18px; right:18px; z-index:2;
  display:flex; align-items:center; gap:8px; padding:7px 14px;
  background:rgba(255,50,80,.15); border:1px solid rgba(255,50,80,.5);
  border-radius:30px; backdrop-filter:blur(10px);
}
.hub-banner-live-dot { width:8px; height:8px; border-radius:50%; background:#FF3C5A; animation:hub-blink 1s infinite; }
.hub-banner-live-txt { font-size:11px; font-weight:900; color:#FF3C5A; letter-spacing:.06em; text-transform:uppercase; }
.hub-banner-live-count { font-family:var(--mono,monospace); font-size:11px; color:rgba(255,255,255,.6); }
.hub-banner-change-btn {
  position:absolute; bottom:14px; right:14px; z-index:2;
  padding:6px 12px; border-radius:6px; font-size:11px; font-weight:700;
  cursor:pointer; background:rgba(0,0,0,.5); border:1px solid rgba(255,255,255,.2);
  color:var(--t2); font-family:var(--font,sans-serif); transition:.15s;
}
.hub-banner-change-btn:hover { background:rgba(0,0,0,.7); color:var(--t1); }
@keyframes hub-blink { 0%,100%{opacity:1} 50%{opacity:.3} }

/* Meta row */
.hub-meta-row {
  display:flex; align-items:flex-end; gap:18px;
  margin-top:-36px; margin-bottom:18px;
  position:relative; z-index:2; flex-wrap:wrap;
}
.hub-logo-wrap { position:relative; flex-shrink:0; }
.hub-logo {
  width:76px; height:76px; border-radius:16px; overflow:hidden;
  border:3px solid var(--bg); background:var(--bg4);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-cond,'Barlow Condensed',sans-serif);
  font-size:26px; font-weight:900; color:var(--lime);
  box-shadow:0 6px 20px rgba(0,0,0,.5);
  background-size:cover; background-position:center;
}
.hub-logo-edit-btn {
  position:absolute; bottom:-6px; right:-6px;
  width:24px; height:24px; border-radius:50%; font-size:12px; cursor:pointer;
  background:var(--bg3); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
}
.hub-meta-info { flex:1; padding-bottom:4px; }
.hub-name {
  font-family:var(--font-cond,'Barlow Condensed',sans-serif);
  font-size:30px; font-weight:900; color:var(--t1); line-height:1; margin-bottom:6px;
}
.hub-badges { display:flex; gap:6px; align-items:center; flex-wrap:wrap; }
.hub-meta-actions { display:flex; gap:8px; align-items:center; flex-shrink:0; padding-bottom:4px; }

/* Tabs */
.hub-tabs {
  display:flex; gap:2px; background:var(--bg3);
  border:1px solid var(--border); border-radius:10px;
  padding:4px; margin-bottom:18px; flex-wrap:wrap;
}
.hub-tab {
  display:flex; align-items:center; gap:6px; padding:8px 16px; border-radius:7px;
  font-family:var(--font-cond,'Barlow Condensed',sans-serif);
  font-size:12px; font-weight:800; text-transform:uppercase; letter-spacing:.06em;
  cursor:pointer; border:1px solid transparent; color:var(--t2); background:transparent;
  transition:all .15s;
}
.hub-tab:hover { color:var(--t1); }
.hub-tab.active { background:var(--bg5,#20213A); color:var(--lime); border-color:rgba(170,255,0,.2); }
.hub-tab svg { opacity:.6; }
.hub-tab.active svg { opacity:1; }
.hub-tab-badge {
  display:inline-flex; align-items:center; justify-content:center;
  background:var(--red); color:#fff; font-size:9px; font-weight:900;
  min-width:16px; height:16px; border-radius:8px; padding:0 4px;
}
.hub-tab-live {
  font-size:9px; font-weight:900; color:#FF3C5A;
  background:rgba(255,50,80,.15); border:1px solid rgba(255,50,80,.3);
  padding:2px 6px; border-radius:10px; letter-spacing:.04em;
}

/* Body layout */
.hub-body { display:grid; grid-template-columns:1fr 300px; gap:20px; }
.hub-pane { display:none; }
.hub-pane.active { display:flex; flex-direction:column; gap:16px; }

/* Description */
.hub-desc-card {
  background:var(--bg3); border:1px solid var(--border); border-radius:12px;
  padding:16px 18px; font-size:13px; color:var(--t2); line-height:1.6;
}

/* Play panel */
.hub-play-panel { background:var(--bg3); border:1px solid var(--border); border-radius:12px; padding:16px; }
.hub-play-title {
  font-family:var(--font-cond,'Barlow Condensed',sans-serif);
  font-size:12px; font-weight:800; text-transform:uppercase; letter-spacing:.07em;
  color:var(--t3); margin-bottom:12px;
}
.hub-play-grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.hub-play-grid--large { grid-template-columns:repeat(3,1fr); }
.hub-play-btn {
  display:flex; flex-direction:column; align-items:flex-start; gap:3px;
  padding:14px; border-radius:10px; cursor:pointer; transition:all .2s;
  border:1px solid var(--border); background:var(--bg4); text-decoration:none;
}
.hub-play-btn:hover { border-color:rgba(170,255,0,.2); background:rgba(170,255,0,.04); transform:translateY(-2px); }
.hub-play-btn--lg { padding:20px; }
.hub-play-icon { font-size:22px; margin-bottom:4px; }
.hub-play-name { font-family:var(--font-cond,'Barlow Condensed',sans-serif); font-size:14px; font-weight:800; color:var(--t1); text-transform:uppercase; }
.hub-play-sub  { font-size:10px; color:var(--t3); }

/* Section heading */
.hub-section-head { display:flex; align-items:center; gap:10px; }
.hub-section-title { font-family:var(--font-cond,'Barlow Condensed',sans-serif); font-size:13px; font-weight:800; text-transform:uppercase; letter-spacing:.06em; color:var(--t1); }
.hub-section-line { flex:1; height:1px; background:var(--border); }
.hub-section-more { font-size:11px; color:var(--lime); cursor:pointer; background:none; border:none; font-family:var(--font,sans-serif); }

/* Announcements */
.hub-ann-card { background:var(--bg3); border:1px solid var(--border); border-radius:10px; padding:14px; transition:.15s; cursor:pointer; }
.hub-ann-card:hover { border-color:var(--border2); }
.hub-ann-type { font-size:9px; font-weight:800; text-transform:uppercase; letter-spacing:.08em; margin-bottom:6px; }
.hub-ann-type.news   { color:var(--teal,#19e5ff); }
.hub-ann-type.event  { color:var(--gold,#F5A623); }
.hub-ann-type.pinned { color:var(--lime); }
.hub-ann-title { font-size:13px; font-weight:700; color:var(--t1); margin-bottom:4px; line-height:1.4; }
.hub-ann-preview { font-size:11px; color:var(--t3); line-height:1.5; margin-bottom:8px; }
.hub-ann-content { font-size:12px; color:var(--t2); line-height:1.6; margin-bottom:8px; }
.hub-ann-foot { font-size:10px; color:var(--t3); display:flex; align-items:center; gap:6px; }

/* Members */
.hub-members-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:10px; }
.hub-member-card { background:var(--bg3); border:1px solid var(--border); border-radius:10px; padding:12px 8px; text-align:center; transition:.15s; }
.hub-member-card:hover { border-color:var(--border2); }
.hub-member-av { width:40px; height:40px; border-radius:50%; margin:0 auto 8px; background:var(--bg5); border:2px solid var(--border); display:flex; align-items:center; justify-content:center; font-size:13px; font-weight:700; color:var(--lime); background-size:cover; background-position:center; }
.hub-member-name { font-size:11px; font-weight:700; color:var(--t1); margin-bottom:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.hub-member-role { font-size:9px; color:var(--t3); text-transform:uppercase; letter-spacing:.04em; }

/* Settings */
.hub-settings-section { background:var(--bg3); border:1px solid var(--border); border-radius:12px; padding:18px; }
.hub-settings-title { font-size:13px; font-weight:800; color:var(--t1); margin-bottom:14px; }
.hub-form-row { display:flex; gap:12px; flex-wrap:wrap; }
.hub-form-group { display:flex; flex-direction:column; gap:6px; flex:1; min-width:180px; margin-bottom:12px; }
.hub-form-label { font-size:10px; font-weight:800; color:var(--t3); text-transform:uppercase; letter-spacing:.07em; }
.hub-form-input { background:var(--bg4); border:1px solid var(--border); border-radius:8px; padding:9px 12px; color:var(--t1); font-family:var(--font,sans-serif); font-size:13px; outline:none; transition:border-color .15s; }
.hub-form-input:focus { border-color:rgba(170,255,0,.35); }
.hub-form-select { background:var(--bg4); border:1px solid var(--border); border-radius:8px; padding:9px 12px; color:var(--t1); font-family:var(--font,sans-serif); font-size:13px; outline:none; cursor:pointer; }
.hub-danger-zone { background:rgba(255,50,80,.05); border:1px solid rgba(255,50,80,.2); border-radius:12px; padding:18px; }

/* Stream */
.hub-stream-panel { background:var(--bg3); border:1px solid var(--border); border-radius:12px; overflow:hidden; }
.hub-stream-header { display:flex; align-items:center; gap:10px; padding:12px 16px; border-bottom:1px solid var(--border); }
.hub-stream-live-indicator { display:flex; align-items:center; gap:6px; }
.hub-stream-live-dot { width:7px; height:7px; border-radius:50%; background:#FF3C5A; animation:hub-blink 1s infinite; }
.hub-stream-live-txt { font-size:10px; font-weight:900; color:var(--t3); text-transform:uppercase; letter-spacing:.06em; }
.hub-stream-channel { flex:1; font-size:13px; font-weight:600; color:var(--t1); }

/* Sidebar */
.hub-side-card { background:var(--bg3); border:1px solid var(--border); border-radius:12px; padding:16px; margin-bottom:14px; }
.hub-side-title { font-family:var(--font-cond,'Barlow Condensed',sans-serif); font-size:12px; font-weight:800; text-transform:uppercase; letter-spacing:.07em; color:var(--t3); margin-bottom:12px; display:flex; align-items:center; gap:8px; }
.hub-side-title::after { content:''; flex:1; height:1px; background:var(--border); }
.hub-info-list {}
.hub-info-row { display:flex; align-items:center; gap:10px; padding:6px 0; font-size:12px; color:var(--t2); border-bottom:1px solid var(--border); }
.hub-info-row:last-child { border-bottom:none; }
.hub-info-row svg { opacity:.5; flex-shrink:0; }
.hub-info-row a { color:var(--teal,#19e5ff); text-decoration:none; }
.hub-info-row a:hover { color:var(--t1); }

/* Chat mini */
.hub-chat-mini { height:200px; background:var(--bg4); border-radius:8px; padding:10px; overflow-y:auto; margin-bottom:10px; display:flex; flex-direction:column; gap:6px; }
.hub-chat-msg { display:flex; gap:8px; }
.hub-chat-msg-av { width:22px; height:22px; border-radius:50%; flex-shrink:0; background:var(--bg5); display:flex; align-items:center; justify-content:center; font-size:8px; font-weight:700; color:var(--lime); }
.hub-chat-msg-name { font-size:10px; font-weight:700; color:var(--lime); }
.hub-chat-msg-txt  { font-size:11px; color:var(--t2); line-height:1.4; }
.hub-chat-input-row { display:flex; gap:8px; align-items:center; background:var(--bg4); border:1px solid var(--border); border-radius:8px; padding:8px 12px; }
.hub-chat-input { flex:1; background:none; border:none; outline:none; color:var(--t1); font-size:12px; font-family:var(--font,sans-serif); }
.hub-chat-input::placeholder { color:var(--t3); }
.hub-chat-send { background:var(--lime); border:none; color:#050607; width:26px; height:26px; border-radius:6px; cursor:pointer; display:flex; align-items:center; justify-content:center; flex-shrink:0; }

/* Empty */
.hub-empty { padding:32px; text-align:center; color:var(--t3); font-size:13px; background:var(--bg3); border:1px solid var(--border); border-radius:12px; }

/* ── RESPONSIVE ──────────────────────────────────────── */
@media(max-width:1100px) {
  .hub-dir-grid { grid-template-columns:repeat(2,1fr); }
  .hub-body { grid-template-columns:1fr; }
  .hub-side { display:none; }
  .hub-members-grid { grid-template-columns:repeat(4,1fr); }
  .hub-stats-bar { margin-left:-24px; margin-right:-24px; padding-left:24px; padding-right:24px; }
}
@media(max-width:768px) {
  .hub-dir-grid { grid-template-columns:1fr; }
  .hub-tabs { flex-wrap:nowrap; overflow-x:auto; }
  .hub-tab { white-space:nowrap; padding:7px 12px; font-size:11px; }
  .hub-play-grid { grid-template-columns:1fr; }
  .hub-play-grid--large { grid-template-columns:repeat(2,1fr); }
  .hub-members-grid { grid-template-columns:repeat(3,1fr); }
  .hub-banner { height:180px; }
  .hub-name { font-size:22px; }
  .hub-dir-title { font-size:44px; }
  .hub-stats-bar { flex-wrap:wrap; margin-left:-16px; margin-right:-16px; padding:8px 16px; }
  .hub-stat-item { padding:10px 16px; border-right:none; border-bottom:1px solid var(--border); }
  .hub-trend-tag { display:none; }
  .hub-trending-row { display:none; }
}

[data-theme="light"] .hub-dir-card,
[data-theme="light"] .hub-side-card,
[data-theme="light"] .hub-settings-section,
[data-theme="light"] .hub-ann-card { background:var(--bg3); border-color:var(--border); }
