:root{--bg-0: #07080d;--bg-1: #0b0d14;--bg-2: #11141d;--bg-3: #171b26;--bg-4: #1e2330;--bg-5: #252a38;--text-0: #f3f5fb;--text-1: #c9cddd;--text-2: #8a90a6;--text-3: #5e6479;--text-4: #3a3f52;--border: rgba(255, 255, 255, .06);--border-strong: rgba(255, 255, 255, .11);--border-focus: rgba(124, 92, 255, .5);--accent: #7c5cff;--accent-2: #3ad8ff;--accent-grad: linear-gradient(135deg, #7c5cff 0%, #3ad8ff 100%);--accent-soft: rgba(124, 92, 255, .13);--accent-soft-2: rgba(124, 92, 255, .07);--online: #4ade80;--warning: #f5b14a;--danger: #ff6b6b;--info: #56a0ff;--r-xs: 6px;--r-sm: 8px;--r-md: 12px;--r-lg: 18px;--r-xl: 24px;--r-2xl: 32px;--shadow-1: 0 2px 8px rgba(0, 0, 0, .3);--shadow-2: 0 8px 28px rgba(0, 0, 0, .4);--shadow-3: 0 20px 60px rgba(0, 0, 0, .55);--ease: cubic-bezier(.22, 1, .36, 1);--ease-sharp: cubic-bezier(.32, 0, .67, 0);--text-xs: 11.5px;--text-sm: 13px;--text-base: 14.5px;--text-md: 16px;--text-lg: 20px;--text-xl: 26px}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:var(--text-base);line-height:1.5;background:var(--bg-0);color:var(--text-0);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow:hidden}button{font-family:inherit;font-size:inherit;color:inherit;background:none;border:0;padding:0;cursor:pointer;-webkit-font-smoothing:inherit}input,textarea{font-family:inherit;font-size:inherit;color:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff12;border-radius:6px}::-webkit-scrollbar-thumb:hover{background:#ffffff21}.tip{position:relative;display:inline-flex;align-items:center;justify-content:center}.tip:after{content:attr(data-tip);position:absolute;z-index:200;left:50%;transform:translate(-50%) translateY(-4px);bottom:calc(100% + 7px);background:var(--bg-5);color:var(--text-1);font-size:11.5px;font-weight:500;padding:5px 10px;border-radius:var(--r-sm);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .14s var(--ease),transform .14s var(--ease);border:1px solid var(--border-strong);box-shadow:var(--shadow-2);letter-spacing:.01em}.tip--bottom:after{bottom:auto;top:calc(100% + 7px);transform:translate(-50%) translateY(4px)}.tip--right:after{left:calc(100% + 7px);bottom:auto;top:50%;transform:translateY(-50%) translate(4px)}.tip:hover:after{opacity:1;transform:translate(-50%) translateY(0)}.tip--bottom:hover:after{transform:translate(-50%) translateY(0)}.tip--right:hover:after{transform:translateY(-50%) translate(0)}.cs-badge{display:inline-flex;align-items:center;padding:2px 7px;border-radius:999px;font-size:10.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;background:#f5b14a26;color:var(--warning);border:1px solid rgba(245,177,74,.25);vertical-align:middle;line-height:1.4}.notice{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:var(--r-md);font-size:var(--text-sm);line-height:1.5;margin-bottom:18px}.notice--info{background:#56a0ff14;border:1px solid rgba(86,160,255,.2);color:var(--text-1)}.notice--warning{background:#f5b14a14;border:1px solid rgba(245,177,74,.2);color:var(--text-1)}.notice__icon{flex:0 0 auto;margin-top:1px;color:var(--info)}.notice--warning .notice__icon{color:var(--warning)}.notice__title{font-weight:600;color:var(--text-0);margin-bottom:2px}.empty-state{flex:1;display:flex;align-items:center;justify-content:center;padding:48px 40px}.empty-state__shell{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:380px}.empty-state__icon-wrap{width:72px;height:72px;border-radius:22px;background:var(--bg-3);border:1px solid var(--border-strong);display:grid;place-items:center;color:var(--text-2);margin-bottom:22px;box-shadow:var(--shadow-2)}.empty-state__title{font-size:var(--text-lg);font-weight:700;letter-spacing:-.01em;color:var(--text-0);margin:0 0 10px}.empty-state__body{font-size:var(--text-sm);color:var(--text-2);line-height:1.65;margin:0 0 20px}.empty-state__eta{display:flex;align-items:center;gap:6px;font-size:var(--text-xs);color:var(--text-3);margin-bottom:16px}.empty-state__pill{display:flex;align-items:center;gap:7px;padding:7px 14px;border-radius:999px;border:1px solid var(--border-strong);background:var(--bg-3);font-size:12px;font-weight:500;color:var(--text-2)}.empty-state__dot{width:7px;height:7px;border-radius:50%;background:var(--warning);flex:0 0 auto;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.app{height:100vh;display:grid;grid-template-columns:76px 340px 1fr;background:radial-gradient(1400px 900px at -5% -5%,rgba(124,92,255,.09),transparent 55%),radial-gradient(1000px 700px at 105% 105%,rgba(58,216,255,.06),transparent 55%),var(--bg-0)}.sidebar{display:flex;flex-direction:column;align-items:center;gap:2px;padding:16px 0 18px;background:var(--bg-1);border-right:1px solid var(--border);position:relative;z-index:10}.sidebar__brand{width:42px;height:42px;border-radius:13px;background:var(--accent-grad);display:grid;place-items:center;font-weight:800;font-size:17px;color:#fff;letter-spacing:-.5px;box-shadow:0 6px 20px #7c5cff61;margin-bottom:6px;position:relative;flex:0 0 auto}.sidebar__beta{position:absolute;top:-5px;right:-7px;background:var(--warning);color:#000;font-size:8px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:2px 5px;border-radius:999px;line-height:1.2}.sidebar__divider{width:28px;height:1px;background:var(--border);margin:6px 0;flex:0 0 auto}.sidebar__nav{display:flex;flex-direction:column;gap:2px;flex:1}.sidebar__btn{width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;color:var(--text-3);position:relative;transition:background .16s var(--ease),color .16s var(--ease);outline:none}.sidebar__btn:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.sidebar__btn:hover{color:var(--text-1);background:#ffffff0a}.sidebar__btn.is-active{color:var(--text-0);background:var(--accent-soft)}.sidebar__btn.is-active:before{content:"";position:absolute;left:-13px;top:12px;bottom:12px;width:3px;border-radius:0 3px 3px 0;background:var(--accent-grad)}.sidebar__btn.has-cs-dot:after{content:"";position:absolute;top:9px;right:9px;width:6px;height:6px;border-radius:50%;background:var(--warning);border:1.5px solid var(--bg-1)}.sidebar__me{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-weight:600;font-size:13px;color:#fff;cursor:pointer;border:2px solid transparent;transition:border-color .18s var(--ease),transform .16s var(--ease);flex:0 0 auto}.sidebar__me:hover{border-color:var(--border-strong);transform:scale(1.05)}.chatlist{display:flex;flex-direction:column;min-width:0;background:var(--bg-1);border-right:1px solid var(--border)}.chatlist__header{padding:18px 18px 10px;display:flex;flex-direction:column;gap:10px}.chatlist__titlerow{display:flex;align-items:center;justify-content:space-between}.chatlist__title{font-size:20px;font-weight:700;letter-spacing:-.02em;margin:0;color:var(--text-0)}.chatlist__compose{width:32px;height:32px;border-radius:10px;display:grid;place-items:center;color:var(--text-3);transition:background .16s var(--ease),color .16s var(--ease)}.chatlist__compose:hover{background:#ffffff0d;color:var(--text-1)}.chatlist__search{display:flex;align-items:center;gap:8px;background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r-md);padding:9px 12px;transition:border-color .18s var(--ease),background .18s var(--ease)}.chatlist__search:focus-within{border-color:var(--border-focus);background:var(--bg-4)}.chatlist__search input{flex:1;border:0;background:transparent;outline:none;font-size:var(--text-sm);color:var(--text-0)}.chatlist__search input::placeholder{color:var(--text-4)}.chatlist__search-icon{color:var(--text-3);flex:0 0 auto}.chatlist__tabs{display:flex;gap:4px;padding:2px 18px 8px;overflow-x:auto;scrollbar-width:none}.chatlist__tabs::-webkit-scrollbar{display:none}.chatlist__tab{padding:5px 12px;border-radius:999px;font-size:12.5px;font-weight:500;color:var(--text-3);white-space:nowrap;transition:color .16s var(--ease),background .16s var(--ease)}.chatlist__tab:hover{color:var(--text-1)}.chatlist__tab.is-active{color:var(--text-0);background:var(--accent-soft)}.chatlist__scroll{flex:1;overflow-y:auto;padding:2px 8px 24px}.chatlist__section-label{font-size:10.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-4);padding:10px 10px 4px}.chatitem{display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:14px;cursor:pointer;transition:background .14s var(--ease);outline:none}.chatitem:hover{background:#ffffff08}.chatitem:focus-visible{outline:2px solid var(--border-focus);outline-offset:-2px}.chatitem.is-active{background:var(--accent-soft)}.chatitem.is-active .chatitem__time{color:#7c5cffb3}.avatar{flex:0 0 auto;width:44px;height:44px;border-radius:50%;display:grid;place-items:center;font-weight:600;font-size:14px;color:#fff;position:relative;letter-spacing:.3px;-webkit-user-select:none;user-select:none}.avatar.is-lg{width:72px;height:72px;font-size:22px}.avatar.is-xl{width:108px;height:108px;font-size:34px}.avatar.is-32{width:32px;height:32px;font-size:11px}.avatar__dot{position:absolute;right:0;bottom:0;width:11px;height:11px;background:var(--online);border:2px solid var(--bg-1);border-radius:50%}.chatitem.is-active .avatar__dot{border-color:var(--bg-1)}.header .avatar__dot{border-color:var(--bg-0)}.chatitem__body{flex:1;min-width:0}.chatitem__topline{display:flex;justify-content:space-between;align-items:baseline;gap:6px}.chatitem__name{font-size:14px;font-weight:600;color:var(--text-0);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chatitem__time{font-size:11px;color:var(--text-4);flex:0 0 auto;letter-spacing:.01em}.chatitem__bottomline{display:flex;justify-content:space-between;align-items:center;gap:6px;margin-top:1px}.chatitem__preview{font-size:12.5px;color:var(--text-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;line-height:1.4}.chatitem__preview--me{color:var(--text-4)}.chatitem__meta{display:flex;align-items:center;gap:4px;color:var(--text-4);flex:0 0 auto}.chatitem__badge{background:var(--accent-grad);color:#fff;font-size:10.5px;font-weight:700;padding:2px 6px;border-radius:999px;min-width:18px;text-align:center;line-height:1.5}.chatitem__badge--muted{background:var(--bg-5);color:var(--text-3)}.chat{display:flex;flex-direction:column;min-width:0;background:var(--bg-2);position:relative}.chat:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 20% 80%,rgba(124,92,255,.04) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(58,216,255,.03) 0%,transparent 50%);pointer-events:none}.chat__empty{flex:1;display:flex;align-items:center;justify-content:center;padding:48px;position:relative}.chat__empty-shell{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:340px}.chat__empty-glyph{width:80px;height:80px;border-radius:24px;background:var(--accent-grad);display:grid;place-items:center;color:#fff;margin-bottom:22px;box-shadow:0 16px 48px #7c5cff47;position:relative}.chat__empty-glyph:after{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:32px;border:1px solid rgba(124,92,255,.18)}.chat__empty-title{font-size:var(--text-lg);font-weight:700;letter-spacing:-.01em;color:var(--text-0);margin:0 0 8px}.chat__empty-sub{font-size:var(--text-sm);color:var(--text-3);line-height:1.6;margin:0 0 20px}.chat__empty-hint{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-4);padding:6px 12px;border-radius:999px;border:1px solid var(--border);background:var(--bg-3)}.header{display:flex;align-items:center;gap:12px;padding:12px 18px;background:#0b0d14b8;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);z-index:5;position:relative}.header__body{flex:1;min-width:0}.header__title{font-size:15px;font-weight:600;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-0)}.header__subtitle{font-size:12px;color:var(--text-3);display:flex;align-items:center;gap:5px;margin-top:1px}.header__subtitle--online{color:var(--online)}.header__actions{display:flex;gap:2px;align-items:center}.iconbtn{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;color:var(--text-3);transition:background .14s var(--ease),color .14s var(--ease);outline:none;flex:0 0 auto}.iconbtn:hover{background:#ffffff0d;color:var(--text-1)}.iconbtn:focus-visible{outline:2px solid var(--border-focus);outline-offset:1px}.iconbtn--unavailable{opacity:.38;cursor:not-allowed;pointer-events:none}.tip:has(.iconbtn--unavailable){pointer-events:auto;cursor:not-allowed}.messages{flex:1;overflow-y:auto;padding:20px 10% 12px;display:flex;flex-direction:column;gap:1px;position:relative;z-index:1}@media (max-width: 1300px){.messages{padding:20px 5% 12px}}@media (max-width: 960px){.messages{padding:16px 16px 12px}}.messages__daysep{align-self:center;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-4);background:var(--bg-3);border:1px solid var(--border);padding:4px 11px;border-radius:999px;margin:16px 0 8px;-webkit-user-select:none;user-select:none}.msgrow{display:flex;gap:8px;align-items:flex-end}.msgrow--me{flex-direction:row-reverse}.msgrow__avatar-slot{width:32px;flex:0 0 auto;display:flex;align-items:flex-end}.bubble{max-width:min(540px,68%);padding:8px 12px;border-radius:16px;font-size:var(--text-base);line-height:1.45;word-wrap:break-word;overflow-wrap:break-word;animation:msg-in .2s var(--ease)}@keyframes msg-in{0%{opacity:0;transform:translateY(6px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.bubble--in{background:var(--bg-3);color:var(--text-0);border-bottom-left-radius:5px}.bubble--in.is-tail-hidden{border-bottom-left-radius:16px}.bubble--in.is-first{border-top-left-radius:16px}.bubble--out{background:var(--accent-grad);color:#fff;border-bottom-right-radius:5px;box-shadow:0 4px 18px #7c5cff33}.bubble--out.is-tail-hidden{border-bottom-right-radius:16px}.msgrow.is-group-start{margin-top:8px}.bubble__sender{font-size:12px;font-weight:600;margin-bottom:3px;letter-spacing:.01em}.bubble__text{display:inline}.bubble__meta{display:inline-flex;align-items:center;gap:3px;font-size:10.5px;opacity:.6;margin-left:6px;white-space:nowrap;vertical-align:middle;line-height:1}.bubble--out .bubble__meta{opacity:.75}.input{padding:10px 10% 18px;display:flex;gap:8px;align-items:flex-end;position:relative;z-index:2}@media (max-width: 1300px){.input{padding:10px 5% 18px}}@media (max-width: 960px){.input{padding:10px 14px 16px}}.input__wrap{flex:1;display:flex;align-items:flex-end;gap:4px;background:var(--bg-3);border:1px solid var(--border);border-radius:18px;padding:5px 5px 5px 10px;transition:border-color .16s var(--ease),background .16s var(--ease)}.input__wrap:focus-within{border-color:var(--border-focus);background:var(--bg-4)}.input__textarea{flex:1;border:0;background:transparent;outline:none;resize:none;font-size:var(--text-base);line-height:1.45;color:var(--text-0);padding:7px 4px;max-height:140px;min-height:22px;align-self:flex-end}.input__textarea::placeholder{color:var(--text-4)}.input__action-group{display:flex;align-items:flex-end;gap:0px}.input__send{width:42px;height:42px;border-radius:13px;background:var(--accent-grad);color:#fff;display:grid;place-items:center;box-shadow:0 6px 18px #7c5cff47;transition:transform .14s var(--ease),opacity .14s var(--ease),box-shadow .14s var(--ease);flex:0 0 auto}.input__send:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 24px #7c5cff5c}.input__send:active:not(:disabled){transform:translateY(0)}.input__send:disabled{opacity:.28;cursor:default;box-shadow:none}.screen{grid-column:2 / -1;overflow-y:auto;background:var(--bg-2);position:relative}.screen:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(800px 600px at 90% 10%,rgba(124,92,255,.05),transparent 55%),radial-gradient(600px 400px at 10% 90%,rgba(58,216,255,.03),transparent 55%);pointer-events:none;z-index:0}.screen__content{position:relative;z-index:1;padding:28px 40px 48px}.screen__inner{max-width:680px;margin:0 auto}.screen--centered{display:flex;flex-direction:column}.screen--centered .screen__content{flex:1;display:flex;flex-direction:column}.screen__header{display:flex;align-items:center;gap:10px;margin-bottom:24px}.screen__title{font-size:var(--text-xl);font-weight:700;letter-spacing:-.02em;margin:0;color:var(--text-0)}.card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r-lg);padding:0 18px;margin-bottom:14px;overflow:hidden}.card__title{font-size:10.5px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--text-4);padding:14px 0 0;margin:0 0 2px;-webkit-user-select:none;user-select:none}.kv{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:13px 0;border-bottom:1px solid var(--border);font-size:var(--text-base)}.kv:last-child{border-bottom:0}.kv__k{color:var(--text-2);font-size:var(--text-sm)}.kv__v{color:var(--text-0);font-weight:500;text-align:right}.setrow{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:14px 0;border-bottom:1px solid var(--border)}.setrow:last-child{border-bottom:0}.setrow__label-group{flex:1;min-width:0}.setrow__label{font-size:var(--text-base);color:var(--text-0);display:flex;align-items:center;gap:8px;flex-wrap:wrap}.setrow__hint{font-size:12px;color:var(--text-3);margin-top:3px;line-height:1.4}.setrow--preview-only .setrow__label{opacity:.7}.setrow--preview-only .setrow__hint{opacity:.6}.toggle{width:40px;height:24px;background:var(--bg-5);border:1px solid var(--border-strong);border-radius:999px;position:relative;cursor:pointer;transition:background .2s var(--ease),border-color .2s var(--ease);flex:0 0 auto;outline:none}.toggle:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:var(--text-2);transition:transform .2s var(--ease),background .2s var(--ease);box-shadow:0 1px 3px #0006}.toggle.is-on{background:var(--accent);border-color:transparent}.toggle.is-on:after{transform:translate(16px);background:#fff}.pills{display:flex;gap:6px;flex-wrap:wrap}.pill{padding:7px 13px;border-radius:999px;background:var(--bg-3);border:1px solid var(--border);color:var(--text-2);font-size:12.5px;font-weight:500;transition:color .14s var(--ease),background .14s var(--ease),border-color .14s var(--ease);cursor:pointer;outline:none}.pill:hover{color:var(--text-0);border-color:var(--border-strong)}.pill:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.pill.is-on{background:var(--accent-soft);border-color:#7c5cff59;color:var(--text-0)}.profile__hero{display:flex;flex-direction:column;align-items:center;gap:6px;padding:28px 20px 20px}.profile__avatar-wrap{position:relative;margin-bottom:10px}.profile__edit-btn{position:absolute;bottom:-2px;right:-2px;width:30px;height:30px;border-radius:50%;background:var(--bg-3);border:2px solid var(--bg-1);display:grid;place-items:center;color:var(--text-2);cursor:pointer;transition:background .15s var(--ease),color .15s var(--ease)}.profile__edit-btn.iconbtn--unavailable{opacity:.5}.profile__name{font-size:22px;font-weight:700;letter-spacing:-.01em;margin:0;color:var(--text-0)}.profile__handle{color:var(--text-3);font-size:var(--text-sm);font-weight:500}.profile__bio{color:var(--text-2);text-align:center;max-width:380px;line-height:1.6;font-size:var(--text-sm);margin:4px 0 0}.soon-row{display:flex;align-items:center;gap:10px;padding:12px 0;border-bottom:1px solid var(--border);opacity:.55;cursor:not-allowed}.soon-row:last-child{border-bottom:0}.soon-row__label{font-size:var(--text-base);flex:1}.contacts-screen,.calls-screen{display:flex;flex-direction:column;height:100%}.icon{width:20px;height:20px;display:block;flex:0 0 auto}.icon--sm{width:16px;height:16px}.icon--xs{width:13px;height:13px}.icon--lg{width:24px;height:24px}.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(1200px 800px at 0% 0%,rgba(124,92,255,.12),transparent 55%),radial-gradient(900px 600px at 100% 100%,rgba(58,216,255,.08),transparent 55%),var(--bg-0);padding:24px}.auth-card{width:100%;max-width:400px;background:var(--bg-1);border:1px solid var(--border-strong);border-radius:var(--r-xl);padding:36px 32px 28px;box-shadow:0 24px 80px #00000080}.auth-brand{text-align:center;margin-bottom:28px}.auth-logo{width:52px;height:52px;border-radius:16px;background:var(--accent-grad);display:grid;place-items:center;font-weight:800;font-size:22px;color:#fff;margin:0 auto 16px;box-shadow:0 8px 28px #7c5cff66}.auth-title{font-size:22px;font-weight:700;letter-spacing:-.01em;margin:0 0 6px}.auth-sub{font-size:13.5px;color:var(--text-3);margin:0}.auth-form{display:flex;flex-direction:column;gap:14px}.auth-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.auth-field{display:flex;flex-direction:column;gap:5px}.auth-label{font-size:12px;font-weight:600;color:var(--text-2);letter-spacing:.02em}.auth-input{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r-md);padding:11px 13px;font-size:14.5px;color:var(--text-0);outline:none;transition:border-color .16s var(--ease),background .16s var(--ease)}.auth-input::placeholder{color:var(--text-4)}.auth-input:focus{border-color:var(--border-focus);background:var(--bg-4)}.auth-btn{margin-top:4px;padding:12px;border-radius:var(--r-md);background:var(--accent-grad);color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:opacity .16s var(--ease),transform .16s var(--ease),box-shadow .16s var(--ease);box-shadow:0 8px 24px #7c5cff4d}.auth-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 12px 32px #7c5cff66}.auth-btn:disabled{opacity:.55;cursor:default;box-shadow:none}.auth-error{background:#ff6b6b1a;border:1px solid rgba(255,107,107,.25);color:var(--danger);padding:10px 12px;border-radius:var(--r-sm);font-size:13px}.auth-switch{text-align:center;color:var(--text-3);font-size:13px;margin:16px 0 0}.auth-link{color:var(--accent);font-weight:500;text-decoration:underline;text-underline-offset:2px}.auth-link:hover{color:var(--text-0)}.auth-demo-hint{margin-top:14px;padding:10px 14px;border-radius:var(--r-md);background:var(--bg-3);border:1px solid var(--border);font-size:12px;color:var(--text-3);text-align:center}.app-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;background:var(--bg-0)}.app-loading__logo{width:56px;height:56px;border-radius:18px;background:var(--accent-grad);display:grid;place-items:center;font-weight:800;font-size:24px;color:#fff;box-shadow:0 10px 32px #7c5cff66}.spinner{width:24px;height:24px;border:2px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg,var(--bg-3) 25%,var(--bg-4) 50%,var(--bg-3) 75%);background-size:200% 100%;animation:shimmer 1.4s ease-in-out infinite;border-radius:var(--r-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton--avatar{width:44px;height:44px;border-radius:50%;flex:0 0 auto}.skeleton--line{height:13px;border-radius:6px}.skeleton-list{display:flex;flex-direction:column;padding:4px 0}.chatlist__status{display:flex;align-items:center;justify-content:center;gap:6px;padding:40px 20px;color:var(--text-4);font-size:13px;text-align:center;flex-direction:column}.chatlist__status--error{color:var(--danger)}.messages-loading{display:flex;justify-content:center;padding:32px}.messages-error{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 20px;font-size:13px;color:var(--danger);background:#ff6b6b14;border-radius:var(--r-md);margin:8px 10%}.load-more-btn{align-self:center;margin:8px auto 0;padding:6px 16px;border-radius:999px;background:var(--bg-3);border:1px solid var(--border-strong);color:var(--text-2);font-size:12.5px;cursor:pointer;transition:background .14s var(--ease),color .14s var(--ease);z-index:3}.load-more-btn:hover{background:var(--bg-4);color:var(--text-0)}.bubble--pending{opacity:.65}.bubble--failed{box-shadow:0 0 0 1.5px var(--danger) inset}
