
.brand { display: flex; align-items: center; gap: 14px; }
.brand-logo { width: 56px; height: 56px; border-radius: 16px; object-fit: cover; box-shadow: var(--shadow); }
.brand h1, .hero-copy h2, .section-head h3, .post-view h2, .post-card h4 { margin: 0; }
.brand p, .hero-copy p { margin: 6px 0 0; color: var(--muted); }
.nav { display: grid; gap: 8px; }
.nav-link, .ghost-btn, .primary-btn, .pill-btn, .counter-btn, .tab {
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  transition: transform var(--normal) var(--ease), background-color var(--fast) ease, border-color var(--fast) ease, box-shadow var(--normal) var(--ease), opacity var(--fast) ease;
}
.nav-link, .ghost-btn, .pill-btn, .counter-btn, .tab {
  background: var(--panel-2);
  color: var(--text);
  padding: 12px 14px;
}
.primary-btn {
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: white;
  border: none;
  padding: 13px 16px;
  box-shadow: 0 14px 30px rgba(72,128,233,.22);
}
.nav-link:hover, .ghost-btn:hover, .pill-btn:hover, .counter-btn:hover, .tab:hover, .primary-btn:hover { transform: translateY(-2px); }
.nav-link.is-active, .pill-btn.is-active, .tab.is-active {
  background: var(--accent-soft);
  border-color: rgba(109,168,255,.22);
  color: var(--accent-2);
}
.search-input { min-width: 0; }
.toolbar { display: grid; grid-template-columns: minmax(0, 1fr) 220px; gap: 12px; }
.select-like { width: 100%; text-align: left; }
.hero-meta, .section-badges, .post-actions, .comment-form-actions, .auth-actions, .profile-stats, .profile-header, .favorite-item, .message-row, .dm-form { display: flex; gap: 12px; }
.hero-meta, .section-badges, .post-actions, .comment-form-actions, .profile-stats { flex-wrap: wrap; }
.hero-stat, .stat, .badge, .role-chip, .status-chip {
  background: var(--panel-2);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 10px 14px;
}
.hero-stat { display: grid; gap: 4px; min-width: 130px; }
.badge, .role-chip, .status-chip { font-size: 13px; }
.post-card {
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel) 96%, transparent), color-mix(in srgb, var(--panel-2) 92%, transparent));
  box-shadow: var(--shadow);
}
.post-card .muted, .favorite-item p { margin: 0; }
.post-meta { color: var(--muted); font-size: 14px; }
.post-actions { align-items: center; justify-content: space-between; }
.counter-btn.is-active { background: var(--accent-soft); border-color: rgba(109,168,255,.22); }
.danger-btn { border-color: rgba(255,127,136,.24); color: var(--danger); }
.online-counter { font-size: 22px; font-weight: 800; }
.online-list, .user-search-results, .conversation-list, .favorite-list { display: grid; gap: 10px; }
.online-user, .search-user, .conversation-item, .favorite-item, .comment-card, .notification-item {
  padding: 12px 14px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line);
  background: var(--panel-2);
}
.search-user, .conversation-item { cursor: pointer; }
.search-user:hover, .conversation-item:hover { transform: translateY(-1px); }
.conversation-item.is-active { border-color: rgba(109,168,255,.28); background: var(--accent-soft); }
.user-line { display: flex; align-items: center; gap: 10px; }
.mini-avatar, .avatar {
  width: 42px; height: 42px; border-radius: 14px; display: grid; place-items: center;
  background: linear-gradient(135deg, var(--accent), var(--accent-2)); color: white; font-weight: 800;
}
.avatar { width: 72px; height: 72px; border-radius: 22px; }
.post-view .body, .comment-body { white-space: pre-wrap; line-height: 1.6; }
.comments-wrap { display: grid; gap: 12px; }
.comment-form textarea, .dm-form textarea { min-height: 110px; }
.comment-replies { display: grid; gap: 10px; margin-top: 12px; margin-left: 16px; padding-left: 14px; border-left: 1px solid var(--line); }
.reply-label { color: var(--accent-2); min-height: 20px; }
.empty-state { padding: 28px; text-align: center; }
.modal {
  position: fixed; inset: 0; z-index: 30; display: grid; place-items: center;
  background: rgba(7,10,16,.55); backdrop-filter: blur(10px);
}
.modal-card {
  width: min(100% - 24px, 460px);
  background: var(--panel);
  border-radius: 28px;
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  padding: 22px;
  display: grid;
  gap: 14px;
  position: relative;
}
.modal-close { position: absolute; top: 16px; right: 16px; border: none; background: transparent; color: var(--muted); font-size: 26px; }
.tabs { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; }
.auth-form, .profile-form, .admin-form { display: grid; gap: 12px; }
.form-error { min-height: 22px; color: var(--danger); }
.toast-stack { position: fixed; right: 20px; bottom: 20px; display: grid; gap: 10px; z-index: 60; }
.toast { padding: 14px 16px; border-radius: 16px; background: color-mix(in srgb, var(--panel) 95%, transparent); border: 1px solid var(--line); box-shadow: var(--shadow); }
.messages-main { display: grid; gap: 12px; }
.dm-messages { min-height: 420px; max-height: 60vh; overflow: auto; display: grid; gap: 10px; padding-right: 4px; }
.message-bubble { max-width: min(620px, 82%); padding: 12px 14px; border-radius: 18px; border: 1px solid var(--line); background: var(--panel-2); }
.message-bubble.from-me { margin-left: auto; background: var(--accent-soft); border-color: rgba(109,168,255,.26); }
.message-meta { margin-top: 6px; color: var(--muted); font-size: 12px; }
.profile-card { display: grid; gap: 16px; }
.favorite-item { display: grid; gap: 8px; }
.admin-panel { display: grid; gap: 12px; padding-top: 8px; border-top: 1px solid var(--line); }
.status-dot { width: 10px; height: 10px; border-radius: 999px; display: inline-block; background: rgba(255,255,255,.2); margin-left: 6px; }
.status-dot.online { background: var(--success); box-shadow: 0 0 0 6px rgba(117,217,152,.12); }

