:root{--bg:#eef2f7;--panel:#fff;--panel2:#f7f9fc;--text:#111827;--muted:#667085;--line:#e5e7eb;--brand:#2aabee;--brand2:#1d8bd1;--danger:#ef4444;--bubble-me:#daf0ff;--bubble-other:#fff;--shadow:0 18px 60px rgba(15,23,42,.12);--radius:18px;--safe-bottom:env(safe-area-inset-bottom,0px);--safe-top:env(safe-area-inset-top,0px)}
[data-theme="dark"]{--bg:#0f172a;--panel:#111827;--panel2:#1f2937;--text:#f8fafc;--muted:#a3adc2;--line:#2e3a4e;--brand:#38bdf8;--brand2:#0284c7;--bubble-me:#103a53;--bubble-other:#1f2937;--shadow:0 18px 60px rgba(0,0,0,.35)}
*{box-sizing:border-box} [hidden]{display:none!important} html,body{height:100%;margin:0;overflow:hidden;font-family:Inter,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text);direction:ltr} button,input,textarea,select{font:inherit} button{cursor:pointer} a{color:inherit}.shell{height:100dvh;display:grid;grid-template-columns:360px minmax(0,1fr);max-width:1480px;margin:0 auto;background:var(--panel);box-shadow:var(--shadow)}
.chat-list{border-right:1px solid var(--line);background:var(--panel);display:flex;flex-direction:column;min-width:0}.list-header{height:64px;padding:10px 12px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line);padding-top:calc(10px + var(--safe-top))}.brand{display:flex;flex-direction:column;line-height:1.05;flex:1}.brand strong{font-size:20px}.brand span{font-size:12px;color:var(--muted)}.round-btn,.composer-btn{width:40px;height:40px;border:0;border-radius:999px;background:var(--panel2);color:var(--text);display:inline-grid;place-items:center;flex:0 0 auto}.round-btn:hover,.composer-btn:hover{background:color-mix(in srgb,var(--brand) 14%,var(--panel2))}.search-box{position:relative;padding:10px;border-bottom:1px solid var(--line)}.search-box input{width:100%;border:1px solid var(--line);border-radius:999px;padding:12px 16px;background:var(--panel2);color:var(--text);outline:0}.search-box input:focus{border-color:var(--brand)}.search-results{position:absolute;z-index:20;top:58px;left:10px;right:10px;background:var(--panel);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);max-height:65dvh;overflow:auto;padding:8px}.search-item,.room-item,.member-item{display:flex;align-items:center;gap:12px;padding:10px;border-radius:14px;border:0;background:transparent;color:var(--text);width:100%;text-align:left}.search-item:hover,.room-item:hover,.member-item:hover,.room-item.active{background:var(--panel2)}.rooms{overflow:auto;min-height:0;padding:8px}.avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--brand),#7c3aed);color:white;border:0;display:grid;place-items:center;font-weight:800;overflow:hidden;flex:0 0 auto}.avatar.small{width:54px;height:54px;font-size:20px}.avatar img{width:100%;height:100%;object-fit:cover}.room-main{min-width:0;flex:1}.room-line{display:flex;justify-content:space-between;gap:8px;align-items:baseline}.room-title-text{font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-time{font-size:11px;color:var(--muted);white-space:nowrap}.room-last{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13px;min-width:0}.room-last span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge{background:var(--brand);color:white;border-radius:999px;padding:2px 7px;font-size:11px;margin-left:auto}.chat-view{height:100dvh;display:flex;flex-direction:column;min-width:0;background:linear-gradient(180deg,color-mix(in srgb,var(--bg) 75%,var(--panel)),var(--bg))}.chat-header{height:64px;display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--line);background:color-mix(in srgb,var(--panel) 94%,transparent);backdrop-filter:blur(12px);padding-top:calc(10px + var(--safe-top));flex:0 0 auto}.room-avatar{width:44px;height:44px}.title-btn{border:0;background:transparent;color:var(--text);text-align:left;min-width:0;flex:1;padding:0}.title-btn strong,.title-btn span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.title-btn span{font-size:12px;color:var(--muted);margin-top:2px}.pinned{display:flex;align-items:center;gap:8px;background:var(--panel);border-bottom:1px solid var(--line);padding:8px 12px;flex:0 0 auto}.pinned button:first-child{border:0;background:transparent;text-align:left;color:var(--text);flex:1}.pinned b{display:block;font-size:12px;color:var(--brand)}.pinned span{display:block;color:var(--muted);font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.messages{flex:1;min-height:0;overflow:auto;padding:18px max(16px,calc((100% - 850px)/2));scroll-behavior:smooth}.empty-state{height:100%;display:grid;place-content:center;text-align:center;color:var(--muted);gap:6px}.empty-state b{color:var(--text);font-size:20px}.day-divider{text-align:center;color:var(--muted);font-size:12px;margin:18px}.message-row{display:flex;gap:8px;margin:7px 0;align-items:flex-end}.message-row.me{justify-content:flex-end}.message-row .avatar{width:30px;height:30px;font-size:12px}.bubble{max-width:min(680px,78%);padding:8px 10px;border-radius:17px;background:var(--bubble-other);box-shadow:0 1px 1px rgba(0,0,0,.05);position:relative;user-select:none;-webkit-user-select:none;touch-action:manipulation;border:1px solid color-mix(in srgb,var(--line) 70%,transparent)}.message-row.me .bubble{background:var(--bubble-me);border-bottom-right-radius:6px}.message-row:not(.me) .bubble{border-bottom-left-radius:6px}.sender{font-size:12px;font-weight:700;color:var(--brand);margin-bottom:2px}.sender button{border:0;background:transparent;color:inherit;padding:0;font-weight:inherit}.reply-preview{border-left:3px solid var(--brand);padding:5px 7px;background:rgba(42,171,238,.12);border-radius:8px;margin-bottom:5px;font-size:12px}.reply-preview b{display:block}.msg-text{white-space:pre-wrap;word-wrap:break-word;line-height:1.45}.msg-text .copy-chip{display:inline-block;border:1px dashed var(--brand);border-radius:8px;padding:1px 5px;margin:0 2px;background:rgba(42,171,238,.12)}.msg-meta{display:flex;align-items:center;justify-content:flex-end;gap:5px;color:var(--muted);font-size:10px;margin-top:3px}.edited{font-style:italic}.msg-media img{max-width:min(320px,70vw);border-radius:13px;display:block}.msg-media video{max-width:min(360px,72vw);border-radius:13px}.msg-media audio{width:min(330px,72vw)}.file-card{display:flex;align-items:center;gap:10px;padding:10px;border:1px solid var(--line);border-radius:12px;text-decoration:none;background:rgba(255,255,255,.08)}.file-ico{font-size:24px}.sticker{font-size:46px;line-height:1.1}.composer-wrap{border-top:1px solid var(--line);background:color-mix(in srgb,var(--panel) 96%,transparent);padding:8px 12px calc(8px + var(--safe-bottom));flex:0 0 auto}.reply-box,.file-preview{display:flex;align-items:center;gap:10px;justify-content:space-between;background:var(--panel2);border-left:3px solid var(--brand);border-radius:12px;padding:8px 10px;margin-bottom:7px;color:var(--text)}.reply-box span,.file-preview{font-size:12px;color:var(--muted)}.attachment-tray{display:flex;gap:8px;overflow:auto;padding:0 0 8px}.attachment-tray button{border:1px solid var(--line);background:var(--panel2);color:var(--text);border-radius:999px;padding:9px 14px;white-space:nowrap}.composer{display:flex;align-items:flex-end;gap:8px}.composer textarea{flex:1;min-height:42px;max-height:140px;resize:none;border:1px solid var(--line);background:var(--panel2);color:var(--text);border-radius:22px;padding:11px 14px;outline:0}.send-btn{width:42px;height:42px;border-radius:50%;border:0;background:var(--brand);color:white;display:grid;place-items:center;font-weight:900}.mic.recording{background:var(--danger);color:white;animation:pulse 1s infinite}@keyframes pulse{50%{transform:scale(1.06)}}
.drawer{position:fixed;inset:0;z-index:100}.drawer-scrim{position:absolute;inset:0;background:rgba(15,23,42,.36)}.drawer-panel{position:absolute;left:0;top:0;bottom:0;width:min(330px,86vw);background:var(--panel);padding:20px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:10px}.drawer-close{align-self:flex-end;border:0;background:var(--panel2);border-radius:50%;width:36px;height:36px;color:var(--text)}.drawer-me{display:grid;gap:5px;border-bottom:1px solid var(--line);padding-bottom:18px;margin-bottom:8px}.drawer-me small{color:var(--muted)}.drawer-panel button,.drawer-link{border:0;background:transparent;text-align:left;color:var(--text);padding:13px;border-radius:12px;text-decoration:none}.drawer-panel button:hover,.drawer-link:hover{background:var(--panel2)}.bottom-sheet{position:fixed;inset:0;z-index:120;background:rgba(15,23,42,.22);display:grid;align-items:end}.sheet-card{background:var(--panel);border-radius:24px 24px 0 0;padding:10px 12px calc(14px + var(--safe-bottom));box-shadow:var(--shadow);max-width:560px;width:100%;margin:0 auto}.sheet-handle{width:46px;height:5px;background:var(--line);border-radius:999px;margin:6px auto 12px}.sheet-card button{display:block;width:100%;padding:14px;border:0;background:transparent;color:var(--text);text-align:left;border-radius:12px}.sheet-card button:hover{background:var(--panel2)}.sticker-panel{position:fixed;right:16px;bottom:84px;z-index:90;background:var(--panel);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:10px;display:grid;grid-template-columns:repeat(6,42px);gap:6px}.sticker-panel button{font-size:24px;border:0;background:var(--panel2);border-radius:12px;height:42px}.dialog{border:0;border-radius:22px;padding:0;background:transparent;color:var(--text);max-width:min(92vw,560px)}.dialog::backdrop{background:rgba(15,23,42,.45);backdrop-filter:blur(2px)}.dialog.wide{max-width:min(96vw,920px)}.modal-card{background:var(--panel);border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow);padding:18px;min-width:min(92vw,460px);max-height:88dvh;overflow:auto}.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.modal-head h2{margin:0;font-size:20px}.modal-head button{border:0;background:var(--panel2);color:var(--text);border-radius:50%;width:36px;height:36px}.modal-card label{display:grid;gap:6px;margin-bottom:12px;color:var(--muted);font-size:13px}.modal-card input,.modal-card textarea,.modal-card select{border:1px solid var(--line);background:var(--panel2);color:var(--text);border-radius:12px;padding:11px;outline:0}.modal-card textarea{min-height:90px;resize:vertical}.two{display:grid;grid-template-columns:1fr 1fr;gap:12px}.grid-form{display:grid;grid-template-columns:1fr 1fr;gap:10px}.span2{grid-column:1/-1}.check{display:flex!important;grid-template-columns:auto 1fr!important;align-items:center;gap:8px;color:var(--text)!important}.check input{width:auto}.primary,.secondary,.inline button{border:0;border-radius:12px;padding:11px 14px;background:var(--brand);color:white;font-weight:700}.secondary{background:var(--panel2);color:var(--text)}.inline{display:flex;gap:8px}.inline input{flex:1}.manage-section{border-top:1px solid var(--line);padding-top:14px;margin-top:14px}.manage-section h3{margin:0 0 10px}.member-list{display:grid;gap:6px}.member-actions{margin-left:auto;display:flex;gap:6px;flex-wrap:wrap}.member-actions button{border:0;border-radius:8px;padding:7px 9px;background:var(--panel2);color:var(--text)}.member-actions .danger{background:#fee2e2;color:#991b1b}.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px}.media-grid a{border:1px solid var(--line);border-radius:12px;min-height:82px;background:var(--panel2);display:grid;place-items:center;text-align:center;padding:8px;text-decoration:none;color:var(--muted);font-size:12px}.profile-card .profile-hero{text-align:center;display:grid;gap:8px}.profile-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:14px}.profile-actions button{border:0;border-radius:12px;padding:11px;background:var(--panel2);color:var(--text)}.profile-actions .primary{background:var(--brand);color:white}.profile-actions .danger{background:#fee2e2;color:#991b1b}.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);background:#111827;color:white;border-radius:999px;padding:10px 16px;z-index:200;box-shadow:var(--shadow);font-size:14px}.mobile-only{display:none!important}
@media(max-width:760px){.shell{display:block;width:100%;height:100dvh;box-shadow:none}.mobile-only{display:inline-grid!important}.chat-list,.chat-view{position:fixed;inset:0;width:100%;height:100dvh;transition:transform .22s ease;background:var(--panel)}body.chat-list-mode .chat-list{transform:translateX(0)}body.chat-list-mode .chat-view{transform:translateX(100%)}body.chat-open .chat-list{transform:translateX(-24%)}body.chat-open .chat-view{transform:translateX(0)}.list-header,.chat-header{height:58px}.messages{padding:12px 8px}.bubble{max-width:86%;font-size:15px}.message-row .avatar{display:none}.composer-wrap{padding:7px 8px calc(7px + var(--safe-bottom))}.composer{gap:5px}.composer-btn,.send-btn{width:38px;height:38px}.composer textarea{min-height:38px;border-radius:19px;padding:9px 12px}.stickerPanel{left:8px;right:8px}.sticker-panel{left:8px;right:8px;bottom:76px;grid-template-columns:repeat(6,1fr)}.dialog{max-width:100vw;width:100vw}.modal-card{width:100vw;max-height:92dvh;border-radius:22px 22px 0 0;min-width:0}.two,.grid-form{grid-template-columns:1fr}.span2{grid-column:auto}.inline{flex-direction:column}.room-avatar{width:40px;height:40px}.room-item{padding:11px 8px}.search-results{max-height:70dvh}.profile-actions{grid-template-columns:1fr}.msg-media img,.msg-media video{max-width:76vw}}
@media(min-width:761px){.chat-view{position:relative}.chat-list{position:relative}}

/* Stability pass: mobile-first Telegram-like layout + auth loading UI */
html,body{width:100%;max-width:100%;-webkit-text-size-adjust:100%;}
body{overscroll-behavior:none;}
.auth-page{min-height:100vh;min-height:100dvh;overflow:auto;display:grid;place-items:center;padding:clamp(14px,4vw,32px);background:radial-gradient(circle at top left,rgba(42,171,238,.16),transparent 36%),var(--bg);}
.auth-card{width:min(100%,430px);background:var(--panel);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);padding:clamp(18px,5vw,30px);display:grid;gap:18px;}
.auth-brand{display:grid;gap:8px;text-align:left;}
.auth-logo{width:56px;height:56px;border-radius:18px;background:linear-gradient(135deg,var(--brand),#7c3aed);color:white;display:grid;place-items:center;font-weight:900;font-size:26px;box-shadow:0 12px 30px rgba(42,171,238,.28);}
.auth-brand h1{margin:4px 0 0;font-size:clamp(24px,6vw,34px);line-height:1.08;letter-spacing:-.04em;}
.auth-brand p{margin:0;color:var(--muted);line-height:1.55;font-size:15px;}
.stack{display:grid;gap:10px;}
.stack label{font-size:13px;color:var(--muted);font-weight:700;}
.stack input{width:100%;min-width:0;border:1px solid var(--line);background:var(--panel2);color:var(--text);border-radius:15px;padding:14px 15px;outline:0;font-size:16px;}
.stack input:focus{border-color:var(--brand);box-shadow:0 0 0 4px rgba(42,171,238,.12);}
.auth-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.auth-grid label{display:grid;gap:7px;}
.auth-submit{position:relative;display:flex;align-items:center;justify-content:center;gap:10px;min-height:48px;margin-top:4px;}
.auth-submit:disabled{opacity:.82;cursor:not-allowed;}
.btn-spinner{display:none;width:18px;height:18px;border-radius:50%;border:2px solid rgba(255,255,255,.42);border-top-color:#fff;animation:spin .8s linear infinite;}
.auth-submit.is-loading .btn-spinner{display:inline-block;}
@keyframes spin{to{transform:rotate(360deg)}}
.auth-hint,.muted-link{font-size:13px;color:var(--muted);text-decoration:none;text-align:center;line-height:1.45;}
.alert{border:1px solid #fecaca;background:#fff1f2;color:#991b1b;border-radius:16px;padding:12px 14px;font-size:14px;line-height:1.5;}
[data-theme="dark"] .alert{background:#3b1115;color:#fecaca;border-color:#7f1d1d;}

@supports not (height:100dvh){.shell,.chat-view,.chat-list{height:100vh}.auth-page{min-height:100vh}}
.chat-list,.chat-view,.messages,.rooms{max-width:100%;}
.room-item,.search-item{min-width:0;}
.room-title-text,.room-last span,.title-btn strong,.title-btn span{min-width:0;}

@media(max-width:760px){
  .shell{position:fixed;inset:0;overflow:hidden;max-width:none;background:var(--panel);}
  .chat-list,.chat-view{top:0;right:0;bottom:0;left:0;height:100%;min-height:0;will-change:transform;}
  body.chat-list-mode .chat-list{transform:translate3d(0,0,0);}
  body.chat-list-mode .chat-view{transform:translate3d(100%,0,0);pointer-events:none;}
  body.chat-open .chat-list{transform:translate3d(-16%,0,0);pointer-events:none;}
  body.chat-open .chat-view{transform:translate3d(0,0,0);pointer-events:auto;}
  .list-header,.chat-header{height:auto;min-height:58px;padding-top:calc(8px + var(--safe-top));padding-bottom:8px;}
  .brand strong{font-size:18px;}
  .brand span{font-size:11px;}
  .search-box{padding:8px 10px;}
  .search-box input{padding:11px 14px;font-size:16px;}
  .rooms{padding:6px;}
  .avatar{width:42px;height:42px;}
  .room-item{gap:10px;border-radius:12px;}
  .room-time{font-size:10px;max-width:58px;overflow:hidden;text-overflow:ellipsis;}
  .room-last{font-size:12px;}
  .messages{padding:10px 7px 12px;}
  .message-row{margin:5px 0;}
  .bubble{max-width:88%;padding:8px 9px;border-radius:16px;}
  .msg-meta{font-size:9px;}
  .composer-wrap{padding:6px 7px calc(6px + var(--safe-bottom));}
  .attachment-tray{padding-bottom:6px;gap:6px;}
  .attachment-tray button{padding:8px 11px;font-size:13px;}
  .composer textarea{font-size:16px;max-height:94px;}
  .drawer-panel{width:min(300px,84vw);padding:calc(14px + var(--safe-top)) 14px calc(16px + var(--safe-bottom));}
  .bottom-sheet{touch-action:none;}
  .sheet-card{border-radius:20px 20px 0 0;}
  .auth-page{align-items:start;padding:calc(18px + env(safe-area-inset-top,0px)) 12px calc(18px + env(safe-area-inset-bottom,0px));}
  .auth-card{border-radius:24px;padding:20px 16px;width:100%;box-shadow:0 14px 45px rgba(15,23,42,.12);}
  .auth-grid{grid-template-columns:1fr;}
  .auth-brand h1{font-size:28px;}
}

@media(max-width:370px){
  .round-btn,.composer-btn,.send-btn{width:36px;height:36px;}
  .composer{gap:4px;}
  .composer textarea{padding:8px 10px;}
  .room-item{padding:9px 6px;}
  .avatar{width:39px;height:39px;}
  .bubble{max-width:91%;font-size:14px;}
  .sticker-panel{grid-template-columns:repeat(5,1fr);}
}


/* Profile and contacts polish */
.drawer-me{cursor:pointer;border-radius:16px;padding:10px 10px 18px;margin:-4px -4px 8px;}
.drawer-me:hover{background:var(--panel2)}
.profile-photo-preview{display:grid;place-items:center;gap:8px;margin-bottom:14px;text-align:center;color:var(--muted)}
.profile-photo-large{width:132px;height:132px;border-radius:50%;border:3px solid color-mix(in srgb,var(--brand) 45%,var(--line));background:linear-gradient(135deg,var(--brand),#7c3aed);color:#fff;display:grid;place-items:center;overflow:hidden;font-size:42px;font-weight:900;padding:0;cursor:pointer;box-shadow:0 16px 45px rgba(15,23,42,.18)}
.profile-photo-large img{width:100%;height:100%;object-fit:cover;display:block}
.profile-card .profile-hero{text-align:center;display:grid;justify-items:center;gap:8px}.profile-card .profile-photo-large{width:154px;height:154px;font-size:50px}.profile-hero small{color:var(--muted)}
.profile-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px}.profile-info-grid div{background:var(--panel2);border:1px solid var(--line);border-radius:14px;padding:11px;min-width:0}.profile-info-grid span{display:block;font-size:12px;color:var(--muted);margin-bottom:5px}.profile-info-grid b{display:block;color:var(--text);font-size:14px;line-height:1.45;word-break:break-word;white-space:pre-wrap}
.photo-dialog{max-width:100vw;width:100vw}.photo-viewer{position:fixed;inset:0;background:rgba(2,6,23,.92);display:grid;place-items:center;padding:calc(24px + var(--safe-top)) 16px calc(24px + var(--safe-bottom));}.photo-viewer img{max-width:96vw;max-height:88dvh;border-radius:18px;object-fit:contain;box-shadow:0 24px 80px rgba(0,0,0,.45)}.photo-viewer button{position:fixed;top:calc(12px + var(--safe-top));right:14px;width:42px;height:42px;border:0;border-radius:50%;background:rgba(255,255,255,.14);color:white;font-size:24px}
.contacts-tools{margin-bottom:12px}.contacts-tools input{width:100%;border:1px solid var(--line);background:var(--panel2);color:var(--text);border-radius:14px;padding:12px 14px;outline:0}.contacts-list{display:grid;gap:6px;max-height:62dvh;overflow:auto}.contact-item{display:flex;align-items:center;gap:12px;width:100%;border:0;border-radius:14px;background:transparent;color:var(--text);text-align:left;padding:10px}.contact-item:hover{background:var(--panel2)}.contact-item span{min-width:0}.contact-item b,.contact-item small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-item small{color:var(--muted);font-size:12px}.empty-state.mini{min-height:180px;height:auto}
@media(max-width:760px){.profile-card .profile-photo-large{width:138px;height:138px}.profile-info-grid{grid-template-columns:1fr}.contacts-list{max-height:70dvh}.profile-actions{grid-template-columns:1fr 1fr}.photo-viewer img{max-width:100vw;max-height:82dvh;border-radius:12px}}

/* Product polish components */
.reactions{display:flex;gap:5px;flex-wrap:wrap;margin-top:6px}.reactions button{border:1px solid var(--line);background:color-mix(in srgb,var(--panel2) 86%,var(--brand));color:var(--text);border-radius:999px;padding:3px 7px;font-size:12px}.reactions b{font-size:11px;color:var(--muted)}
.full-input{width:100%;border:1px solid var(--line);background:var(--panel2);color:var(--text);border-radius:14px;padding:12px 14px;font-size:16px;outline:0}.search-result-list{display:grid;gap:6px;margin-top:12px;max-height:58dvh;overflow:auto}.search-hit{display:grid;gap:3px;text-align:left;border:0;background:transparent;color:var(--text);border-radius:14px;padding:10px}.search-hit:hover{background:var(--panel2)}.search-hit span{color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-hit small{font-size:11px;color:var(--muted)}
[data-wallpaper="clean"] .messages{background-image:linear-gradient(180deg,rgba(148,163,184,.06),transparent)}[data-wallpaper="blue"] .messages{background:linear-gradient(135deg,rgba(42,171,238,.12),rgba(124,58,237,.08))}[data-wallpaper="dark"] .messages{background:#0f172a}.compact-mode .room-item{padding-top:7px;padding-bottom:7px}.compact-mode .bubble{padding:7px 9px}.compact-mode .messages{gap:2px}.member-row{display:flex;justify-content:space-between;align-items:center;gap:10px;border:1px solid var(--line);border-radius:14px;padding:10px;background:var(--panel2)}.member-row span{min-width:0}.member-row b,.member-row small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-row small{color:var(--muted);font-size:12px}.message-row:has(.bubble:target) .bubble,.bubble.flash{outline:3px solid color-mix(in srgb,var(--brand) 35%,transparent)}
@media(max-width:760px){.search-result-list{max-height:64dvh}.reactions button{font-size:11px;padding:3px 6px}}
.msg-checks{font-weight:800;color:var(--brand);margin-left:4px;letter-spacing:-2px}

/* ---- Stability/media/upload fixes ---- */
.msg-media{border:0;background:transparent;padding:0;display:block;max-width:min(340px,72vw);border-radius:18px;overflow:hidden;cursor:pointer;position:relative;text-align:left}
.msg-media img,.msg-media video{display:block;max-width:100%;width:auto;max-height:420px;object-fit:cover;background:var(--panel-2,#eef2f7)}
.video-card video{width:min(340px,72vw);height:210px;object-fit:cover;filter:brightness(.82)}
.play-badge{position:absolute;inset:auto auto 50% 50%;transform:translate(-50%,50%);width:48px;height:48px;border-radius:50%;background:rgba(0,0,0,.55);color:#fff;display:grid;place-items:center;font-size:18px;padding-left:3px}
.media-viewer-dialog::backdrop,.photo-dialog::backdrop{background:rgba(5,10,18,.82)}
.media-viewer,.photo-viewer{width:min(96vw,980px);height:min(92dvh,760px);display:flex;align-items:center;justify-content:center;position:relative;background:#050914;border-radius:22px;padding:18px;overflow:hidden}
.media-viewer img,.photo-viewer img{max-width:100%;max-height:100%;object-fit:contain;border-radius:12px}
.media-viewer video{max-width:100%;max-height:100%;border-radius:12px;background:#000}
.media-viewer [data-close],.photo-viewer [data-close]{position:absolute;top:14px;right:14px;z-index:3;border:0;border-radius:999px;width:42px;height:42px;background:rgba(255,255,255,.14);color:#fff;font-size:24px}
.media-viewer #mediaDownload{position:absolute;bottom:14px;right:14px;background:rgba(255,255,255,.14);color:#fff;border:1px solid rgba(255,255,255,.22)}
.pending-upload-row{opacity:.92}.pending-bubble{min-width:180px}.pending-file{display:flex;align-items:center;gap:12px}.upload-ring{width:34px;height:34px;transform:rotate(-90deg)}.upload-ring circle{fill:none;stroke:rgba(0,0,0,.16);stroke-width:3}.upload-ring path{fill:none;stroke:currentColor;stroke-width:3;stroke-linecap:round;stroke-dasharray:0,100}.upload-check{display:inline-grid;place-items:center;width:26px;height:26px;border-radius:50%;background:#26b56b;color:#fff;margin-left:-6px}.pending-upload-row.done .upload-ring{display:none}
.msg-checks{font-weight:700;letter-spacing:-3px;color:var(--accent,#2AABEE);margin-left:3px}.chat-header .avatar img,.drawer-me .avatar img,.room-item .avatar img{width:100%;height:100%;object-fit:cover}
@media (max-width: 560px){.msg-media{max-width:78vw}.msg-media img,.msg-media video{max-height:300px}.video-card video{width:78vw;height:190px}.media-viewer,.photo-viewer{width:100vw;height:100dvh;border-radius:0;padding:calc(14px + env(safe-area-inset-top)) 10px calc(14px + env(safe-area-inset-bottom))}.auth-card{max-width:calc(100vw - 22px)}}

/* ---- Sticker/GIF library + chat action UX fixes ---- */
.small-card{max-width:420px}.delete-actions{display:grid;gap:10px}.delete-actions button{justify-content:center}.muted{color:var(--muted);font-size:13px}.sticker-manager .inline{display:flex;gap:8px;flex-wrap:wrap}.sticker-library-list{display:grid;gap:10px;margin-top:14px;max-height:55vh;overflow:auto}.sticker-library-row{display:grid;grid-template-columns:68px 1fr auto;align-items:center;gap:10px;padding:10px;border:1px solid var(--border);border-radius:14px;background:var(--surface-2)}.sticker-library-row span{display:grid;gap:2px;min-width:0}.sticker-library-row small{color:var(--muted)}.sticker-panel{position:absolute;left:12px;right:12px;bottom:calc(72px + env(safe-area-inset-bottom));max-height:48vh;overflow:auto;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:18px;padding:12px;z-index:30}.sticker-tabs{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.sticker-tabs button{height:32px;border-radius:10px}.sticker-section{display:grid;gap:8px;margin:10px 0}.sticker-section small{font-weight:700;color:var(--muted)}.sticker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(48px,1fr));gap:8px}.sticker-grid .muted{grid-column:1/-1;padding:10px;text-align:center}.sticker-item,.emoji-send{height:52px;border-radius:14px;border:1px solid var(--border);background:var(--surface-2);display:grid;place-items:center;font-size:24px;overflow:hidden}.sticker-item img{width:100%;height:100%;object-fit:cover;border-radius:12px}.emoji-sticker{font-size:28px}.gif-item::after{content:'GIF';position:absolute;font-size:9px;background:rgba(0,0,0,.65);color:#fff;border-radius:5px;padding:1px 4px;right:4px;bottom:4px}.sticker-item{position:relative}.sticker-library-row .sticker-item{width:56px;height:56px}.sticker-library-row .sticker-item small{display:none}.media-tile{min-height:92px;border:1px solid var(--border);border-radius:12px;background:var(--surface-2);display:grid;place-items:center;padding:8px;overflow:hidden;color:var(--text);text-decoration:none}.media-tile img{width:100%;height:100%;object-fit:cover;border-radius:10px}.sheet-card>b{display:block;padding:8px 12px;color:var(--muted);text-align:center}.bottom-sheet[hidden]{display:none!important}.danger[hidden],button[hidden]{display:none!important}@media(max-width:720px){.sticker-panel{position:fixed;left:8px;right:8px;bottom:calc(70px + env(safe-area-inset-bottom));max-height:52vh}.sticker-grid{grid-template-columns:repeat(5,1fr)}.sticker-library-row{grid-template-columns:58px 1fr}.sticker-library-row .danger{grid-column:1/-1}.delete-actions{grid-template-columns:1fr}.sheet-card button{min-height:46px}.media-tile{min-height:78px}}

/* ---- Admin dashboard + Sticker Bot mobile UI upgrade ---- */
.admin-page{min-height:100dvh;background:var(--bg);color:var(--text);padding:20px;overflow-x:hidden}.admin-topbar{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px}.admin-topbar h1{margin:0;font-size:30px}.admin-topbar p{margin:4px 0 0;color:var(--muted)}.admin-grid.pro{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.admin-card.metric h2{font-size:26px;margin:6px 0 0}.admin-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:14px;margin-top:14px}.wide-card{min-width:0}.admin-section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.admin-section-head h2{margin:0}.admin-section-head input{border:1px solid var(--line);background:var(--panel2);color:var(--text);border-radius:12px;padding:10px 12px;min-width:260px}.table-wrap{width:100%;overflow:auto;border-radius:14px;border:1px solid var(--line)}.admin-table{min-width:840px}.admin-user-cell{display:grid;gap:2px}.admin-user-cell small{color:var(--muted)}.pill{display:inline-flex;align-items:center;justify-content:center;min-width:62px;border-radius:999px;background:var(--panel2);color:var(--muted);font-size:12px;font-weight:700;padding:4px 8px}.pill.ok{background:rgba(34,197,94,.12);color:#16a34a}.pill.bad{background:rgba(239,68,68,.12);color:#dc2626}.admin-page pre{white-space:pre-wrap;background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:10px;max-height:220px;overflow:auto}.bot-command-bar{display:flex;gap:8px;overflow-x:auto;padding:6px 2px 9px}.bot-command-bar button{border:1px solid var(--line);background:var(--panel2);color:var(--brand);border-radius:999px;padding:8px 12px;font-weight:800;white-space:nowrap}.sticker-panel{display:block}.sticker-columns{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;min-width:0}.sticker-section{min-width:0;overflow:hidden}.sticker-section small{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sticker-grid{grid-template-columns:repeat(auto-fill,minmax(46px,1fr));align-content:start;max-height:180px;overflow:auto;padding:2px}.sticker-item,.emoji-send{min-width:0}.sticker-item img{object-fit:contain;background:color-mix(in srgb,var(--panel2) 70%,transparent)}
@media(max-width:760px){.admin-page{padding:12px}.admin-topbar{align-items:flex-start}.admin-topbar h1{font-size:24px}.admin-layout{grid-template-columns:1fr}.admin-section-head{display:grid}.admin-section-head input{min-width:0;width:100%}.admin-grid.pro{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-card.metric h2{font-size:21px}.sticker-panel{left:10px!important;right:10px!important;bottom:calc(78px + env(safe-area-inset-bottom))!important;max-height:58dvh!important;padding:12px!important;border-radius:22px!important}.sticker-tabs{position:sticky;top:0;background:var(--surface);z-index:2;padding-bottom:8px}.sticker-columns{grid-template-columns:1fr;gap:8px}.sticker-section{border:1px solid var(--border);border-radius:16px;background:var(--surface-2);padding:9px}.sticker-grid{grid-template-columns:repeat(6,minmax(0,1fr));max-height:126px;gap:6px}.sticker-item,.emoji-send{height:44px;border-radius:12px;font-size:22px}.sticker-grid .muted{text-align:left;padding:8px}.bot-command-bar{padding-bottom:7px}.bot-command-bar button{font-size:13px;padding:8px 11px}}
@media(max-width:390px){.sticker-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.admin-grid.pro{grid-template-columns:1fr}.room-title-text{max-width:155px}}
:root{--surface:var(--panel);--surface-2:var(--panel2);--border:var(--line);--accent:var(--brand)}


/* ---- Mobile touch/zoom hardening ---- */
html,body{touch-action:manipulation;overscroll-behavior:none;-webkit-text-size-adjust:100%;}
body,.shell,.chat-list,.chat-panel,.messages,.room-item,.bubble,.bottom-sheet,.drawer,.sticker-panel,.admin-page{ -webkit-user-select:none; user-select:none; -webkit-touch-callout:none; }
input,textarea,[contenteditable="true"],.copy-chip{ -webkit-user-select:text!important; user-select:text!important; -webkit-touch-callout:default!important; }
button,a,.room-item,.bubble,.sticker-item,.emoji-send{ -webkit-tap-highlight-color:transparent; touch-action:manipulation; }
input,textarea,select{font-size:16px!important;}
.message-row,.bubble{ -webkit-user-drag:none; }
@media(max-width:760px){
  .messages{touch-action:pan-y;}
  .bubble{cursor:default;}
  .bot-command-bar button{min-height:42px;}
}
/* Update 6 music/bot UI */
.music-library-list{display:grid;gap:10px;margin-top:12px}.music-row{display:flex;gap:12px;align-items:center;justify-content:space-between;border:1px solid var(--line);background:var(--panel2);border-radius:16px;padding:12px}.music-info{display:grid;gap:5px;min-width:0;flex:1}.music-info b,.music-info small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.music-info audio{width:100%;max-width:420px}.music-row .actions{display:flex;gap:8px;flex-wrap:wrap}.music-manager .inline input{min-width:0}.danger{background:#fee2e2!important;color:#b91c1c!important}
