@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--bg-primary: #1c1c1e;--bg-secondary: #2c2c2e;--bg-tertiary: #3a3a3a;--accent: #2aabee;--accent-dark: #229ed9;--text-primary: #ffffff;--text-secondary: #8d8d8d;--online: #4dcd5e;--danger: #ff453a;--divider: rgba(255, 255, 255, .08);--safe-top: max(env(safe-area-inset-top), 0px);--safe-bottom: max(env(safe-area-inset-bottom), 0px);font-family:Inter,sans-serif}:root[data-theme=light]{--bg-primary: #f4f6fb;--bg-secondary: #ffffff;--bg-tertiary: #e6ebf2;--text-primary: #141414;--text-secondary: #6b7280;--divider: rgba(0, 0, 0, .08)}*{box-sizing:border-box;-webkit-font-smoothing:antialiased}html,body,#root{min-height:100vh}body{margin:0;background:var(--bg-primary);color:var(--text-primary);overflow-x:hidden}button,input,textarea{font:inherit}button{border:0;background:none;color:inherit}input,textarea{outline:none;-webkit-appearance:none}.sr-only-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}a{color:inherit;text-decoration:none}.app-error,.auth-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(160deg,#0d0d0d,#1a1a2e,#0d0d0d)}.auth-card{width:min(100%,400px);padding:28px 24px;border-radius:24px;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);box-shadow:0 24px 60px #00000059}.auth-brand{color:var(--accent);font-size:28px;font-weight:700}.auth-subtitle{color:var(--text-secondary)}.app-error-actions{display:flex;gap:12px;margin-top:20px}.primary-button,.ghost-button,.outline-button,.ghost-inline-button{border-radius:14px;transition:.15s ease}.primary-button,.outline-button,.ghost-button{min-height:48px;padding:0 16px}.primary-button{background:var(--accent);color:#fff}.ghost-button,.ghost-inline-button{color:var(--text-secondary)}.outline-button{border:1px solid var(--accent);color:var(--accent)}.auth-page{padding:24px}.auth-shell{position:relative;width:min(100%,360px);margin:0 auto;animation:auth-screen-in .3s ease-out}.auth-stage{display:flex;flex-direction:column}.auth-mode-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:18px}.auth-mode-tab{min-height:44px;border-radius:14px;display:grid;place-items:center;background:#ffffff0f;color:var(--text-secondary);font-weight:600}.auth-mode-tab.active{background:#2aabee29;color:var(--accent)}.auth-logo-block,.auth-code-top{text-align:center}.auth-logo-block{margin-bottom:48px}.auth-logo{width:80px;height:80px;display:block;margin:0 auto 16px;object-fit:contain}.auth-logo-small{width:56px;height:56px;margin-bottom:18px}.auth-brand-title{font-size:28px;font-weight:700;letter-spacing:-.5px}.auth-brand-tagline,.auth-code-top p,.auth-name-subtitle,.auth-footnote,.auth-resend-row span{color:var(--text-secondary)}.auth-code-top h1,.auth-name-title{margin:0 0 10px;font-size:24px;font-weight:700}.auth-field-label{margin-bottom:8px;font-size:13px;color:var(--text-secondary)}.auth-phone-wrap{position:relative}.auth-phone-prefix{position:absolute;inset:0 auto 0 16px;display:inline-flex;align-items:center;gap:8px;pointer-events:none}.auth-phone-input,.auth-name-input{width:100%;height:52px;padding:0 16px;border-radius:14px;border:1px solid rgba(255,255,255,.1);background:#ffffff12;color:#fff}.auth-phone-input{padding-left:72px}.auth-phone-input:focus,.auth-name-input:focus,.code-cell:focus,.screen-search input:focus,.sheet-search input:focus,.chat-composer-input:focus,.profile-inline-input:focus,.profile-inline-area:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2aabee26}.auth-phone-input::placeholder,.auth-name-input::placeholder{color:#ffffff40}.auth-error-row{display:flex;align-items:center;gap:6px;margin-top:12px;color:#ff6b6b;font-size:13px;animation:auth-fade-in .2s ease,auth-shake .4s ease}.auth-submit-button{width:100%;height:52px;margin-top:20px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--accent);color:#fff;font-size:15px;font-weight:600}.auth-submit-button:hover:not(:disabled),.primary-button:hover,.floating-button:hover,.chat-send-button:hover{background:var(--accent-dark)}.auth-submit-button:disabled{opacity:.7}.auth-spinner{animation:spin .8s linear infinite}.auth-footnote{margin:24px 0 0;font-size:12px;text-align:center}.auth-back-button{position:absolute;top:-6px;left:-6px;width:36px;height:36px;border-radius:18px;display:grid;place-items:center;color:var(--text-secondary)}.code-grid{display:grid;grid-template-columns:repeat(6,44px);justify-content:center;gap:8px}.code-cell{width:44px;height:52px;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#ffffff12;color:#fff;text-align:center;font-size:22px;font-weight:600;caret-color:transparent}.code-cell.filled{border-color:#2aabee66;background:#2aabee14}.auth-resend-row{display:flex;justify-content:center;gap:6px;margin-top:24px;flex-wrap:wrap}.auth-resend-button{color:var(--accent)}.auth-name-badge{width:64px;height:64px;margin:0 auto 20px;border-radius:50%;display:grid;place-items:center;color:var(--accent);background:#2aabee26;font-size:28px}.mobile-app{min-height:100vh;padding-top:calc(var(--safe-top) + 8px);background:var(--bg-primary);position:relative}.mobile-app.is-chat-detail{height:100dvh;padding-top:0;display:flex;flex-direction:column;overflow:hidden}.mobile-app:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at top center,rgba(42,171,238,.12),transparent 26%),radial-gradient(circle at bottom left,rgba(80,120,255,.08),transparent 28%);pointer-events:none;z-index:0}.global-inline-error{position:relative;z-index:2;margin:0 16px 8px;padding:12px 14px;border-radius:12px;background:#ff453a24;color:#ff8a80}.call-overlay-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:55;display:grid;place-items:center;padding:24px;background:#06060a8c;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.call-overlay-card{width:min(100%,360px);padding:24px;border-radius:28px;display:grid;justify-items:center;gap:10px;background:linear-gradient(180deg,#2b5278eb,#1c1c1efa);box-shadow:0 24px 50px #00000059;text-align:center}.call-overlay-card.video{background:linear-gradient(180deg,#0d141eb3,#0a0a0ce6)}.call-overlay-card.video-active{width:min(100%,420px);margin-top:auto;align-self:end;gap:8px;background:linear-gradient(180deg,#0c0e1299,#0c0e12eb);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.call-overlay-card h3{margin:4px 0 0;font-size:24px}.call-overlay-card p,.call-overlay-card small{margin:0;color:#ffffffc2}.call-inline-error{width:100%;margin-top:4px;padding:10px 12px;border-radius:14px;background:#ff453a1f;color:#ff9a92;font-size:13px}.call-overlay-actions{width:100%;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:12px}.call-secondary-actions{width:100%;display:flex;justify-content:center;margin-top:4px}.call-secondary-button{min-height:44px;padding:0 14px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;gap:8px;background:#ffffff24;color:#fff;font-weight:500}.call-action-button{min-height:52px;border-radius:18px;display:inline-flex;align-items:center;justify-content:center;gap:8px;color:#fff;font-weight:600}.call-action-button.accept{background:#2aabee}.call-action-button.reject{background:#ff453ad1}.call-action-button.wide{grid-column:1 / -1}.call-video-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:54;background:#050608}.call-remote-video,.call-local-video{position:absolute;object-fit:cover;background:#111}.call-remote-video{top:0;right:0;bottom:0;left:0;width:100%;height:100%}.call-local-video{right:18px;bottom:calc(200px + var(--safe-bottom));width:108px;height:152px;border-radius:20px;box-shadow:0 18px 30px #00000059;border:1px solid rgba(255,255,255,.18)}.screen{min-height:100vh;display:flex;flex-direction:column;position:relative;z-index:1;animation:screen-in .26s ease-out}.screen-header,.chat-screen-header{flex-shrink:0;position:sticky;top:0;z-index:15;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:calc(var(--safe-top) + 8px) 16px 12px;background:#1c1c1ef2;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,.03)}.screen-header{position:sticky;top:0;z-index:15}.screen-header-main,.chat-screen-main{display:flex;align-items:center;gap:12px}.screen-header-main{min-width:0}.chat-screen-main{min-width:0;flex:1;overflow:hidden}.screen-header-main h1,.chat-screen-copy strong{margin:0;font-size:20px;font-weight:700}.screen-logo{width:28px;height:28px;object-fit:contain;filter:drop-shadow(0 0 18px rgba(42,171,238,.2))}.screen-title-block{display:flex;flex-direction:column;gap:2px;min-width:0}.screen-title-block span{color:var(--text-secondary);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.screen-header-actions,.chat-screen-actions{position:relative;display:flex;align-items:center;gap:8px;margin-left:auto;flex-shrink:0;z-index:3;pointer-events:auto}.icon-button-solid,.icon-button-glass,.composer-icon-button{width:40px;height:40px;border-radius:20px;display:grid;place-items:center;background:var(--bg-secondary);color:var(--text-primary)}.icon-button-glass{background:#ffffff26}.attach-trigger{background:transparent;box-shadow:none}.screen-search,.sheet-search{margin:0 16px 12px;padding:0 14px;height:40px;border-radius:20px;display:flex;align-items:center;gap:10px;background:var(--bg-secondary);color:var(--text-secondary)}.screen-search input,.sheet-search input,.chat-composer-input,.profile-inline-input,.profile-inline-area{width:100%;border:1px solid transparent;background:transparent;color:var(--text-primary)}.screen-body{flex:1;overflow:auto}.screen-body.with-tabs{padding:0 16px calc(92px + var(--safe-bottom))}.screen-body.is-empty{overflow:hidden;display:flex}.screen-body.is-empty .empty-block{min-height:auto;flex:1}.bottom-tabs{position:fixed;inset:auto 0 0;z-index:30;height:calc(60px + var(--safe-bottom));padding-bottom:var(--safe-bottom);display:grid;grid-template-columns:repeat(4,1fr);background:var(--bg-primary);border-top:1px solid #2c2c2e;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}body.sheet-open .bottom-tabs{opacity:0;pointer-events:none;transform:translateY(100%)}.bottom-tab{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--text-secondary);transition:color .15s ease,transform .15s ease}.bottom-tab.active{color:var(--accent);transform:translateY(-1px)}.bottom-tab.active:before{content:"";position:absolute;top:5px;left:50%;width:24px;height:4px;border-radius:999px;background:var(--accent);transform:translate(-50%)}.bottom-tab-label{font-size:10px}.bottom-tab-icon{position:relative;display:inline-flex}.bottom-tab-badge{position:absolute;top:-6px;right:-10px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;display:grid;place-items:center;background:var(--accent);color:#fff;font-size:10px;font-weight:700}.floating-button{position:fixed;right:20px;bottom:calc(76px + var(--safe-bottom));z-index:25;width:56px;height:56px;border-radius:28px;display:grid;place-items:center;background:var(--accent);color:#fff;box-shadow:0 18px 30px #2aabee4d;touch-action:manipulation;transition:transform .15s ease,box-shadow .15s ease}.floating-button:active{transform:scale(.97)}.menu-dropdown,.settings-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:190px;padding:8px;border-radius:14px;background:#252527;border:1px solid var(--divider);box-shadow:0 20px 40px #00000059}.menu-dropdown button,.settings-dropdown button{width:100%;min-height:42px;padding:0 10px;display:flex;align-items:center;gap:10px;border-radius:10px}.empty-block{min-height:calc(100vh - 220px);display:grid;place-items:center;align-content:center;gap:10px;text-align:center;color:var(--text-secondary);position:relative}.empty-block>*{position:relative;z-index:1}.enriched-empty{overflow:hidden}.empty-orb{position:absolute;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(42,171,238,.18),transparent 68%);filter:blur(8px);pointer-events:none}.empty-block svg{color:#2aabee80}.chat-list-mobile{display:flex;flex-direction:column;gap:8px}.stagger-item{animation:rise-in .26s ease both}.chat-row-shell{position:relative;border-radius:18px;background:linear-gradient(180deg,#ffffff05,#fff0);border:1px solid rgba(255,255,255,.03)}.chat-row{position:relative;z-index:1;width:100%;min-height:72px;padding:10px 14px;display:flex;align-items:center;gap:12px;border-radius:18px;background:transparent;transform:translate(0);transition:transform .18s ease,background-color .15s ease}.chat-row-main{min-width:0;flex:1;display:flex;align-items:center;gap:12px;text-align:left;border:0;padding:0;background:transparent;color:inherit;font:inherit}.chat-row:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(135deg,rgba(42,171,238,.06),transparent 45%);opacity:0;pointer-events:none;transition:opacity .18s ease}.chat-filters{padding:0 16px 8px;display:flex;gap:8px}.chat-filter-pill{min-height:34px;padding:0 14px;border-radius:999px;background:#ffffff0d;color:var(--text-secondary);display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600}.chat-filter-pill span{min-width:18px;height:18px;padding:0 6px;border-radius:999px;background:#2aabee2e;color:var(--accent);display:inline-flex;align-items:center;justify-content:center;font-size:11px}.chat-filter-pill.active{background:#2aabee2e;color:#fff}.chat-row:hover:after,.chat-row:active:after{opacity:1}.chat-row:active,.contact-row:active,.settings-row:active,.profile-info-row:active,.sheet-list-item:active,.action-card-row:active,.settings-user-card:active{background:#ffffff0a}.chat-row-copy,.contact-row-copy,.sheet-list-copy{min-width:0;flex:1}.chat-row-more{width:34px;height:34px;flex:0 0 34px;border-radius:17px;border:0;display:inline-flex;align-items:center;justify-content:center;color:var(--text-secondary);background:#ffffff0a}.chat-row-head,.chat-row-foot{display:flex;align-items:center;justify-content:space-between;gap:10px}.chat-row-title{display:inline-flex;align-items:center;gap:6px;min-width:0}.chat-row-title strong,.chat-row-foot span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-row-head strong,.contact-row-copy strong,.sheet-list-copy strong{font-size:15px;font-weight:600}.chat-row-head span,.chat-row-foot span,.contact-row-copy span,.sheet-list-copy span{color:var(--text-secondary);font-size:13px}.pill-badge{min-width:20px;height:20px;padding:0 6px;border-radius:10px;display:grid;place-items:center;background:var(--accent);color:#fff;font-size:11px;font-weight:700}.screen-chats .chat-list-mobile{padding-top:4px}.action-card,.settings-card,.profile-card{margin-top:4px;border-radius:16px;background:var(--bg-secondary);overflow:hidden}.action-card-elevated,.polished-card{box-shadow:inset 0 1px #ffffff08,0 16px 30px #00000024}.action-card-row,.contact-row,.settings-row,.profile-info-row{position:relative;width:100%;min-height:60px;padding:0 16px;display:flex;align-items:center;gap:14px;text-align:left}.action-card-icon,.settings-row-icon{width:40px;height:40px;border-radius:20px;display:grid;place-items:center;background:#2aabee29;color:var(--accent)}.contacts-sections{display:flex;flex-direction:column;gap:18px;margin-top:20px}.contact-section-letter,.settings-card-title{margin:0 4px 10px;color:var(--text-secondary);font-size:12px;text-transform:uppercase;letter-spacing:.08em;position:sticky;top:0;z-index:1;padding:6px 0;background:linear-gradient(180deg,#1c1c1ef5,#1c1c1eb3);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.contact-row{width:100%;min-height:60px;border-radius:14px;border:0;text-align:left}.contact-row-copy span.online{color:var(--online)}.contact-row-remove{margin-left:auto;width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:var(--text-secondary);background:#ffffff0a}.contact-row-remove:active{transform:scale(.96)}.contact-picker-item{justify-content:space-between}.contact-picker-action{min-width:86px;height:34px;padding:0 12px;border-radius:999px;background:#2aabee29;color:var(--accent);font-size:13px;font-weight:600}.contact-picker-action.is-added{background:#ffffff14;color:var(--text-primary)}.settings-user-card{width:100%;padding:16px;margin-bottom:24px;border-radius:16px;display:flex;align-items:center;gap:14px;background:var(--bg-secondary)}.settings-user-card svg:last-child{color:var(--text-secondary)}.settings-user-copy{flex:1;display:flex;flex-direction:column;gap:4px;text-align:left}.settings-user-copy strong{font-size:17px}.settings-user-copy span,.settings-row-copy small,.profile-info-copy span{color:var(--text-secondary);font-size:13px}.settings-row{min-height:52px}.settings-row-copy{flex:1;display:flex;flex-direction:column;gap:2px}.settings-row.danger{color:var(--danger)}.settings-sheet-row{width:100%;min-height:54px;padding:0 14px;display:flex;align-items:center;justify-content:space-between;gap:12px;border-radius:14px;text-align:left}.settings-sheet-row span{display:flex;flex-direction:column;gap:2px}.settings-sheet-row strong{font-size:14px;font-weight:600}.settings-sheet-row small{color:var(--text-secondary);font-size:12px}.settings-sheet-row.selected{background:#2aabee1f;color:var(--accent)}.settings-sheet-card{padding:16px;border-radius:16px;background:var(--bg-secondary);display:flex;flex-direction:column;gap:6px}.settings-sheet-card strong{font-size:16px}.settings-sheet-card span,.settings-sheet-card small{color:var(--text-secondary)}.settings-update-notes{margin:0;padding-left:18px;color:var(--text-secondary);display:flex;flex-direction:column;gap:6px}.settings-update-notes li{line-height:1.4}.settings-sheet-notice{margin-top:12px;min-height:40px;padding:0 14px;border-radius:14px;display:flex;align-items:center;gap:8px;background:#2aabee1f;color:var(--accent)}.settings-sessions-list{margin-top:12px}.settings-session-item{align-items:flex-start}.settings-session-item .sheet-list-copy{flex:1}.settings-session-item .sheet-list-copy small{color:var(--text-secondary);font-size:12px}.settings-session-action{flex-shrink:0;min-width:92px;align-self:center}.group-manage-card{display:flex;flex-direction:column;gap:16px}.group-manage-hero{position:relative;display:flex;justify-content:center;padding-top:8px}.group-avatar-action{position:absolute;right:calc(50% - 48px);bottom:-4px}.group-members-header{margin-top:16px;display:flex;align-items:center;justify-content:space-between;gap:12px}.group-members-list{margin-top:12px}.group-member-item{align-items:flex-start}.group-member-actions{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.group-role-icon{color:var(--accent);margin-top:6px}.group-role-icon.muted{color:var(--text-secondary)}.group-danger-zone{margin-top:16px;display:flex;flex-direction:column;gap:10px}.danger-text{color:var(--danger)}.sheet-section-title{margin:18px 0 10px;color:var(--text-secondary);font-size:12px;text-transform:uppercase;letter-spacing:.08em}.settings-divider{position:absolute;left:70px;right:0;bottom:0;height:1px;background:var(--divider)}.danger-outline{border-color:#ff453a59;color:var(--danger)}.profile-screen{background:linear-gradient(180deg,#2b5278,#1c1c1e 280px)}.profile-hero{min-height:280px;padding:12px 16px 24px;position:relative;overflow:hidden}.profile-hero:before,.profile-hero:after{content:"";position:absolute;border-radius:50%;filter:blur(6px)}.profile-hero:before{width:220px;height:220px;top:28px;left:-40px;background:radial-gradient(circle,rgba(94,169,255,.26),transparent 68%)}.profile-hero:after{width:170px;height:170px;top:8px;right:-20px;background:radial-gradient(circle,rgba(255,255,255,.12),transparent 70%)}.profile-hero-actions{display:flex;justify-content:flex-end;gap:8px;position:relative;z-index:1}.profile-hero-content{margin-top:14px;display:grid;justify-items:center;text-align:center;position:relative;z-index:1}.profile-avatar-wrap{position:relative}.profile-camera-badge{position:absolute;right:-4px;bottom:-4px;width:32px;height:32px;border-radius:16px;display:grid;place-items:center;background:var(--accent);color:#fff}.profile-hero-content h1{margin:16px 0 6px;font-size:22px}.profile-hero-content p{margin:0;color:#ffffffb8}.profile-action-grid{width:100%;margin-top:20px;display:grid;grid-template-columns:repeat(3,1fr);gap:10px;max-width:360px}.profile-action-button{min-height:64px;border-radius:16px;display:grid;place-items:center;gap:6px;background:#ffffff26;transition:transform .15s ease,background-color .15s ease}.profile-action-button:active{transform:translateY(1px) scale(.98)}.profile-body{margin-top:-12px}.profile-photo-actions{display:grid;gap:10px}.profile-photo-action{min-height:76px;padding:14px 16px;align-items:flex-start;border:1px solid var(--divider);border-radius:18px;background:#ffffff0a}.profile-photo-action .sheet-list-copy{display:flex;flex-direction:column;gap:4px}.profile-photo-action .sheet-list-copy span{display:block;line-height:1.4;text-align:left}.profile-info-row+.profile-info-row{border-top:1px solid var(--divider)}.profile-info-copy{width:100%;display:flex;flex-direction:column;gap:4px}.profile-info-copy strong{font-size:16px;font-weight:500;text-align:left}.profile-inline-input::placeholder,.profile-inline-area::placeholder{color:#ffffff57}.profile-inline-input,.profile-inline-area{padding:0;color:var(--text-primary)}.profile-inline-area{min-height:52px;resize:vertical}.profile-inline-error{margin-top:16px;padding:12px 14px;border-radius:14px;background:#ff453a1f;color:#ff8a80;font-size:14px}.danger-card{width:100%;margin-top:20px;min-height:56px;border-radius:16px;background:#ff453a1f;color:var(--danger);font-weight:600}.chat-screen{height:100%;display:flex;flex-direction:column;background:var(--bg-primary);animation:chat-slide-in .26s ease;overflow:hidden}.chat-screen-copy{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1;overflow:hidden}.chat-screen-copy strong,.chat-screen-copy span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-screen-copy span,.typing-copy,.message-time,.message-status{color:var(--text-secondary);font-size:12px}.chat-messages{flex:1;min-height:0;padding:8px 16px 12px;overflow:auto;background:var(--bg-primary);scroll-behavior:smooth}.date-separator-wrap{display:flex;justify-content:center;margin:14px 0}.date-separator{padding:6px 12px;border-radius:999px;background:var(--bg-secondary);color:var(--text-secondary);font-size:12px}.message-row{display:flex;margin-bottom:10px;animation:message-in .2s ease}.message-row.system{justify-content:center;margin:16px 0}.message-row-highlight .message-bubble{box-shadow:0 0 0 1px #2aabee80,0 0 0 8px #2aabee14}.message-row.own{justify-content:flex-end}.message-bubble{max-width:min(78%,440px);padding:10px 12px 8px;border-radius:18px}.message-bubble.interactive{cursor:pointer}.message-bubble.other{background:var(--bg-secondary);border-bottom-left-radius:6px}.message-bubble.own{background:#2b5278;border-bottom-right-radius:6px}.system-message-chip{max-width:min(92%,420px);padding:8px 14px;border-radius:999px;display:inline-flex;align-items:center;gap:10px;background:#ffffff14;color:var(--text-secondary);font-size:12px;text-align:center}.system-message-chip small{color:var(--text-secondary);opacity:.8}.message-author{margin-bottom:6px;color:var(--accent);font-size:12px}.message-text{font-size:14px;line-height:1.5;white-space:pre-wrap}.message-reply-preview{width:100%;margin:0 0 8px;padding:8px 10px;border-radius:12px;display:flex;flex-direction:column;gap:4px;background:#ffffff14;text-align:left}.message-reply-preview strong{font-size:12px;color:var(--accent)}.message-reply-preview span,.chat-pinned-copy span,.composer-context-copy span{color:var(--text-secondary);font-size:12px;line-height:1.4}.message-reactions{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.message-reaction-chip{min-height:26px;padding:0 8px;border-radius:999px;display:inline-flex;align-items:center;gap:5px;background:#ffffff14;color:var(--text-primary);font-size:12px}.message-reaction-chip.active{background:#2aabee29;color:var(--accent)}.message-meta{display:flex;justify-content:flex-end;align-items:center;gap:4px;margin-top:6px}.message-status.read{color:var(--accent)}.message-action-button{min-width:28px;height:28px;padding:0 8px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;gap:6px;background:#ffffff0f;color:var(--text-secondary)}.message-action-button .active{color:var(--accent)}.message-action-button.danger{color:#ff8a80}.message-action-button.emoji{min-width:52px;height:40px;border-radius:16px;background:#ffffff14;font-size:20px}.message-action-grid{display:flex;gap:8px;margin-bottom:8px}.message-image-button{width:100%;padding:0;border:0;background:transparent;display:block}.message-image,.message-video{width:100%;border-radius:14px;margin-bottom:8px}.media-viewer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;background:#04060cf0;display:flex;align-items:center;justify-content:center;padding:20px}.media-viewer-shell{width:min(100%,960px);max-height:100%;display:flex;flex-direction:column;gap:12px}.media-viewer-actions{display:flex;justify-content:flex-end;gap:10px}.media-viewer-image{width:100%;max-height:calc(100vh - 120px);object-fit:contain;border-radius:18px}.file-card{display:inline-flex;min-height:44px;align-items:center;margin-bottom:8px;padding:0 12px;border-radius:12px;background:#ffffff14}.typing-bubble{padding:10px 12px;border-radius:18px;display:inline-flex;align-items:center;gap:6px;background:var(--bg-secondary)}.typing-dot{width:6px;height:6px;border-radius:50%;background:var(--text-secondary);animation:typing 1.2s infinite ease-in-out}.typing-dot:nth-child(2){animation-delay:.12s}.typing-dot:nth-child(3){animation-delay:.24s}.chat-pinned-bar{display:flex;align-items:center;gap:10px;padding:10px 16px;border-bottom:1px solid var(--divider);background:#2c2c2eeb;flex-shrink:0}.chat-pinned-copy,.composer-context-copy{min-width:0;flex:1;display:flex;flex-direction:column;gap:2px}.chat-pinned-copy strong,.composer-context-copy strong{font-size:13px;font-weight:600}.composer-context{display:flex;align-items:center;gap:10px;padding:10px 16px;border-top:1px solid var(--divider);background:#2c2c2ee0;flex-shrink:0}.search-message-item{text-align:left}.forward-preview{margin-bottom:12px;padding:12px 14px;border-radius:14px;background:#2aabee14;color:var(--text-primary);text-align:left}.chat-composer{padding:10px 16px calc(10px + var(--safe-bottom));display:flex;align-items:flex-end;gap:10px;border-top:1px solid var(--divider);background:var(--bg-primary);flex-shrink:0}.chat-composer-input{min-height:44px;max-height:140px;padding:11px 16px;border-radius:20px;resize:none;background:var(--bg-secondary);color:var(--text-primary)}.chat-send-button{width:44px;height:44px;flex:0 0 44px;border-radius:22px;display:grid;place-items:center;background:var(--bg-secondary);color:var(--text-secondary)}.chat-send-button.active{background:var(--accent);color:#fff}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;display:flex;align-items:flex-end;background:#00000073;overscroll-behavior:contain;overflow:hidden;height:100vh;height:100dvh;touch-action:none}.sheet{width:100%;min-height:min(68vh,540px);min-height:min(68dvh,540px);max-height:100vh;max-height:100dvh;padding:10px 16px calc(20px + var(--safe-bottom));border-radius:24px 24px 0 0;display:flex;flex-direction:column;background:#202022;animation:sheet-in .25s ease;overflow:hidden;touch-action:pan-y}.sheet-handle{width:42px;height:4px;margin:0 auto 12px;border-radius:999px;background:#fff3}.sheet-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}.sheet-header h3{margin:0;font-size:18px}.sheet-body{flex:1;min-height:0;overflow-y:auto;padding-bottom:8px;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;touch-action:pan-y}.sheet-list{display:flex;flex-direction:column}.sheet-panel{padding:0 0 12px}.sheet-label{display:block;margin:0 0 8px;color:var(--text-secondary);font-size:13px}.sheet-inline-input{width:100%;min-height:48px;padding:0 14px;border:1px solid transparent;border-radius:14px;background:var(--bg-secondary);color:var(--text-primary)}.sheet-inline-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2aabee26}.sheet-helper{padding:18px 8px;color:var(--text-secondary);font-size:14px;text-align:center}.sheet-helper.error{padding-top:0;color:#ff8a80}.chip-row{display:flex;flex-wrap:wrap;gap:8px;padding:0 0 12px}.chip{min-height:32px;padding:0 12px;border-radius:16px;background:#2aabee29;color:var(--accent)}.sheet-list-item{width:100%;min-height:62px;padding:0 4px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--divider)}.sheet-list-item.selected{background:#2aabee14}.sheet-list-item:last-child{border-bottom:0}.sheet-submit{width:100%;margin-top:16px}.ui-avatar{position:relative;flex:0 0 auto}.ui-avatar-image,.ui-avatar-fallback{width:100%;height:100%;border-radius:50%}.ui-avatar-image{object-fit:cover}.ui-avatar-fallback{display:grid;place-items:center;color:#fff;font-weight:700}.ui-avatar-status{position:absolute;right:0;bottom:0;width:12px;height:12px;border:2px solid #fff;border-radius:50%;background:var(--online)}.empty-chat-logo{width:80px;opacity:.85}@keyframes spin{to{transform:rotate(360deg)}}@keyframes typing{0%,80%,to{transform:scale(.7);opacity:.6}40%{transform:scale(1);opacity:1}}@keyframes screen-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes rise-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes message-in{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes chat-slide-in{0%{opacity:0;transform:translate(18px)}to{opacity:1;transform:translate(0)}}@keyframes sheet-in{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes auth-fade-in{0%{opacity:0}to{opacity:1}}@keyframes auth-screen-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes auth-shake{20%,60%{transform:translate(-6px)}40%,80%{transform:translate(6px)}to{transform:translate(0)}}@media(min-width:900px){.mobile-app{max-width:520px;margin:0 auto;border-left:1px solid var(--divider);border-right:1px solid var(--divider)}.mobile-app.is-chat-detail{height:100dvh}.bottom-tabs,.floating-button,.sheet-backdrop{max-width:520px;left:50%;transform:translate(-50%)}}
