/* ===== NovaChat v5 social pack: mobile sidebar fix, attachments, reactions, profile, moderation ===== */
:root{--nova-danger:#ef4444;--nova-ok:#22c55e;--nova-note:#f59e0b}

/* Critical mobile chat fix */
body.nova-chat-sidebar-open{overflow:hidden!important;touch-action:none}
.sidebar-overlay{z-index:3000!important;pointer-events:none!important;opacity:0!important;display:block!important;transition:opacity .18s ease!important;background:rgba(2,6,23,.56)!important;backdrop-filter:blur(8px)!important}
.sidebar-overlay.active{opacity:1!important;pointer-events:auto!important}
.nova-chat-sidebar,.sidebar{z-index:3010!important;pointer-events:auto!important}
@media(max-width:760px){
  .nova-chat-layout{position:relative!important;height:100dvh!important;overflow:hidden!important}
  .nova-chat-sidebar,.sidebar{position:fixed!important;left:10px!important;top:10px!important;bottom:10px!important;width:min(380px,calc(100vw - 20px))!important;max-width:calc(100vw - 20px)!important;transform:translate3d(calc(-100% - 24px),0,0)!important;visibility:hidden!important;opacity:.98!important;transition:transform .22s ease,visibility .22s ease!important;box-shadow:0 22px 70px rgba(0,0,0,.42)!important;overflow:auto!important;-webkit-overflow-scrolling:touch!important}
  .nova-chat-sidebar.open,.sidebar.open{transform:translate3d(0,0,0)!important;visibility:visible!important}
  .friends-list{max-height:none!important;overflow:auto!important;padding-bottom:18px!important}
  .friend-item{position:relative!important;z-index:3020!important;touch-action:manipulation!important}
  .chat-header-actions{overflow-x:auto;max-width:45vw;padding-bottom:2px}
  .chat-header-actions .call-btn{flex:0 0 40px}
  .chat-input-form{grid-template-columns:auto auto auto 1fr auto!important;gap:7px!important}
  .chat-input{min-width:0!important}
  .message-actions-mini{opacity:1!important;transform:none!important;flex-wrap:wrap}
  .nova-modal-backdrop{padding:12px!important}
}

.friend-badges{display:flex;gap:6px;flex-wrap:wrap;margin-top:5px}.friend-badges em{font-style:normal;font-size:10px;font-weight:900;padding:4px 7px;border-radius:999px;background:color-mix(in srgb,var(--nova-brand) 14%,transparent);color:var(--nova-muted);border:1px solid var(--nova-line)}.friend-item.is-archived{opacity:.62}.friend-item.is-pinned .friend-name:before{content:'📌 ';font-size:12px}.chat-header-actions .call-btn{border:1px solid var(--nova-line)!important}.chat-header-actions .call-btn:hover{transform:translateY(-1px)}

.nova-reply-quote{width:100%;display:grid;gap:3px;text-align:left;border:0;border-left:3px solid var(--nova-brand);border-radius:12px;background:color-mix(in srgb,var(--nova-brand) 12%,transparent);padding:8px 10px;margin-bottom:8px;color:var(--nova-ink);cursor:pointer}.nova-reply-quote strong{font-size:12px}.nova-reply-quote span{font-size:12px;color:var(--nova-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nova-reply-preview{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px;padding:10px 12px;border-radius:18px;background:color-mix(in srgb,var(--nova-brand) 12%,var(--nova-card));border:1px solid var(--nova-line)}.nova-reply-preview[hidden]{display:none!important}.nova-reply-preview div{display:grid;gap:2px;min-width:0}.nova-reply-preview strong{font-size:12px;color:var(--nova-ink)}.nova-reply-preview span{font-size:12px;color:var(--nova-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nova-reply-preview button{width:32px;height:32px;border:0;border-radius:11px;background:var(--nova-surface-2);color:var(--nova-muted);cursor:pointer}

.nova-attachments{display:grid;gap:8px;margin-top:10px}.nova-attachment{display:flex;align-items:center;gap:10px;text-decoration:none;border:1px solid var(--nova-line);background:var(--nova-surface-2);border-radius:16px;padding:10px;color:var(--nova-ink);font-weight:800}.nova-attachment i{font-size:22px;color:var(--nova-brand)}.nova-attachment.image{display:grid;padding:8px}.nova-attachment.image img{width:100%;max-width:280px;max-height:240px;border-radius:13px;object-fit:cover}.nova-attachment.image span{font-size:12px;color:var(--nova-muted);padding:0 2px 3px}.nova-attachment.voice{align-items:flex-start}.nova-attachment.voice audio{width:min(270px,70vw);margin-top:6px}.nova-voice-state{display:inline-flex;align-items:center;gap:8px;margin-top:8px;padding:8px 10px;border-radius:999px;background:color-mix(in srgb,var(--nova-danger) 13%,transparent);color:var(--nova-danger);font-size:12px;font-weight:900}.nova-voice-state[hidden]{display:none!important}.nova-voice-state i{font-size:8px;animation:novaPulse 1s infinite}.sticker-btn.recording{background:var(--nova-danger)!important;color:#fff!important;box-shadow:0 0 0 6px color-mix(in srgb,var(--nova-danger) 20%,transparent)!important}

.nova-reactions-line{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}.nova-reactions-line button,.nova-reaction-popover button{border:1px solid var(--nova-line);background:var(--nova-surface-2);border-radius:999px;padding:5px 9px;cursor:pointer;color:var(--nova-ink);font-weight:900}.nova-reactions-line span{font-size:11px;color:var(--nova-muted)}.nova-reaction-popover{position:absolute;left:10px;bottom:36px;display:flex;gap:4px;padding:7px;border-radius:999px;background:var(--nova-card-strong);border:1px solid var(--nova-line);box-shadow:var(--nova-shadow);z-index:20}.message-content{position:relative}.message-edited{font-size:11px;color:var(--nova-muted)}.nova-deleted-message{color:var(--nova-muted);font-style:italic}.nova-message-highlight .message-content{outline:3px solid color-mix(in srgb,var(--nova-brand) 45%,transparent);outline-offset:3px}.message-actions-mini button{white-space:nowrap}

.nova-modal-backdrop{position:fixed;inset:0;z-index:7000;display:grid;place-items:center;background:rgba(2,6,23,.72);backdrop-filter:blur(10px)}.nova-modal-backdrop[hidden]{display:none!important}.nova-report-modal{width:min(440px,100%);display:grid;gap:12px;padding:22px;border-radius:26px;background:var(--nova-card-strong);border:1px solid var(--nova-line);box-shadow:var(--nova-shadow)}.nova-report-modal h3{margin:0;color:var(--nova-ink)}.nova-report-modal p{margin:0;color:var(--nova-muted);font-weight:700}.nova-report-modal select,.nova-report-modal textarea,.nova-v5-form input,.nova-v5-form select,.nova-v5-form textarea{width:100%;border:1px solid var(--nova-line);background:var(--nova-input);color:var(--nova-ink);border-radius:15px;padding:12px;font:inherit}.nova-report-modal div:last-child{display:flex;justify-content:flex-end;gap:8px}.nova-report-modal button{border:0;border-radius:14px;padding:11px 14px;font-weight:900;cursor:pointer}.nova-report-modal button[type=submit]{background:linear-gradient(135deg,var(--nova-brand),var(--nova-brand-2));color:#fff}

.nova-alert{border-radius:18px;padding:14px 16px;font-weight:900;border:1px solid var(--nova-line)}.nova-alert.success{background:color-mix(in srgb,var(--nova-ok) 14%,transparent);color:var(--nova-ok)}.nova-alert.error{background:color-mix(in srgb,var(--nova-danger) 14%,transparent);color:var(--nova-danger)}.nova-v5-form{display:grid;gap:10px}.nova-v5-form label{font-weight:900;color:var(--nova-muted);font-size:13px}.nova-check{display:flex!important;align-items:center;gap:9px;color:var(--nova-ink)!important}.nova-check input{width:auto!important}.nova-inline-form{grid-template-columns:1fr auto;align-items:end}.nova-v5-list{display:grid;gap:10px}.nova-v5-row{display:grid;grid-template-columns:42px 1fr auto;gap:10px;align-items:center;padding:10px;border-radius:18px;background:var(--nova-surface-2);border:1px solid var(--nova-line)}.nova-v5-row img{width:42px;height:42px;border-radius:14px;object-fit:cover}.nova-v5-row button{border:0;border-radius:12px;padding:9px 12px;background:var(--nova-danger);color:#fff;font-weight:900;cursor:pointer}

.nova-notification-row{display:grid;grid-template-columns:48px 1fr auto;align-items:center;gap:12px;text-decoration:none;color:var(--nova-ink);padding:13px;border-radius:20px;background:var(--nova-surface-2);border:1px solid var(--nova-line);transition:.16s ease}.nova-notification-row:hover{transform:translateY(-1px);background:var(--hover-bg)}.nova-notification-row.unread{border-color:color-mix(in srgb,var(--nova-brand) 55%,var(--nova-line));box-shadow:0 0 0 3px color-mix(in srgb,var(--nova-brand) 10%,transparent)}.nova-notification-icon{width:48px;height:48px;border-radius:17px;display:grid;place-items:center;background:linear-gradient(135deg,var(--nova-brand),var(--nova-brand-2));color:#fff}.nova-notification-body{display:grid;gap:3px;min-width:0}.nova-notification-body strong{font-size:15px}.nova-notification-body em{font-style:normal;color:var(--nova-muted);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nova-notification-body small{color:var(--nova-soft);font-weight:800}.nova-notification-user{font-size:12px;color:var(--nova-muted);font-weight:900}

.nova-profile-upload-panel{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}.nova-profile-upload-panel label{display:flex;align-items:center;justify-content:center;gap:8px;min-height:44px;border:1px solid var(--nova-line);border-radius:15px;background:var(--nova-surface-2);cursor:pointer;font-weight:900}.nova-profile-cover-v5{height:220px;border-radius:28px;background:linear-gradient(135deg,var(--nova-brand),var(--nova-brand-2));background-size:cover;background-position:center;border:1px solid var(--nova-line);margin-bottom:-70px}.nova-profile-v5-card{position:relative;background:var(--nova-card-strong);border:1px solid var(--nova-line);border-radius:30px;padding:86px 22px 22px;box-shadow:var(--nova-shadow)}

@media(max-width:620px){.nova-v5-row{grid-template-columns:38px 1fr}.nova-v5-row button{grid-column:1/-1}.nova-notification-row{grid-template-columns:44px 1fr}.nova-notification-user{grid-column:2}.nova-profile-upload-panel{grid-template-columns:1fr}.nova-inline-form{grid-template-columns:1fr}.nova-attachment.image img{max-width:100%}}
