:root{--bg-deep: #0a0a14;--bg-surface: #15152a;--bg-elevated: rgba(36, 36, 64, .6);--bg-overlay: rgba(10, 10, 20, .75);--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .16);--text: #ecedf3;--text-dim: #9ca3b5;--text-muted: #6b7280;--accent: #6366f1;--accent-hover: #818cf8;--accent-glow: rgba(99, 102, 241, .35);--accent-soft: rgba(99, 102, 241, .12);--gradient-bg: radial-gradient(ellipse 1200px 800px at 50% -100px, rgba(99, 102, 241, .18), transparent 60%), radial-gradient(ellipse 800px 600px at 80% 100%, rgba(168, 85, 247, .12), transparent 50%), var(--bg-deep);--gradient-accent: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #a855f7 100%);--gradient-bubble-mine: linear-gradient(135deg, #6366f1, #7c3aed);--danger: #ef4444;--success: #10b981;--success-soft: rgba(16, 185, 129, .12);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .6);--shadow-glow: 0 0 24px var(--accent-glow);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 18px;--radius-xl: 24px;--radius-pill: 999px}*{box-sizing:border-box;margin:0;padding:0}*::selection{background:var(--accent);color:#fff}html,body{height:100%;background:var(--bg-deep);color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}body{background:var(--gradient-bg);background-attachment:fixed}#app{display:flex;flex-direction:column;height:100vh;height:100dvh;max-width:720px;margin:0 auto;position:relative}h1{font-size:22px;font-weight:700;letter-spacing:-.02em}h2{font-size:14px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em}p{color:var(--text-dim)}button{font-family:inherit;font-size:14px;font-weight:600;color:var(--text);background:var(--accent);border:none;border-radius:var(--radius-md);padding:10px 18px;cursor:pointer;transition:all .15s ease;position:relative;letter-spacing:0}button:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md),0 0 16px var(--accent-glow)}button:active{transform:translateY(0)}button:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}button.primary{background:var(--gradient-accent);background-size:200% 200%;background-position:0% 50%;transition:all .3s ease}button.primary:hover{background-position:100% 50%;box-shadow:var(--shadow-md),var(--shadow-glow)}button.secondary{background:var(--bg-elevated);color:var(--text);border:1px solid var(--border);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}button.secondary:hover{background:var(--bg-surface);border-color:var(--border-strong);box-shadow:var(--shadow-md)}button.big{font-size:16px;padding:14px 22px;border-radius:var(--radius-md);width:100%}button.back-link{background:transparent;color:var(--text-dim);padding:6px 0;align-self:flex-start;font-weight:500;font-size:13px}button.back-link:hover{color:var(--text);background:transparent;transform:none;box-shadow:none}input{font-family:inherit;font-size:15px;color:var(--text);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 14px;width:100%;transition:all .15s ease}input::placeholder{color:var(--text-muted)}input:focus{outline:none;border-color:var(--accent);background:var(--bg-deep);box-shadow:0 0 0 3px var(--accent-soft)}.screen{display:flex;flex-direction:column;flex:1;padding:24px;gap:14px;overflow:hidden;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.screen.intro{justify-content:center;align-items:center;text-align:center;padding:32px}.screen.intro .actions{width:100%;max-width:360px}.screen.auth{max-width:420px;margin:0 auto;width:100%;padding-top:48px}.hero{display:flex;flex-direction:column;align-items:center;gap:14px;margin-bottom:36px;animation:heroIn .6s cubic-bezier(.16,1,.3,1)}@keyframes heroIn{0%{opacity:0;transform:scale(.85) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.hero-logo{width:96px;height:96px;border-radius:var(--radius-lg);filter:drop-shadow(0 8px 32px var(--accent-glow));animation:pulse 4s ease-in-out infinite}@keyframes pulse{0%,to{filter:drop-shadow(0 8px 32px var(--accent-glow))}50%{filter:drop-shadow(0 8px 48px rgba(168,85,247,.6))}}.hero-title{font-size:40px;font-weight:700;letter-spacing:-.04em;background:var(--gradient-accent);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.hero-tagline{color:var(--text-dim);font-size:15px;max-width:320px}.row{display:flex;gap:10px;align-items:center}.row>button{flex:1}.actions{display:flex;gap:10px}.actions.vstack{flex-direction:column;align-items:stretch}.error{color:var(--danger);font-size:13px;font-weight:500}.hint{color:var(--text-dim);font-size:13px;line-height:1.55}.hint.center{text-align:center;max-width:320px}.contacts{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:6px;padding-bottom:20px;scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}.contacts::-webkit-scrollbar{width:6px}.contacts::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}.contacts::-webkit-scrollbar-track{background:transparent}.contact{padding:14px 16px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:all .15s ease;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.contact:hover{background:var(--bg-surface);border-color:var(--border-strong);transform:translate(2px)}.contact .name{font-weight:600;font-size:15px;display:flex;align-items:center;gap:4px}.contact .preview{color:var(--text-muted);font-size:12px;margin-top:3px}.contact .badge{background:var(--accent);color:#fff;border-radius:var(--radius-pill);padding:3px 9px;font-size:11px;font-weight:600}.contact.group .name{color:var(--accent-hover)}.verified-badge{color:var(--success);font-size:13px;margin-left:4px}.chat-header{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border);background:var(--bg-overlay);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);position:sticky;top:0;z-index:10}.chat-header .back{background:transparent;border:1px solid var(--border);padding:6px 12px;font-size:14px}.chat-header .back:hover{background:var(--bg-elevated);transform:none}.chat-header .name{flex:1;font-weight:600;font-size:16px;cursor:pointer;display:flex;align-items:center;gap:6px}.chat-header .name:hover{color:var(--accent-hover)}.chat-header .info{background:transparent;border:1px solid var(--border);padding:6px 12px;font-size:16px}.chat-header .info:hover{background:var(--bg-elevated);transform:none}.chat-header .verified-badge{font-size:14px}.messages{flex:1;overflow-y:auto;overflow-x:hidden;padding:16px;display:flex;flex-direction:column;align-items:stretch;gap:6px;scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent;overscroll-behavior:contain}.messages::-webkit-scrollbar{width:6px}.messages::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}.bubble{max-width:78%;padding:10px 14px;border-radius:var(--radius-lg);word-wrap:break-word;overflow-wrap:anywhere;word-break:break-word;white-space:pre-wrap;min-width:0;font-size:15px;line-height:1.45;animation:bubbleIn .25s cubic-bezier(.16,1,.3,1)}@keyframes bubbleIn{0%{opacity:0;transform:translateY(6px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.bubble.mine{background:var(--gradient-bubble-mine);align-self:flex-end;border-bottom-right-radius:6px;color:#fff;box-shadow:0 2px 12px #6366f140}.bubble.theirs{background:var(--bg-elevated);border:1px solid var(--border);align-self:flex-start;border-bottom-left-radius:6px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.bubble .sender-label{font-size:12px;font-weight:600;color:var(--accent-hover);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-swiping{transition:transform .05s linear;will-change:transform}.chat-swipe-out{transition:transform .2s cubic-bezier(.16,1,.3,1),opacity .2s;transform:translate(100%);opacity:0}.bubble .time{font-size:11px;opacity:.7;margin-top:4px;text-align:right;display:flex;justify-content:flex-end;align-items:center;gap:4px}.bubble .check{display:inline-block;font-size:11px}.bubble .check.pending{opacity:.5}.bubble .check.sent{opacity:.85}.bubble .check.delivered{opacity:1;color:#7ee787}.bubble .edited-tag{font-size:10px;opacity:.6;margin-right:4px;font-style:italic}.bubble.highlight-flash{animation:highlightFlash 1.5s ease}@keyframes highlightFlash{0%,to{background-color:inherit}20%,80%{background-color:var(--accent-soft)}}.reply-quote{border-left:3px solid var(--accent-hover);padding:4px 8px;margin-bottom:6px;background:#ffffff0f;border-radius:6px;cursor:pointer;transition:background .15s}.bubble.mine .reply-quote{border-left-color:#ffffff8c;background:#ffffff1f}.reply-quote:hover{background:#ffffff1f}.reply-author{font-size:12px;font-weight:600;color:var(--accent-hover);margin-bottom:2px}.bubble.mine .reply-author{color:#fffffff2}.reply-preview{font-size:13px;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bubble.mine .reply-preview{color:#ffffffd9}.bubble-menu{position:fixed;z-index:200;background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-md);padding:4px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;min-width:180px;animation:modalIn .12s ease}.bubble-menu-item{background:transparent;border:none;text-align:left;padding:9px 12px;border-radius:var(--radius-sm);color:var(--text);font-size:14px;font-weight:500;cursor:pointer}.bubble-menu-item:hover{background:var(--bg-elevated);transform:none;box-shadow:none}.bubble-menu-item.danger{color:var(--danger)}.bubble-menu-item.danger:hover{background:#ef44441f}.composer-extras{display:flex;align-items:center;gap:10px;padding:10px 14px;margin:0 12px;background:var(--bg-elevated);border:1px solid var(--border);border-bottom:none;border-radius:var(--radius-md) var(--radius-md) 0 0}.composer-extras-icon{color:var(--accent-hover);font-size:18px;font-weight:700}.composer-extras-text{flex:1;min-width:0}.composer-extras-author{font-size:12px;font-weight:600;color:var(--accent-hover)}.composer-extras-preview{font-size:13px;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bubble.media{padding:4px;background:transparent;box-shadow:none;border:none}.bubble.media.mine,.bubble.media.theirs{background:transparent;border:none}.bubble.media img{display:block;max-width:100%;max-height:360px;border-radius:var(--radius-md);cursor:zoom-in;transition:transform .2s ease}.bubble.media img:hover{transform:scale(1.01)}.bubble .media-loading{display:flex;align-items:center;justify-content:center;width:200px;height:200px;background:var(--bg-elevated);border-radius:var(--radius-md);color:var(--text-muted);font-size:13px}.bubble.audio{padding:8px 12px}.bubble .audio-loading{font-size:14px;padding:8px 0;color:var(--text-dim)}.audio-player{display:flex;align-items:center;gap:10px;min-width:200px}.audio-play{background:var(--bg-deep);color:var(--text);border:1px solid var(--border-strong);border-radius:var(--radius-pill);width:36px;height:36px;padding:0;font-size:13px;flex:0 0 auto;display:flex;align-items:center;justify-content:center}.bubble.mine .audio-play{background:#ffffff2e;border-color:#ffffff4d}.audio-progress{flex:1;height:4px;background:#ffffff26;border-radius:2px;cursor:pointer;position:relative}.audio-progress-fill{height:100%;background:var(--text);border-radius:2px;width:0%;transition:width .1s linear}.bubble.mine .audio-progress-fill{background:#fffffff2}.audio-duration{font-size:12px;color:var(--text-dim);min-width:36px;text-align:right}.bubble.mine .audio-duration{color:#ffffffd9}.composer .mic{background:var(--bg-elevated);border:1px solid var(--border);padding:8px 12px;font-size:18px;flex:0 0 auto}.composer .mic.recording{background:var(--danger);border-color:var(--danger);animation:micPulse 1.2s ease-in-out infinite}@keyframes micPulse{0%,to{box-shadow:0 0 #ef444499}50%{box-shadow:0 0 0 10px #ef444400}}.recording-indicator{display:flex;align-items:center;justify-content:center;padding:8px 12px;background:var(--bg-overlay);border-top:1px solid var(--border);color:var(--danger);font-size:13px;font-weight:600}.chat-root{display:flex;flex-direction:column;flex:1;overflow:hidden}.composer{display:flex;gap:8px;padding:12px 16px 16px;border-top:1px solid var(--border);background:var(--bg-overlay);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);align-items:center}.composer input[type=text]{flex:1}.composer .attach{background:var(--bg-elevated);border:1px solid var(--border);padding:8px 12px;font-size:18px;flex:0 0 auto}.composer .attach:hover{background:var(--bg-surface);transform:none}.composer button{flex:0 0 auto;min-width:44px}.status{font-size:12px;color:var(--text-muted);text-align:center;padding:8px 4px}.status.bad{color:var(--danger)}.spacer{flex:1}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100;padding:16px;animation:overlayIn .2s ease}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-lg);padding:24px;max-width:480px;width:100%;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow-lg);animation:modalIn .25s cubic-bezier(.16,1,.3,1)}@keyframes modalIn{0%{opacity:0;transform:scale(.94) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal h2{color:var(--text);text-transform:none;letter-spacing:-.01em;font-size:18px}.modal .safety-number{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;background:var(--bg-deep);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;font-size:15px;letter-spacing:1px;line-height:1.8;text-align:center;word-spacing:6px;-webkit-user-select:all;user-select:all}.modal .actions{display:flex;gap:8px;justify-content:flex-end;margin-top:4px}.modal .verified-state{background:var(--success-soft);border:1px solid var(--success);border-radius:var(--radius-md);padding:12px;color:var(--success);font-size:13px;font-weight:500}.member-picker,.member-list{max-height:280px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius-md);padding:6px;background:var(--bg-deep)}.member-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm)}.member-row:hover{background:var(--bg-elevated)}.member-row label{cursor:pointer;flex:1;font-size:14px}.member-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent);cursor:pointer}.member-row .small{padding:4px 8px;font-size:11px;background:var(--danger)}.member-row .small:hover{background:#dc2626}.avatar{display:flex;align-items:center;justify-content:center;border-radius:var(--radius-pill);font-weight:700;color:#fff;text-transform:uppercase;flex:0 0 auto;-webkit-user-select:none;user-select:none;background:var(--gradient-accent);box-shadow:var(--shadow-sm),inset 0 1px #ffffff26;font-family:Inter,sans-serif}.avatar.group{border-radius:var(--radius-md)}.avatar-sm{width:28px;height:28px;font-size:12px}.avatar-md{width:44px;height:44px;font-size:17px}.avatar-lg{width:64px;height:64px;font-size:24px}.avatar-hero{width:96px;height:96px;font-size:36px}.contacts-screen{padding:16px 16px 0;gap:12px}.topbar{display:flex;align-items:center;gap:12px;padding:4px 0 8px}.topbar-name{flex:1;font-size:18px;font-weight:700}.icon-btn{background:var(--bg-elevated);border:1px solid var(--border);padding:8px 12px;font-size:16px;color:var(--text-dim)}.icon-btn:hover{background:var(--bg-surface);color:var(--text);transform:none}.icon-btn.danger:hover{background:#ef444426;color:var(--danger);border-color:#ef44444d}.remember-row{display:flex;align-items:center;gap:10px;padding:4px 2px;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:14px;color:var(--text-dim)}.remember-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent);cursor:pointer}.remember-row:hover{color:var(--text)}.push-banner{display:flex;align-items:center;gap:8px;padding:10px 14px;background:linear-gradient(135deg,#6366f12e,#a855f724);border:1px solid var(--accent-soft);border-radius:var(--radius-md);font-size:13px;animation:fadeIn .3s ease}.push-banner-text{flex:1;color:var(--text)}button.small{padding:6px 12px;font-size:12px}button.icon-btn.small{padding:6px 10px}.search-input{font-size:14px;padding:10px 14px;border-radius:var(--radius-pill);background:var(--bg-elevated)}.search-input::-webkit-search-cancel-button{-webkit-appearance:none;-moz-appearance:none;appearance:none}.contact{gap:12px}.row-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;overflow:hidden}.row-name{font-weight:600;font-size:15px;display:flex;align-items:center;gap:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row-preview{color:var(--text-dim);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row-preview mark{background:var(--accent-soft);color:var(--text);padding:0 2px;border-radius:3px}.row-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex:0 0 auto}.row-time{font-size:11px;color:var(--text-muted)}.row-badge{background:var(--gradient-accent);color:#fff;border-radius:var(--radius-pill);padding:2px 8px;font-size:11px;font-weight:700;min-width:22px;text-align:center}.search-results{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:6px;padding-bottom:20px}.chat-title{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}.chat-title .name{flex:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-subtitle{font-size:12px;color:var(--text-muted)}.typing-indicator{font-size:12px;color:var(--accent-hover);height:14px;opacity:0;transition:opacity .2s ease}.typing-indicator.active{opacity:1}@media (max-width: 480px){.screen{padding:16px}.screen.auth{padding-top:32px}.hero-title{font-size:32px}.hero-logo{width:80px;height:80px}.bubble{max-width:85%}}