.counter-btn.is-negative { background: rgba(255,127,136,.12); border-color: rgba(255,127,136,.24); color: #ff9ea4; }
.post-author-line { display:flex; align-items:center; gap:12px; }
.post-cover { border-radius: 22px; overflow:hidden; border:1px solid var(--line); background: var(--panel-2); }
.post-cover img { display:block; width:100%; max-height:420px; object-fit:cover; }
.tiny-avatar { width: 28px; height: 28px; border-radius: 10px; display:grid; place-items:center; background: linear-gradient(135deg, var(--accent), var(--accent-2)); color:white; font-size:12px; font-weight:800; }
.admin-image-preview { display:grid; gap:10px; padding:12px; border:1px solid var(--line); border-radius:18px; background: var(--panel-2); }
.admin-image-preview img { width:100%; max-height:220px; object-fit:cover; border-radius:16px; }
.messages-main { display:grid; gap:14px; min-height: 620px; background: linear-gradient(180deg, color-mix(in srgb, var(--panel) 98%, transparent), color-mix(in srgb, var(--panel-2) 95%, transparent)); }
.dm-topbar { display:flex; align-items:center; justify-content:space-between; gap:14px; padding: 4px 2px 10px; border-bottom:1px solid var(--line); }
.dm-messages { min-height: 420px; max-height: 62vh; overflow: auto; display: flex; flex-direction: column; gap: 10px; padding: 8px 4px 4px; }
.message-row { display:flex; align-items:flex-end; gap:10px; }
.message-row.from-me { justify-content:flex-end; }
.message-row.from-them { justify-content:flex-start; }
.message-bubble { max-width: min(520px, 72%); padding: 12px 14px 10px; border-radius: 22px; border: 1px solid var(--line); background: rgba(255,255,255,.03); box-shadow: inset 0 1px 0 rgba(255,255,255,.04); }
.message-bubble.from-me { margin-left: auto; background: linear-gradient(180deg, rgba(109,168,255,.24), rgba(109,168,255,.16)); border-color: rgba(109,168,255,.3); }
.message-text { line-height: 1.45; word-break: break-word; }
.message-meta { margin-top: 6px; color: var(--muted); font-size: 12px; text-align: right; }
.dm-form { display:grid; grid-template-columns: minmax(0,1fr) auto; align-items:end; gap:12px; padding-top: 8px; border-top:1px solid var(--line); }
.dm-form textarea { min-height: 56px; max-height: 140px; resize: vertical; border-radius: 20px; }
.conversation-preview { margin-top: 8px; }
.empty-chat { display:grid; place-items:center; min-height: 220px; color: var(--muted); text-align:center; border:1px dashed var(--line); border-radius:22px; }

/* Telegram-like chat */

.chat-messages{display:flex;flex-direction:column;gap:6px;padding:16px;overflow-y:auto}
.message-row{display:flex;gap:8px;align-items:flex-end}
.message{max-width:65%;padding:10px 14px;border-radius:16px;font-size:14px}
.message.me{align-self:flex-end;background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff;border-bottom-right-radius:4px}
.message.other{background:#1e2a38;border-bottom-left-radius:4px}
.message-time{font-size:11px;opacity:.6;margin-top:4px;text-align:right}
.avatar{width:28px;height:28px;border-radius:50%}
.chat-input{display:flex;gap:8px;padding:10px;border-top:1px solid rgba(255,255,255,.05)}
.chat-input textarea{flex:1;resize:none;border-radius:18px;padding:10px 14px;background:#1c2735;border:none;color:#fff}
.send-btn{background:linear-gradient(135deg,#4facfe,#00f2fe);border:none;border-radius:50%;width:42px;height:42px}


.online-list-anonymous { min-height: 0; }
.anonymous-online { display: grid; gap: 6px; }
.register-code-row { display:grid; grid-template-columns:minmax(0,1fr) auto; gap:10px; }
.auth-hint { margin-top:-4px; }
.field-label { font-size: 13px; color: var(--muted); }
.post-icon-avatar { object-fit: cover; }
.post-avatar-preview { width: 84px; height: 84px; border-radius: 24px; object-fit: cover; }


.mobile-tabbar {
  position: fixed;
  left: 12px;
  right: 12px;
  bottom: calc(12px + env(safe-area-inset-bottom));
  z-index: 45;
  display: none;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  padding: 8px;
  border-radius: 22px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--panel) 92%, transparent);
  backdrop-filter: blur(18px);
  box-shadow: var(--shadow);
}
.mobile-tab {
  border: 1px solid transparent;
  border-radius: 16px;
  background: transparent;
  color: var(--muted);
  padding: 12px 10px;
  font-weight: 700;
}
.mobile-tab.is-active {
  background: var(--accent-soft);
  color: var(--text);
  border-color: rgba(109,168,255,.25);
}
.dm-back-btn { display: none; padding: 10px 12px; min-width: 44px; }
.post-card, .favorite-item, .comment-card, .conversation-item, .search-user { min-width: 0; }
.messages-sidebar { min-width: 0; }
.messages-main { min-width: 0; }
@supports (height: 100dvh) {
  .app-shell, .sidebar { min-height: 100dvh; height: auto; }
}


.dm-banner {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin: 0 0 6px;
  padding: 13px 14px;
  border-radius: 18px;
  border: 1px solid rgba(148, 163, 184, 0.14);
  background: linear-gradient(180deg, rgba(96, 165, 250, 0.12), rgba(96, 165, 250, 0.06));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
}
.dm-banner.is-dnd {
  background: linear-gradient(180deg, rgba(250, 204, 21, 0.12), rgba(250, 204, 21, 0.05));
  border-color: rgba(250, 204, 21, 0.2);
}
.dm-banner__icon {
  width: 30px;
  height: 30px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  flex: 0 0 30px;
  background: rgba(255,255,255,.07);
  color: var(--text);
  font-size: 14px;
  font-weight: 800;
}
.dm-banner__title {
  font-size: 13px;
  font-weight: 800;
  color: rgba(226, 232, 240, 0.95);
}
.dm-banner__text {
  margin-top: 2px;
  font-size: 13px;
  line-height: 1.35;
  color: rgba(203, 213, 225, 0.82);
}
