/* BL-Modern · Дашборд-хаб (единое окно). Использует переменные из cabinet.css + feed.css */
.hub-top { position: sticky; top: 0; z-index: 60; display: flex; align-items: center; gap: 14px; padding: 10px 18px; background: rgba(10,16,26,.92); backdrop-filter: blur(12px); border-bottom: 1px solid var(--border); }
.hub-top .brand { display: flex; align-items: center; gap: 10px; text-decoration: none; }
.hub-top .brand img { width: 34px; height: 34px; }
.hub-top .brand strong { color: #fff; font-family: 'Space Grotesk', sans-serif; display: block; line-height: 1; }
.hub-top .brand em { color: var(--muted); font-style: normal; font-size: .72rem; }
.hub-search { position: relative; flex: 1; max-width: 460px; }
.hub-search input { width: 100%; background: var(--s2); border: 1px solid var(--border); color: #fff; border-radius: 11px; padding: 10px 14px 10px 38px; font: inherit; outline: none; }
.hub-search input:focus { border-color: var(--gold); }
.hub-search i { position: absolute; left: 13px; top: 50%; transform: translateY(-50%); color: var(--muted); }
.hub-sr { position: absolute; top: 46px; left: 0; right: 0; background: var(--s2); border: 1px solid var(--border); border-radius: 12px; box-shadow: 0 18px 50px rgba(0,0,0,.5); padding: 6px; display: none; z-index: 70; max-height: 60vh; overflow-y: auto; }
.hub-sr.open { display: block; }
.hub-sr a { display: flex; align-items: center; gap: 10px; padding: 9px 11px; border-radius: 9px; color: #fff; text-decoration: none; }
.hub-sr a:hover { background: #0b1320; }
.hub-top .actions { display: flex; align-items: center; gap: 8px; margin-left: auto; }
.hub-bell { position: relative; background: var(--s2); border: 1px solid var(--border); color: var(--text); width: 40px; height: 40px; border-radius: 11px; cursor: pointer; }
.hub-bell .dot, .hub-nav .badge { background: var(--red); color: #fff; font-size: .68rem; font-weight: 800; border-radius: 999px; min-width: 17px; height: 17px; padding: 0 4px; display: grid; place-items: center; }
.hub-bell .dot { position: absolute; top: -5px; right: -5px; }

.hub { display: grid; grid-template-columns: 230px minmax(0,1fr) 290px; gap: 18px; width: min(1280px, calc(100% - 32px)); margin: 18px auto 60px; align-items: start; }
.hub-nav { position: sticky; top: 78px; background: var(--s2); border: 1px solid var(--border); border-radius: 16px; padding: 10px; display: flex; flex-direction: column; gap: 2px; }
.hub-nav a { display: flex; align-items: center; gap: 12px; padding: 11px 13px; border-radius: 11px; color: var(--text); text-decoration: none; font-weight: 600; }
.hub-nav a i { width: 20px; text-align: center; color: var(--muted); }
.hub-nav a:hover { background: #0b1320; }
.hub-nav a.on { background: rgba(245,204,0,.1); color: var(--gold); }
.hub-nav a.on i { color: var(--gold); }
.hub-nav .badge { margin-left: auto; }
.hub-nav .sep { height: 1px; background: var(--border); margin: 8px 4px; }

.hub-main { min-width: 0; padding: 0; }
.hub-rail { position: sticky; top: 78px; display: flex; flex-direction: column; gap: 14px; }
.rail-card { background: var(--s2); border: 1px solid var(--border); border-radius: 16px; padding: 14px; }
.rail-card h4 { color: #fff; font-size: .95rem; margin: 0 0 10px; }
.rail-me { display: flex; align-items: center; gap: 11px; }
.rail-ava { width: 46px; height: 46px; border-radius: 12px; overflow: hidden; position: relative; display: grid; place-items: center; font-weight: 800; color: #0a1119; }
.rail-ava img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.rail-name { color: #fff; font-weight: 700; }
.rail-bal { color: var(--gold); font-size: .85rem; }
.rail-online { display: flex; align-items: center; justify-content: space-between; color: var(--muted); font-size: .85rem; margin-bottom: 6px; }
.rail-online b { color: #fff; }
.sug { display: flex; align-items: center; gap: 9px; padding: 7px 0; }
.sug .a { color: #fff; text-decoration: none; font-weight: 600; font-size: .9rem; flex: 1; }
.sug button { font-size: .78rem; padding: 5px 10px; }

/* МЕССЕНДЖЕР */
.ms { display: grid; grid-template-columns: 280px minmax(0,1fr); gap: 14px; }
.ms-list { background: var(--s2); border: 1px solid var(--border); border-radius: 16px; padding: 8px; height: 72vh; overflow-y: auto; }
.ms-list .top { display: flex; gap: 8px; padding: 6px; }
.ms-list .top button { flex: 1; }
.ms-conv { display: flex; gap: 10px; align-items: center; padding: 10px; border-radius: 11px; cursor: pointer; }
.ms-conv:hover { background: #0b1320; } .ms-conv.on { background: rgba(245,204,0,.08); }
.ms-cava { width: 42px; height: 42px; border-radius: 11px; overflow: hidden; position: relative; display: grid; place-items: center; font-weight: 800; color: #0a1119; flex: none; }
.ms-cava img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.ms-cava.grp { background: #2a3b54; color: #fff; }
.ms-cbody { min-width: 0; flex: 1; }
.ms-ctitle { color: #fff; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ms-clast { color: var(--muted); font-size: .82rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ms-cmeta { text-align: right; flex: none; }
.ms-cmeta .ago { color: var(--faint); font-size: .72rem; }
.ms-cmeta .badge { background: var(--gold); color: #0a1119; font-weight: 800; border-radius: 999px; font-size: .7rem; padding: 1px 7px; display: inline-block; margin-top: 4px; }
.ms-chat { background: var(--s2); border: 1px solid var(--border); border-radius: 16px; display: flex; flex-direction: column; height: 72vh; min-height: 0; }
.ms-head { display: flex; align-items: center; gap: 10px; padding: 13px 16px; border-bottom: 1px solid var(--border); }
.ms-head .t { color: #fff; font-weight: 700; }
.ms-head .s { color: var(--muted); font-size: .8rem; }
.ms-body { flex: 1; min-height: 0; padding: 16px; display: flex; flex-direction: column; gap: 8px; overflow-y: auto; }
.mm-img { max-width: 240px; max-height: 240px; border-radius: 10px; margin-top: 4px; display: block; cursor: pointer; }
.ms-attach { display: inline-grid; place-items: center; width: 40px; flex: none; color: var(--muted); cursor: pointer; border: 1px solid var(--border); border-radius: 11px; }
.ms-attach:hover { color: #fff; border-color: var(--bh); }
.ms-game { flex: none; width: 40px; padding: 0; display: inline-grid; place-items: center; }
.ms-game.on { color: #fff; background: rgba(168, 85, 247, .18); border-color: #a855f7; box-shadow: 0 0 0 1px #a855f7 inset; }
.ms-game.on i { color: #c8a2ff; }
.ms-imgprev { display: flex; align-items: center; gap: 8px; padding: 6px 14px; }

/* ── Игровой глобальный чат ── */
.gc-wrap { display: flex; flex-direction: column; height: calc(100vh - 130px); min-height: 420px; padding: 0; overflow: hidden; }
.gc-head { display: flex; align-items: center; gap: 12px; padding: 12px 14px; border-bottom: 1px solid var(--border); flex-wrap: wrap; }
.gc-tabs { display: flex; gap: 6px; }
.gc-tab { display: inline-flex; align-items: center; gap: 7px; padding: 7px 14px; border: 1px solid var(--border); background: transparent; color: var(--muted); border-radius: 999px; cursor: pointer; font: inherit; font-size: .9rem; }
.gc-tab:hover { color: #fff; border-color: var(--bh); }
.gc-tab.on { color: #fff; background: rgba(95, 176, 255, .16); border-color: #5fb0ff; }
.gc-hint { margin-left: auto; color: var(--muted); font-size: .82rem; }
.gc-body { flex: 1; overflow-y: auto; padding: 12px 14px; display: flex; flex-direction: column; gap: 9px; }
.gc-earlier { align-self: center; margin-bottom: 4px; padding: 7px 16px; border-radius: 999px; border: 1px solid var(--border); background: var(--s2); color: var(--muted); font: inherit; font-size: .82rem; font-weight: 600; cursor: pointer; display: inline-flex; align-items: center; gap: 7px; }
.gc-earlier:hover:not([disabled]) { color: #fff; border-color: var(--bh); }
.gc-earlier[disabled] { opacity: .5; cursor: default; }
.gc-msg { display: grid; grid-template-columns: auto auto 1fr; align-items: start; gap: 8px; }
.gc-srv { flex: none; align-self: center; font-size: .68rem; font-weight: 700; padding: 2px 7px; border-radius: 6px; background: #2a3b54; color: #cfe0f5; letter-spacing: .3px; }
.gc-srv.tfgm1 { background: rgba(24, 217, 138, .18); color: #18d98a; }
.gc-srv.tfgm2 { background: rgba(224, 64, 96, .18); color: #ff6b81; }
.gc-ava { width: 28px; height: 28px; border-radius: 8px; display: inline-grid; place-items: center; overflow: hidden; color: #061018; font-weight: 700; font-size: .8rem; flex: none; }
.gc-ava img { width: 100%; height: 100%; object-fit: cover; }
.gc-bd { min-width: 0; line-height: 1.4; }
.gc-au { color: #fff; font-weight: 600; text-decoration: none; }
.gc-au:hover { text-decoration: underline; }
.gc-tx { color: var(--text); word-break: break-word; }
.gc-ago { color: var(--muted); font-size: .74rem; margin-left: 6px; white-space: nowrap; }
.gc-img { display: block; margin-top: 5px; max-width: 220px; max-height: 220px; border-radius: 10px; cursor: pointer; border: 1px solid var(--border); }
.gc-foot { padding: 9px 14px; border-top: 1px solid var(--border); color: var(--muted); font-size: .82rem; }
.gc-send { display: flex; gap: 8px; padding: 10px 14px; border-top: 1px solid var(--border); align-items: center; }
.gc-srvsel { flex: none; border: 1px solid var(--border); background: #0b1320; color: #fff; border-radius: 11px; padding: 10px 10px; outline: none; cursor: pointer; }
.gc-send input { flex: 1; min-width: 0; border: 1px solid var(--border); background: #0b1320; color: #fff; border-radius: 11px; padding: 11px 14px; outline: none; }
.gc-send input:focus { border-color: #5fb0ff; }
.gc-send .btn { flex: none; }
.srv-dot.d1 { background: #18d98a; }
.srv-dot.d2 { background: #ff6b81; }
.ms-imgprev img { max-height: 70px; border-radius: 8px; border: 1px solid var(--border); }
.ms-imgprev button { background: rgba(0,0,0,.5); color: #fff; border: 0; width: 26px; height: 26px; border-radius: 7px; cursor: pointer; }
.mm { max-width: 74%; padding: 9px 13px; border-radius: 13px; border: 1px solid var(--border); background: var(--s1); }
.mm.me { align-self: flex-end; background: #16314a; border-color: transparent; }
.mm .h { font-size: .74rem; color: var(--muted); margin-bottom: 3px; }
.mm .b { color: var(--text); white-space: pre-wrap; overflow-wrap: anywhere; line-height: 1.4; }
.ms-bar { display: flex; gap: 9px; padding: 12px 14px; border-top: 1px solid var(--border); }
.ms-bar input { flex: 1; border: 1px solid var(--border); background: #0b1320; color: #fff; border-radius: 11px; padding: 11px 14px; font: inherit; outline: none; }
.ms-bar input:focus { border-color: var(--gold); }
.ms-empty { margin: auto; color: var(--muted); text-align: center; padding: 30px; }

/* игроки */
.pp-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(220px,1fr)); gap: 12px; }
.pp { display: flex; align-items: center; gap: 11px; background: var(--s2); border: 1px solid var(--border); border-radius: 14px; padding: 12px; overflow: hidden; }
.pp > div { flex: 1; min-width: 0; }
.pp-ava { width: 46px; height: 46px; border-radius: 12px; overflow: hidden; position: relative; display: grid; place-items: center; font-weight: 800; color: #0a1119; flex: none; }
.pp-ava img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.pp-nm { color: #fff; font-weight: 700; text-decoration: none; display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pp-act { display: flex; gap: 6px; margin-top: 6px; flex-wrap: wrap; }
.pp-act .btn { font-size: .76rem; padding: 5px 9px; min-width: 0; }

.hub-title { color: #fff; font-family: 'Space Grotesk', sans-serif; font-size: 1.5rem; font-weight: 700; margin: 0 0 14px; }

@media (max-width: 1100px) { .hub { grid-template-columns: 76px minmax(0,1fr); } .hub-rail { display: none; } .hub-nav a span { display: none; } .hub-nav a { justify-content: center; position: relative; } .hub-nav .badge { position: absolute; top: 4px; right: 8px; } }

/* мобайл: нижняя панель-иконки */
@media (max-width: 760px) {
    .hub { grid-template-columns: 1fr; gap: 0; margin-top: 12px; }
    .hub-main { padding-bottom: 74px; }
    .hub-nav {
        position: fixed; left: 0; right: 0; bottom: 0; top: auto;
        flex-direction: row; justify-content: space-around; align-items: center;
        border-radius: 0; border: 0; border-top: 1px solid var(--border);
        background: rgba(10,16,26,.97); backdrop-filter: blur(12px);
        padding: 6px 4px; gap: 0; overflow-x: auto; z-index: 80;
    }
    .hub-nav .sep { display: none; }
    .hub-nav a:not([data-route]) { display: none; }   /* второстепенное прячем, оно есть в Кабинете/Профиле */
    .hub-nav a { flex-direction: column; gap: 3px; font-size: .62rem; padding: 6px 10px; min-width: 56px; }
    .hub-nav a span { display: block; }
    .hub-nav a i { font-size: 1.15rem; }
    .hub-nav .badge { position: absolute; top: 2px; right: 12px; }
    .ms { grid-template-columns: 1fr; }
    .ms-list.has-active { display: none; }
    .hub-search { max-width: none; }
}

.srv-dot { display:inline-block; width:8px; height:8px; border-radius:50%; background:var(--red); margin-right:4px; }
.srv-dot.on { background:var(--green); }
.hub .gd-toolbar { display:flex; gap:10px; margin-bottom:14px; flex-wrap:wrap; }
.hub .gd-search { flex:1; min-width:160px; background:var(--s2); border:1px solid var(--border); color:#fff; border-radius:11px; padding:10px 14px; font:inherit; outline:none; }
.hub .gd-search:focus { border-color:var(--gold); }
.hub-sr a .btn { flex:none; }

/* онлайн на сайте */
.pres-dot { position:absolute; right:-2px; bottom:-2px; width:11px; height:11px; border-radius:50%; background:var(--green); border:2px solid var(--s2); }
.pres-chip { display:inline-flex; align-items:center; gap:5px; margin-left:8px; font-size:.78rem; color:var(--green); vertical-align:middle; }
.pres-chip .pres-dot { width:9px; height:9px; border:0; }
