@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap";:root{--bg-app: #17212b;--bg-sidebar: #1e2c3a;--bg-chat: #0e1621;--bg-bubble-in: #1e2c3a;--bg-bubble-out: linear-gradient(135deg, #d32f2f 0%, #8e1a1a 100%);--bg-input: #1a2633;--bg-card: #1a2836;--border-subtle: rgba(255,255,255,.06);--text: #e8ecf0;--text-muted: #6d8299;--text-dim: #4a6175;--accent: #e53935;--accent-hover: #c62828;--accent-soft: rgba(229,57,53,.1);--accent-glow: rgba(229,57,53,.15);--icon-accent: #e53935;--icon-muted: #5a7388;--shadow-lg: 0 8px 32px rgba(0,0,0,.35);--shadow-bubble: 0 1px 4px rgba(0,0,0,.15);--radius: 14px;--radius-lg: 20px;--radius-bubble: 16px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);font-family:Manrope,system-ui,-apple-system,sans-serif;background:var(--bg-app);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}*{box-sizing:border-box;margin:0;padding:0}html{overflow:hidden;height:100%;height:100dvh;width:100%;max-width:100vw}body{height:100%;min-height:0;width:100%;max-width:100vw;background:var(--bg-app);overscroll-behavior:none;overflow:hidden;touch-action:manipulation}#root{overflow:hidden;height:100%;width:100%;max-width:100vw}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:3px}::selection{background:#e539354d;color:#fff}a{color:var(--accent);text-decoration:none;transition:opacity .15s}a:hover{opacity:.85}button,input,textarea{font:inherit}button{cursor:pointer;-webkit-tap-highlight-color:transparent}input,textarea{-webkit-tap-highlight-color:transparent}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInL{0%{opacity:0;transform:translate(-14px)}to{opacity:1;transform:translate(0)}}@keyframes slideInR{0%{opacity:0;transform:translate(14px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes recPulse{0%,to{box-shadow:0 0 #e5393580}50%{box-shadow:0 0 0 8px #e5393500}}@keyframes scaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.auth-page{height:100svh;height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem;padding-top:calc(1.5rem + var(--safe-top));padding-bottom:calc(1.5rem + var(--safe-bottom));background:var(--bg-chat);position:relative;overflow:auto;overflow-x:hidden}.auth-page:before{content:"";position:absolute;top:-40%;left:-20%;width:80%;height:80%;background:radial-gradient(ellipse,rgba(229,57,53,.06) 0%,transparent 70%);pointer-events:none}.auth-page .panel{max-width:min(400px,calc(100vw - 2rem));width:100%;position:relative;z-index:1}.auth-logo{display:flex;align-items:center;justify-content:center;margin-bottom:2rem;animation:fadeInUp .6s ease-out}.auth-logo img{width:72px;height:72px;border-radius:18px;box-shadow:var(--shadow-lg)}.auth-page h1{margin:0 0 .25rem;font-size:1.65rem;font-weight:800;color:var(--text);text-align:center;letter-spacing:-.02em;animation:fadeInUp .5s ease-out}.auth-subtitle{text-align:center;color:var(--text-muted);font-size:.9rem;margin-bottom:1.75rem;animation:fadeInUp .55s ease-out}.panel{max-width:720px;margin:0 auto;padding:1.5rem}.card{background:var(--bg-card);border-radius:var(--radius-lg);padding:1.75rem;border:1px solid var(--border-subtle);box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:scaleIn .4s ease-out}.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.15rem}.field label{font-size:.78rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}input,textarea{padding:.7rem .85rem;border-radius:12px;border:1px solid var(--border-subtle);background:var(--bg-input);color:var(--text);font-size:.95rem;transition:border-color .2s,box-shadow .2s}input::placeholder,textarea::placeholder{color:var(--text-dim)}input:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.7rem 1.25rem;border-radius:12px;border:none;background:var(--accent);color:#fff;font-weight:700;font-size:.95rem;transition:background .2s,transform .1s,box-shadow .2s;position:relative;overflow:hidden}.btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.08) 0%,transparent 100%);pointer-events:none}.btn:hover{background:var(--accent-hover);box-shadow:0 4px 16px #e539354d}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}.btn-full{width:100%}.btn-ghost{background:transparent;color:var(--accent);border:1px solid rgba(229,57,53,.25)}.btn-ghost:after{display:none}.btn-ghost:hover{background:var(--accent-soft);border-color:var(--accent);box-shadow:none}.btn-small{padding:.4rem .75rem;font-size:.82rem;border-radius:10px}.error{color:#ef5350;font-size:.88rem;font-weight:500;animation:fadeIn .3s ease}.hint{font-size:.88rem;color:var(--text-muted);margin-top:1rem;text-align:center}.app-shell{display:grid;grid-template-columns:minmax(280px,340px) 1fr;height:100%;height:100dvh;width:100%;max-width:100vw;max-height:100vh;max-height:100dvh;background:var(--bg-app);overflow:hidden;position:fixed;top:0;right:0;bottom:0;left:0}.chat-main{display:flex;flex-direction:column;min-height:0;max-height:100%;overflow:hidden;background:var(--bg-chat);max-width:100vw}.chat-sidebar{display:flex;flex-direction:column;min-height:0;max-height:100%;overflow:hidden;background:var(--bg-sidebar);border-right:1px solid var(--border-subtle);max-width:100vw}.chat-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;padding-top:calc(.75rem + var(--safe-top));min-height:56px;border-bottom:1px solid var(--border-subtle);flex-shrink:0;background:#1e2c3ad9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);position:sticky;top:0;z-index:10}.chat-sidebar-title{font-size:1.2rem;font-weight:800;color:var(--text)}.icon-btn{display:inline-flex;align-items:center;justify-content:center;padding:.45rem;border:none;background:transparent;color:var(--icon-muted);border-radius:12px;transition:background .15s,color .15s,transform .1s}.icon-btn:hover{background:var(--accent-soft);color:var(--icon-accent)}.icon-btn:active{transform:scale(.9)}.icon-24{width:24px;height:24px;flex-shrink:0}.sidebar-error{margin:.5rem 1rem 0;color:#ef5350;font-size:.82rem}.sidebar-hint{margin:.75rem 1rem;color:var(--text-muted);font-size:.85rem;animation:pulse 1.5s infinite}.sidebar-section{padding:.65rem .75rem;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.sidebar-new-toggle{width:100%;text-align:left;padding:.6rem .85rem;border-radius:12px;border:1px dashed rgba(255,255,255,.1);background:#ffffff05;color:var(--text-muted);font-weight:600;font-size:.88rem;transition:border-color .2s,color .2s,background .2s}.sidebar-new-toggle:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.sidebar-new-panel{margin-top:.75rem;overflow:hidden;animation:fadeInUp .3s ease-out}.field-compact{margin-bottom:.65rem}.field-compact:last-child{margin-bottom:0}.field-compact label{font-size:.72rem;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.3rem;display:block}.row-gap{display:flex;gap:.45rem;align-items:center}.row-gap input{flex:1;min-width:0;font-size:.88rem;padding:.5rem .7rem}.user-pick-list{list-style:none;margin:0 0 .5rem}.user-pick-list li{margin-bottom:.3rem}.user-pick-btn{width:100%;text-align:left;padding:.5rem .65rem;border-radius:10px;border:1px solid var(--border-subtle);background:var(--bg-input);color:var(--text);font-size:.88rem;font-weight:500;transition:border-color .15s,background .15s}.user-pick-btn:hover{border-color:var(--accent);background:var(--accent-soft)}.chat-room-nav{flex:1;overflow-y:auto;overflow-x:hidden;min-height:0;-webkit-overflow-scrolling:touch}.chat-room-list{list-style:none}.chat-room-item{display:flex;align-items:center;gap:.85rem;padding:.7rem .85rem;text-decoration:none;color:inherit;border-radius:14px;margin:.15rem .4rem;transition:background .15s}.chat-room-item:hover{background:#ffffff0a;text-decoration:none}.chat-room-item.active{background:var(--accent-soft)}.chat-room-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#e53935,#b71c1c);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.15rem;flex-shrink:0;box-shadow:0 2px 8px #e5393533}.chat-room-avatar-img{object-fit:cover;background:var(--bg-input)}.chat-room-avatar-wrap{position:relative;flex-shrink:0;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center}.chat-room-avatar-wrap>.chat-room-avatar{width:100%;height:100%}.chat-room-avatar-wrap.is-ancient:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:50%;border:2px solid #ef5350;box-shadow:0 0 0 1px #ef535040;pointer-events:none}.chat-room-presence-dot{position:absolute;right:-1px;bottom:-1px;width:13px;height:13px;border-radius:50%;border:2px solid var(--bg-sidebar);box-shadow:0 1px 2px #0006;pointer-events:none}.chat-room-presence-dot.is-online{background:#34c759}.chat-room-presence-dot.is-offline{background:#4fc3f7}.chat-room-avatar-wrap.is-ancient .chat-room-presence-dot{border-color:#1a0707}.chat-room-presence{color:var(--text-dim)}.chat-room-presence-online{color:#34c759;font-weight:600}.chat-room-presence-sep{color:var(--text-dim)}.chat-room-meta{display:flex;flex-direction:column;min-width:0;gap:.15rem}.chat-room-name{font-weight:600;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}.chat-room-sub{font-size:.78rem;color:var(--text-dim)}.chat-room-badge{flex-shrink:0;min-width:22px;height:22px;padding:0 6px;border-radius:11px;background:var(--accent);color:#fff;font-size:.72rem;font-weight:700;display:flex;align-items:center;justify-content:center}.push-enable-btn{width:100%;padding:.7rem 1rem;border-radius:12px;border:none;background:var(--accent);color:#fff;font-weight:700;font-size:.9rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,box-shadow .2s,transform .1s;box-shadow:0 2px 12px #e5393559;animation:pushGlow 2s ease-in-out infinite}.push-enable-btn:hover{background:var(--accent-hover);box-shadow:0 4px 20px #e5393573}.push-enable-btn:active{transform:scale(.97)}.push-enable-btn:disabled{opacity:.5;cursor:not-allowed;animation:none}@keyframes pushGlow{0%,to{box-shadow:0 2px 12px #e5393559}50%{box-shadow:0 2px 20px #e539358c}}.sidebar-footnote{font-size:.72rem;color:var(--text-dim);padding:.65rem 1rem;padding-bottom:calc(.65rem + var(--safe-bottom));border-top:1px solid var(--border-subtle);flex-shrink:0;line-height:1.4}.chat-empty{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;min-height:0;background:var(--bg-chat);position:relative}.chat-empty:before{content:"";position:absolute;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(229,57,53,.04) 0%,transparent 70%);pointer-events:none}.chat-empty-inner{text-align:center;max-width:340px;animation:fadeInUp .5s ease-out}.chat-empty-icon{display:inline-flex;align-items:center;justify-content:center;width:88px;height:88px;border-radius:28px;background:#e5393514;color:var(--accent);margin-bottom:1.5rem}.chat-empty-icon svg{width:44px;height:44px}.chat-empty-title{margin:0 0 .6rem;font-size:1.35rem;font-weight:800;color:var(--text)}.chat-empty-text{margin:0;color:var(--text-muted);font-size:.9rem;line-height:1.55}.chat-room{display:flex;flex-direction:column;flex:1;min-height:0;max-width:100%;overflow:hidden;background:var(--bg-chat)}.chat-room-error{padding:2rem}.chat-header{display:flex;align-items:center;gap:.6rem;padding:.55rem .85rem;padding-top:calc(.55rem + var(--safe-top));min-height:56px;background:#1e2c3ad9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle);flex-shrink:0;overflow:visible;z-index:10}.chat-back{flex-shrink:0}.chat-header-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0}.chat-header-avatar-letter{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e53935,#b71c1c);color:#fff;font-weight:800;font-size:.95rem;width:40px;height:40px;border-radius:50%;flex-shrink:0;text-decoration:none}.chat-header-text{min-width:0;flex:1}.chat-header-title{font-size:1rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}.chat-header-sub{margin:.1rem 0 0;font-size:.78rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-room-banner{padding:.4rem 1rem;font-size:.82rem}.offline-banner{color:var(--text-muted);background:#ffa50014;border-bottom:1px solid rgba(255,165,0,.15);animation:fadeIn .3s ease}.chat-toolbar{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;padding:.4rem .85rem;background:#1e2c3a99;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.phrase-display{font-family:Manrope,monospace;font-weight:700;font-size:.85rem;padding:.3rem .65rem;border-radius:8px;background:var(--bg-input);border:1px solid var(--border-subtle);color:var(--accent);cursor:pointer;-webkit-user-select:all;user-select:all;letter-spacing:.02em;transition:border-color .15s}.phrase-display:hover{border-color:var(--accent);background:var(--accent-soft)}.hint-inline{font-size:.78rem;color:var(--text-dim)}.msg-list{flex:1;display:flex;flex-direction:column;gap:.3rem;overflow-y:auto;overflow-x:hidden;padding:.75rem .85rem;min-height:0;max-width:100%;-webkit-overflow-scrolling:touch}.msg-list-end{height:1px;flex-shrink:0}.bubble{align-self:flex-start;max-width:min(80%,520px);min-width:72px;padding:.5rem .85rem .4rem;border-radius:var(--radius-bubble);border-bottom-left-radius:6px;background:var(--bg-bubble-in);font-size:.93rem;box-shadow:var(--shadow-bubble);border:1px solid rgba(255,255,255,.04);color:var(--text);overflow-wrap:anywhere;word-break:break-word;content-visibility:auto;contain-intrinsic-size:auto 60px}.bubble.me{align-self:flex-end;background:var(--bg-bubble-out);color:#fff;border:none;border-bottom-left-radius:var(--radius-bubble);border-bottom-right-radius:6px}.bubble.new-msg{animation:slideInL .25s ease-out}.bubble.me.new-msg{animation:slideInR .25s ease-out}.bubble.me .bubble-author{color:#ffffff8c}.bubble-author{font-size:.7rem;font-weight:600;color:var(--accent);margin-bottom:.1rem}.bubble-body{word-break:break-word;overflow-wrap:anywhere;line-height:1.5;white-space:pre-wrap}.bubble-body a{overflow-wrap:anywhere;word-break:break-all}.bubble.me .bubble-body a{color:#fff;text-decoration:underline;text-decoration-color:#fff6;text-underline-offset:2px}.bubble.me .bubble-body a:hover{text-decoration-color:#fffc}.bubble-footer{display:flex;justify-content:flex-end;align-items:center;gap:.35rem;margin-top:.15rem}.bubble-time{font-size:.65rem;color:var(--text-dim);font-weight:500}.bubble-delete{display:none;border:none;background:none;color:var(--text-dim);font-size:.85rem;cursor:pointer;padding:0 .2rem;line-height:1;opacity:.6;transition:opacity .15s}.bubble-delete:hover{opacity:1;color:#ef5350}.bubble:hover .bubble-delete{display:inline-flex}.bubble.me .bubble-time{color:#fff6}.bubble.grouped{margin-top:-.15rem;padding-top:.3rem;animation:none}.bubble.grouped:not(.me){border-top-left-radius:6px}.bubble.grouped.me{border-top-right-radius:6px}.bubble.group-cont:not(.me){border-bottom-left-radius:6px}.bubble.group-cont.me{border-bottom-right-radius:6px}.bubble-check{width:16px;height:16px;color:var(--text-dim);flex-shrink:0}.bubble.me .bubble-check{color:#fff6}.bubble-check.read{color:#4fc3f7!important}.bubble-check.pending{opacity:.5;animation:pulse 1.5s infinite}.decrypt-failed{color:var(--text-dim);font-size:.82rem;font-style:italic;display:inline-flex;align-items:center;gap:.35rem}.retry-btn{border:none;background:none;color:var(--accent);font-size:1rem;cursor:pointer;padding:.1rem .3rem;border-radius:6px;transition:background .15s}.retry-btn:hover{background:var(--accent-soft)}.decrypt-pending{display:inline-block;width:60px;height:.9em;border-radius:4px;background:linear-gradient(90deg,var(--bg-input) 25%,rgba(255,255,255,.06) 50%,var(--bg-input) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.chat-header-sub.online{color:#4fc3f7}.voice-player{display:flex;align-items:center;gap:.5rem;margin-top:.35rem;min-width:0;max-width:100%;overflow:hidden}.voice-play-btn{width:36px;height:36px;border-radius:50%;border:none;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:transform .1s,background .15s}.voice-play-btn:hover{background:var(--accent-hover)}.voice-play-btn:active{transform:scale(.92)}.voice-play-btn svg{width:18px;height:18px}.voice-waveform{flex:1;height:32px;cursor:pointer;display:block}.voice-time{font-size:.72rem;color:var(--text-dim);font-weight:500;font-variant-numeric:tabular-nums;flex-shrink:0;min-width:32px;text-align:right}.bubble.me .voice-play-btn{background:#fff3}.bubble.me .voice-play-btn:hover{background:#ffffff4d}.bubble.me .voice-time{color:#ffffff80}.voice-loading{height:36px;border-radius:8px;background:var(--bg-input);overflow:hidden;margin-top:.35rem}.voice-loading-bar{height:100%;background:var(--accent-soft);transition:width .3s ease}.file-card{display:flex;align-items:center;gap:.65rem;margin-top:.35rem;padding:.3rem 0;max-width:100%;min-width:0;overflow:hidden}.file-icon-wrap{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative}.file-icon-wrap.loading{background:var(--bg-input)}.file-ext{font-size:.65rem;font-weight:800;letter-spacing:.03em;text-transform:uppercase}.file-progress-ring{width:44px;height:44px;position:absolute;top:0;left:0}.file-info{display:flex;flex-direction:column;gap:.1rem;min-width:0}.file-name{font-size:.85rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.file-size{font-size:.72rem;color:var(--text-dim)}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999;background:#000000eb;display:flex;align-items:center;justify-content:center;cursor:default;animation:fadeIn .2s ease;overflow:hidden;touch-action:none}.lightbox-img{max-width:95vw;max-height:calc(95vh - 56px);max-height:calc(95dvh - 56px);object-fit:contain;border-radius:4px;box-shadow:0 8px 48px #00000080;transition:transform .15s ease;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;touch-action:none}.lightbox-toolbar{position:fixed;top:0;left:0;right:0;display:flex;align-items:center;justify-content:flex-end;gap:.35rem;padding:.6rem .85rem;padding-top:calc(.6rem + var(--safe-top));background:linear-gradient(180deg,rgba(0,0,0,.6) 0%,transparent 100%);z-index:1000;pointer-events:none}.lightbox-btn{pointer-events:auto;display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 .55rem;border:none;border-radius:10px;background:#ffffff1f;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s,transform .1s;text-decoration:none;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.lightbox-btn:hover{background:#ffffff38}.lightbox-btn:active{transform:scale(.92)}.lightbox-close{font-size:1.4rem;font-weight:400;min-width:40px;height:40px}.bubble-file-link{display:inline-flex;align-items:center;gap:.3rem;margin-top:.35rem;color:var(--accent);font-weight:500;font-size:.82rem;text-decoration:none;padding:.25rem .6rem;border-radius:8px;background:#e5393514;transition:background .15s}.bubble-file-link:hover{background:#e5393526;text-decoration:none}.bubble.me .bubble-file-link{color:#ffcdd2;background:#ffffff1a}.chat-room-top-row{display:flex;align-items:baseline;justify-content:space-between;gap:.4rem}.chat-room-time{font-size:.7rem;color:var(--text-dim);flex-shrink:0;font-weight:500}.chat-room-bottom-row{display:flex;align-items:center;justify-content:space-between;gap:.4rem}.chat-room-sub{font-size:.78rem;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bubble-reply-quote{display:flex;flex-direction:column;gap:.05rem;padding:.3rem .6rem;margin-bottom:.3rem;border-left:3px solid var(--accent);border-radius:4px;background:#ffffff0d;cursor:pointer;transition:background .15s}.bubble-reply-quote:hover{background:#ffffff14}.bubble.me .bubble-reply-quote{border-left-color:#fff6;background:#ffffff14}.bubble.me .bubble-reply-quote:hover{background:#ffffff1f}.reply-quote-sender{font-size:.7rem;font-weight:700;color:var(--accent)}.bubble.me .reply-quote-sender{color:#ffffffb3}.reply-quote-body{font-size:.78rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.bubble.me .reply-quote-body{color:#ffffff80}.pending-file-preview{display:flex;align-items:center;gap:.6rem;padding:.5rem .85rem;background:#1e2c3af2;border-top:1px solid var(--border-subtle);flex-shrink:0;overflow:hidden;max-width:100%;animation:fadeIn .15s ease}.pending-file-thumb{width:48px;height:48px;border-radius:8px;object-fit:cover;flex-shrink:0;border:1px solid var(--border-subtle)}.pending-file-icon{width:40px;height:40px;border-radius:10px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}.pending-file-info{display:flex;flex-direction:column;gap:.1rem;min-width:0;flex:1;overflow:hidden}.pending-file-name{font-size:.85rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pending-file-size{font-size:.72rem;color:var(--text-dim)}.pending-file-close{border:none;background:none;color:var(--text-dim);font-size:1.2rem;cursor:pointer;padding:.2rem .4rem;border-radius:6px;flex-shrink:0;transition:color .15s,background .15s;line-height:1}.pending-file-close:hover{color:var(--text);background:#ffffff0f}.upload-queue{display:flex;flex-direction:column;gap:1px;background:#1e2c3af2;border-top:1px solid var(--border-subtle);flex-shrink:0;max-height:180px;overflow-y:auto}.upload-item{display:flex;align-items:center;gap:.55rem;padding:.45rem .85rem;animation:fadeIn .15s ease}.upload-item.upload-done{opacity:.6}.upload-item.upload-error{background:#ef53500f}.upload-item-thumb{width:36px;height:36px;border-radius:6px;object-fit:cover;flex-shrink:0;border:1px solid var(--border-subtle)}.upload-item-icon{width:32px;height:32px;border-radius:8px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}.upload-item-info{display:flex;flex-direction:column;gap:.15rem;min-width:0;flex:1;overflow:hidden}.upload-item-name{font-size:.82rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upload-item-status{font-size:.7rem;color:var(--text-muted);font-weight:500}.upload-item.upload-error .upload-item-status{color:#ef5350}.upload-item.upload-done .upload-item-status{color:#4fc3f7}.upload-item-bar{height:3px;border-radius:2px;background:var(--border-subtle);overflow:hidden;margin-top:.1rem}.upload-item-bar-fill{height:100%;border-radius:2px;background:var(--accent);transition:width .3s ease}.upload-item-bar-indeterminate{width:40%;animation:indeterminate 1.2s ease-in-out infinite}@keyframes indeterminate{0%{transform:translate(-100%)}50%{transform:translate(150%)}to{transform:translate(250%)}}.upload-item-retry{border:none;background:var(--accent-soft);color:var(--accent);font-size:.95rem;cursor:pointer;padding:.2rem .45rem;border-radius:6px;flex-shrink:0;line-height:1;transition:background .15s;font-weight:600}.upload-item-retry:hover{background:var(--accent);color:#fff}.upload-item-close{border:none;background:none;color:var(--text-dim);font-size:1.1rem;cursor:pointer;padding:.1rem .35rem;border-radius:6px;flex-shrink:0;line-height:1;transition:color .15s,background .15s}.upload-item-close:hover{color:var(--text);background:#ffffff0f}.reply-preview{display:flex;align-items:center;gap:.5rem;padding:.4rem .85rem;background:#1e2c3af2;border-top:1px solid var(--border-subtle);border-left:3px solid var(--accent);flex-shrink:0;animation:fadeIn .15s ease}.reply-preview-content{display:flex;flex-direction:column;gap:.05rem;min-width:0;flex:1}.reply-preview-sender{font-size:.72rem;font-weight:700;color:var(--accent)}.reply-preview-body{font-size:.82rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reply-preview-close{border:none;background:none;color:var(--text-dim);font-size:1.1rem;cursor:pointer;padding:.2rem .4rem;border-radius:6px;flex-shrink:0;transition:color .15s,background .15s}.reply-preview-close:hover{color:var(--text);background:#ffffff0f}.pin-banner{display:flex;align-items:center;gap:.5rem;padding:.35rem .85rem;background:#1e2c3ae6;border-bottom:1px solid var(--border-subtle);cursor:pointer;flex-shrink:0;transition:background .15s;animation:fadeIn .2s ease}.pin-banner:hover{background:#1e2c3a}.pin-banner-text{display:flex;flex-direction:column;gap:.05rem;min-width:0;flex:1}.pin-banner-label{font-size:.68rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.04em}.pin-banner-body{font-size:.8rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pin-banner-close{border:none;background:none;color:var(--text-dim);font-size:1.1rem;cursor:pointer;padding:.2rem .4rem;border-radius:6px;flex-shrink:0;transition:color .15s,background .15s}.pin-banner-close:hover{color:var(--text);background:#ffffff0f}.bubble-action{display:none;border:none;background:none;color:var(--text-dim);cursor:pointer;padding:.1rem .2rem;line-height:1;opacity:.5;transition:opacity .15s}.bubble-action:hover{opacity:1;color:var(--accent)}.bubble:hover .bubble-action{display:inline-flex}.bubble.me .bubble-action{color:#ffffff59}.bubble.me .bubble-action:hover{color:#fffc}@keyframes msgFlash{0%{background:#e5393526}to{background:transparent}}.highlight-flash{animation:msgFlash 1.5s ease-out}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;background:#000000a6;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .15s ease}.modal-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:1.25rem 1.35rem;max-width:min(420px,calc(100vw - 2rem));width:100%;box-shadow:var(--shadow-lg);animation:scaleIn .18s ease-out}.scroll-to-bottom{position:absolute;bottom:80px;right:20px;width:40px;height:40px;border-radius:50%;border:1px solid var(--border-subtle);background:var(--bg-sidebar);color:var(--text);font-size:1.2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-lg);z-index:6;transition:background .15s}.scroll-to-bottom:hover{background:var(--accent-soft)}.typing-indicator{padding:.15rem .85rem;font-size:.78rem;color:var(--text-muted);animation:pulse 1.5s infinite;flex-shrink:0}.bubble-image{max-width:100%;width:auto;height:auto;max-height:min(300px,50vh);border-radius:8px;margin-top:.35rem;cursor:pointer;object-fit:contain;display:block}.chat-room{position:relative}.msg-list{background-image:radial-gradient(circle at 20% 80%,rgba(229,57,53,.015) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(229,57,53,.01) 0%,transparent 50%)}.composer{display:flex;align-items:flex-end;gap:.3rem;padding:.55rem .65rem;padding-bottom:calc(.55rem + var(--safe-bottom));background:#1e2c3ad9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border-subtle);flex-shrink:0;overflow:visible;width:100%;max-width:100%;position:relative}.composer-input-wrap{position:relative;flex:1;min-width:0}.composer-input{width:100%;min-height:42px;max-height:120px;resize:none;border-radius:22px;padding:.6rem 2.4rem .6rem 1rem;border:1px solid var(--border-subtle);background:var(--bg-input);color:var(--text);font-size:1rem;line-height:1.4;transition:border-color .2s,box-shadow .2s,opacity .2s;box-sizing:border-box}.composer-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}.composer-input.composer-disabled{opacity:.55;cursor:not-allowed}.composer-locked-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.4rem .85rem;background:#0e1621b3;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);border-top:1px solid var(--border-subtle);color:var(--text-muted);font-size:.82rem;font-weight:500;pointer-events:none;text-align:center}.composer-locked-overlay svg{width:16px;height:16px;flex-shrink:0;opacity:.7}.composer-emoji-btn{position:absolute;right:.45rem;bottom:.45rem;width:28px;height:28px;border:none;background:none;color:var(--text-dim);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;padding:0;transition:color .15s,background .15s}.composer-emoji-btn:hover{color:var(--accent);background:var(--accent-soft)}.icon-20{width:20px;height:20px}.composer-attach,.composer-send,.composer-mic{flex-shrink:0;margin-bottom:.1rem}.emoji-picker{position:fixed;bottom:70px;right:max(.5rem,calc(50vw - 170px));width:min(340px,calc(100vw - 1rem));max-height:min(380px,calc(100dvh - 140px));background:var(--bg-sidebar);border:1px solid var(--border-subtle);border-radius:14px;box-shadow:0 8px 32px #00000073;display:flex;flex-direction:column;z-index:200;animation:emojiSlideUp .15s ease-out;overflow:hidden}@keyframes emojiSlideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.emoji-tabs{display:flex;gap:0;border-bottom:1px solid var(--border-subtle);flex-shrink:0;padding:0 .25rem}.emoji-tab{flex:1;border:none;background:none;padding:.5rem .15rem;font-size:1.15rem;cursor:pointer;opacity:.45;transition:opacity .15s;border-bottom:2px solid transparent;line-height:1}.emoji-tab:hover{opacity:.75}.emoji-tab.active{opacity:1;border-bottom-color:var(--accent)}.emoji-search{margin:.4rem .5rem;padding:.4rem .7rem;border-radius:10px;border:1px solid var(--border-subtle);background:var(--bg-input);color:var(--text);font-size:.85rem;outline:none;flex-shrink:0;transition:border-color .15s}.emoji-search:focus{border-color:var(--accent)}.emoji-grid{flex:1;display:grid;grid-template-columns:repeat(8,1fr);gap:1px;overflow-y:auto;padding:.3rem .4rem;-webkit-overflow-scrolling:touch}.emoji-cell{border:none;background:none;font-size:1.45rem;padding:.3rem;cursor:pointer;border-radius:8px;line-height:1;text-align:center;transition:background .1s,transform .1s}.emoji-cell:hover{background:var(--accent-soft);transform:scale(1.2)}.emoji-cell:active{transform:scale(.95)}.emoji-empty{grid-column:1/-1;text-align:center;color:var(--text-dim);font-size:.82rem;padding:2rem 0}.composer-rec-stop{margin-bottom:.1rem;animation:recPulse 1.2s infinite}.composer:has(.voice-rec-bar) .composer-input-wrap,.composer:has(.voice-rec-bar) .composer-attach,.composer:has(.voice-rec-bar) .composer-send{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);pointer-events:none;opacity:0}.voice-rec-bar{display:flex;align-items:center;gap:.4rem;flex:1;min-width:0;width:100%;max-width:100%;padding:.3rem 0;animation:fadeIn .15s ease;overflow:hidden}.voice-rec-indicator{display:flex;align-items:center;gap:.3rem;flex-shrink:0}.voice-rec-dot{width:10px;height:10px;border-radius:50%;background:#e53935;animation:recPulse 1.2s infinite;flex-shrink:0}.voice-rec-time{font-size:.82rem;font-weight:600;color:var(--text);font-variant-numeric:tabular-nums;min-width:32px;flex-shrink:0}.voice-rec-waveform{flex:1;height:28px;min-width:30px}.voice-rec-actions{display:flex;gap:.3rem;flex-shrink:0;margin-left:auto}.voice-rec-lock{border:none;background:#ffffff0f;color:var(--text-dim);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .15s,color .15s}.voice-rec-lock:hover{background:#ffffff1f;color:var(--text)}.msg-date-sep{display:flex;align-items:center;justify-content:center;padding:.5rem 0;position:sticky;top:0;z-index:2}.msg-date-sep span{font-size:.72rem;font-weight:600;color:var(--text-dim);background:#0e1621e6;padding:.25rem .85rem;border-radius:12px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}@media(max-width:768px){.app-shell{grid-template-columns:1fr}.app-shell[data-chat-open=true] .chat-sidebar,.app-shell[data-profile-open=true] .chat-sidebar,.app-shell[data-chat-open=false][data-profile-open=false] .chat-main{display:none}.chat-main{border-left:none;height:100%;max-height:100dvh}.chat-sidebar{height:100%;max-height:100dvh;border-right:none}.chat-room-item{margin:.1rem .3rem;border-radius:12px}.bubble{max-width:min(90%,520px)}.msg-list{padding:.5rem}.voice-player{min-width:0}.file-name{max-width:100%}input,textarea,select,.composer-input{font-size:1rem}.emoji-picker{width:calc(100vw - 1rem);right:.5rem;left:auto;transform:none;max-height:min(320px,calc(100dvh - 120px));bottom:60px}.emoji-grid{grid-template-columns:repeat(7,1fr)}.emoji-cell{font-size:1.3rem;padding:.25rem}.emoji-tab{font-size:1rem;padding:.4rem .1rem}.mute-dropdown{right:0;max-width:calc(100vw - 2rem)}.chat-search-bar{padding:.3rem .55rem;gap:.25rem}.chat-search-deep{padding:.3rem .55rem;font-size:.75rem}.sidebar-search{padding:.4rem .55rem}.profile-body{padding:1rem}.gp-phrase-actions{flex-wrap:wrap}.chat-header{gap:.4rem;padding:.45rem .55rem;padding-top:calc(.45rem + var(--safe-top))}.pending-file-preview{padding:.4rem .55rem}.upload-queue{max-height:min(180px,30vh)}}@media(max-height:420px){.chat-header{min-height:44px;padding-top:.35rem;padding-bottom:.35rem}.chat-toolbar{padding:.25rem .65rem}.pin-banner{padding:.2rem .65rem}.reply-preview{padding:.25rem .65rem}.pending-file-preview{padding:.3rem .65rem}.pending-file-thumb{width:36px;height:36px}.composer{padding:.35rem .5rem;padding-bottom:calc(.35rem + var(--safe-bottom))}.composer-input{min-height:36px;max-height:80px;padding:.45rem .85rem}.emoji-picker{max-height:calc(100dvh - 100px);bottom:50px}.bubble-image{max-height:min(200px,40vh)}}.image-editor-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;background:#000000eb;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.image-editor{width:100%;height:100%;display:flex;flex-direction:column;max-width:100vw;max-height:100vh;max-height:100dvh;overflow:hidden}.image-editor-toolbar{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;padding-top:calc(.5rem + var(--safe-top));flex-shrink:0;background:#0e1621e6;border-bottom:1px solid var(--border-subtle)}.image-editor-tools{display:flex;gap:.4rem;align-items:center}.image-editor-canvas-wrap{flex:1;display:flex;align-items:center;justify-content:center;min-height:0;padding:.5rem;overflow:hidden}.image-editor-stack{position:relative;display:inline-block;max-width:100%;max-height:100%;line-height:0}.image-editor-stack .image-editor-canvas{max-width:100%;max-height:100%;display:block;touch-action:none}.image-editor-draw-layer{position:absolute;left:0;top:0;width:100%;height:100%;touch-action:none;pointer-events:none}.image-editor-tool-active{border-color:var(--accent)!important;color:var(--accent)!important}.image-editor-draw-toolbar{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.5rem .75rem;padding:.35rem .75rem .5rem;background:#0e1621bf;border-bottom:1px solid var(--border-subtle)}.image-editor-colors{display:flex;align-items:center;gap:.35rem}.image-editor-swatch{width:26px;height:26px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0;flex-shrink:0;box-sizing:border-box}.image-editor-swatch-active{border-color:#fff!important;box-shadow:0 0 0 1px #0006}.image-editor-widths{display:flex;align-items:center;gap:.25rem}.image-editor-width-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--border-subtle);background:#ffffff0f;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.image-editor-width-active{border-color:var(--accent);background:var(--accent-soft)}.image-editor-width-dot{border-radius:50%;background:var(--text)}.image-editor-loading{color:var(--text-muted);font-size:.9rem;animation:pulse 1.5s infinite}.profile-page{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--bg-chat)}.profile-header{display:flex;align-items:center;gap:.6rem;padding:.55rem .85rem;padding-top:calc(.55rem + var(--safe-top));min-height:56px;background:#1e2c3ad9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle);flex-shrink:0}.profile-header-title{font-size:1rem;font-weight:700;color:var(--text)}.profile-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:1.5rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem;animation:fadeInUp .4s ease-out;max-width:100%}.profile-avatar-section{display:flex;flex-direction:column;align-items:center;gap:.5rem}.profile-avatar-large{width:120px;height:120px;border-radius:50%;overflow:hidden;cursor:pointer;position:relative;background:linear-gradient(135deg,#e53935,#b71c1c);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 24px #e5393540;transition:transform .15s}.profile-avatar-large:hover{transform:scale(1.03)}.profile-avatar-large img{width:100%;height:100%;object-fit:cover}.profile-avatar-letter{font-size:2.5rem;font-weight:800;color:#fff}.profile-avatar-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0006;opacity:0;transition:opacity .2s;color:#fff}.profile-avatar-large:hover .profile-avatar-overlay{opacity:1}.profile-status{font-size:.82rem;color:var(--text-muted);animation:pulse 1.5s infinite}.profile-form{width:100%;max-width:min(360px,calc(100vw - 2rem))}.profile-success{color:#4fc3f7;font-size:.88rem;font-weight:500;animation:fadeIn .3s ease}.profile-bio-input{width:100%;max-width:100%;min-height:96px;resize:vertical;border-radius:12px;padding:.65rem .85rem;border:1px solid var(--border-subtle);background:var(--bg-input);color:var(--text);font-size:.92rem;line-height:1.45;font-family:inherit}.profile-sessions{width:100%;max-width:min(560px,calc(100vw - 2rem));margin-top:.5rem}.profile-sessions-header{display:flex;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.6rem}.profile-sessions-title{margin:0;font-size:1.05rem;font-weight:700;color:var(--text)}.profile-sessions-hint{margin:.4rem 0 .8rem;font-size:.82rem;color:var(--text-muted)}.profile-sessions-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.profile-session{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;padding:.7rem .85rem;border:1px solid var(--border-subtle);border-radius:12px;background:var(--bg-input)}.profile-session.is-current{border-color:#4fc3f780;background:linear-gradient(0deg,#4fc3f70d,#4fc3f70d),var(--bg-input)}.profile-session-main{display:flex;flex-direction:column;gap:.25rem;min-width:0;flex:1}.profile-session-title{display:flex;flex-wrap:wrap;align-items:baseline;gap:.4rem;font-size:.95rem;color:var(--text)}.profile-session-browser{font-weight:600}.profile-session-os{color:var(--text-muted);font-size:.88rem}.profile-session-badge{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#4fc3f7;border:1px solid rgba(79,195,247,.45);border-radius:999px;padding:1px 8px;background:#4fc3f714}.profile-session-meta{display:flex;flex-wrap:wrap;gap:.6rem;font-size:.78rem;color:var(--text-muted)}.profile-session-meta-dim{color:var(--text-dim)}.btn-link{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:0;color:#4fc3f7;font-size:.85rem;font-weight:600;cursor:pointer;padding:.25rem .35rem;border-radius:8px;transition:background .15s}.btn-link:hover:not(:disabled){background:#4fc3f71a}.btn-link:disabled{opacity:.6;cursor:default}.btn-link-danger{color:#ef5350}.btn-link-danger:hover:not(:disabled){background:#ef53501f}.user-profile-page{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--bg-chat)}.profile-avatar-static{cursor:default}.profile-avatar-static:hover{transform:none}.user-profile-loading,.profile-loading{padding:1.5rem;text-align:center;color:var(--text-muted)}.user-profile-readonly{align-items:center}.user-profile-info{width:100%;max-width:min(400px,calc(100vw - 2rem));text-align:center}.user-profile-name{font-size:1.25rem;font-weight:800;color:var(--text);margin:0}.user-profile-username{font-size:.88rem;color:var(--text-muted);margin:.35rem 0 0}.user-profile-bio{margin:1rem 0 0;font-size:.95rem;line-height:1.5;color:var(--text);white-space:pre-wrap;word-break:break-word}.user-profile-bio-empty{margin:1rem 0 0;font-size:.9rem;color:var(--text-dim);font-style:italic}.chat-header-peer{display:flex;align-items:center;gap:.6rem;min-width:0;flex:1;text-decoration:none;color:inherit}.chat-header-peer:active{opacity:.95}.chat-header-group-avatar-wrap{position:relative;cursor:pointer;flex-shrink:0;border-radius:50%;overflow:hidden;width:40px;height:40px;transition:transform .15s}.chat-header-group-avatar-wrap:hover{transform:scale(1.05)}.chat-header-group-avatar-wrap .chat-header-avatar-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000073;opacity:0;transition:opacity .2s;color:#fff;border-radius:50%}.chat-header-group-avatar-wrap:hover .chat-header-avatar-overlay{opacity:1}.chat-header-uploading{font-size:.72rem;color:var(--text-muted);flex-shrink:0;animation:pulse 1.5s infinite}.mute-wrap{position:relative;flex-shrink:0}.mute-toggle.muted{color:#ef5350;background:#ef535026;border-radius:10px}.mute-dropdown{position:absolute;top:100%;right:0;margin-top:.35rem;min-width:180px;max-width:calc(100vw - 1rem);width:max-content;background:var(--bg-sidebar);border:1px solid var(--border-subtle);border-radius:12px;box-shadow:var(--shadow-lg);z-index:50;overflow:hidden;animation:scaleIn .15s ease-out}.mute-dropdown-title{padding:.5rem .75rem .25rem;font-size:.72rem;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em}.mute-dropdown-item{display:block;width:100%;text-align:left;padding:.55rem .75rem;border:none;background:none;color:var(--text);font-size:.88rem;font-weight:500;cursor:pointer;transition:background .15s}.mute-dropdown-item:hover{background:var(--accent-soft);color:var(--accent)}.chat-room-top-right{display:flex;align-items:center;gap:.3rem;flex-shrink:0}.chat-room-muted-icon{width:14px;height:14px;color:var(--text-dim);flex-shrink:0}.gp-info{text-align:center;width:100%;max-width:min(400px,calc(100vw - 2rem))}.gp-name-row{display:flex;align-items:center;justify-content:center;gap:.6rem}.gp-name{font-size:1.35rem;font-weight:800;color:var(--text);margin:0}.gp-member-count{font-size:.88rem;color:var(--text-muted);margin:.3rem 0 0}.gp-name-edit{display:flex;flex-direction:column;gap:.5rem;width:100%}.gp-name-input{text-align:center;font-size:1.1rem;font-weight:700;padding:.6rem .85rem}.gp-name-actions{display:flex;gap:.4rem;justify-content:center}.gp-section{width:100%;max-width:min(400px,calc(100vw - 2rem));padding:0}.gp-section-title{font-size:.78rem;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;margin:0 0 .65rem}.gp-phrase-block{display:flex;flex-direction:column;gap:.5rem}.gp-phrase-actions{display:flex;gap:.4rem;flex-wrap:wrap}.gp-member-list{list-style:none;width:100%}.gp-member-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .3rem;border-bottom:1px solid var(--border-subtle);transition:background .1s}.gp-member-item:last-child{border-bottom:none}.gp-member-item:hover{background:#ffffff05}.gp-member-link{display:flex;align-items:center;gap:.6rem;flex:1;min-width:0;text-decoration:none;color:inherit}.gp-member-link:hover{opacity:.9}.gp-member-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0}.gp-member-avatar-letter{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e53935,#b71c1c);color:#fff;font-weight:800;font-size:.9rem}.gp-member-info{display:flex;flex-direction:column;min-width:0}.gp-member-name{font-size:.92rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gp-member-you{font-weight:400;color:var(--text-muted)}.gp-member-role{font-size:.72rem;color:var(--text-dim);font-weight:500}.gp-member-role.admin{color:var(--accent);font-weight:700}.gp-member-actions{display:flex;gap:.3rem;flex-shrink:0}.gp-btn-danger{color:#ef5350!important;border-color:#ef53504d!important}.gp-btn-danger:hover{background:#ef53501a!important}.gp-danger-zone{display:flex;flex-direction:column;gap:.6rem;padding-top:.5rem}.gp-btn-leave{color:var(--accent)!important;border-color:#e5393540!important}.gp-btn-leave:hover{background:var(--accent-soft)!important}.gp-btn-delete{background:#c62828!important}.gp-btn-delete:hover{background:#b71c1c!important}.bubble-author .bubble-author-link{color:inherit;text-decoration:none;cursor:pointer;border-bottom:1px dashed rgba(255,255,255,.2)}.bubble-author .bubble-author-link:hover{color:var(--accent)}.bubble.me .bubble-author .bubble-author-link{border-bottom-color:#ffffff40}.sidebar-search{padding:.5rem .75rem;flex-shrink:0;border-bottom:1px solid var(--border-subtle)}.sidebar-search-wrap{display:flex;align-items:center;gap:.4rem;background:var(--bg-input);border-radius:12px;border:1px solid var(--border-subtle);padding:0 .65rem;transition:border-color .2s}.sidebar-search-wrap:focus-within{border-color:var(--accent)}.sidebar-search-icon{width:16px;height:16px;color:var(--text-dim);flex-shrink:0}.sidebar-search-input{flex:1;min-width:0;border:none!important;background:transparent!important;color:var(--text);font-size:.88rem;padding:.45rem 0!important;outline:none!important;border-radius:0!important;box-shadow:none!important}.sidebar-search-input::placeholder{color:var(--text-dim)}.sidebar-search-clear{border:none;background:none;color:var(--text-dim);font-size:1.05rem;cursor:pointer;padding:0 .15rem;line-height:1;flex-shrink:0;transition:color .15s}.sidebar-search-clear:hover{color:var(--text)}.chat-search-bar{display:flex;align-items:center;gap:.4rem;padding:.4rem .85rem;background:#1e2c3af2;border-bottom:1px solid var(--border-subtle);flex-shrink:0;animation:fadeIn .15s ease;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:9}.chat-search-input-wrap{display:flex;align-items:center;flex:1;min-width:0;gap:.4rem;background:var(--bg-input);border-radius:12px;border:1px solid var(--border-subtle);padding:0 .65rem;transition:border-color .2s}.chat-search-input-wrap:focus-within{border-color:var(--accent)}.chat-search-icon{width:18px;height:18px;color:var(--text-dim);flex-shrink:0}.chat-search-input{flex:1;min-width:0;border:none!important;background:transparent!important;color:var(--text);font-size:.9rem;padding:.5rem 0!important;outline:none!important;border-radius:0!important;box-shadow:none!important}.chat-search-input::placeholder{color:var(--text-dim)}.chat-search-count{font-size:.78rem;color:var(--text-muted);font-weight:600;white-space:nowrap;flex-shrink:0;font-variant-numeric:tabular-nums}.chat-search-count-btn{border:none;background:none;font:inherit;color:inherit;padding:.15rem .25rem;margin:0 -.25rem;border-radius:6px;cursor:pointer;transition:background .12s}.chat-search-count-btn:hover{background:#ffffff14}.chat-search-count-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.chat-search-nav{display:flex;gap:.1rem;flex-shrink:0}.chat-search-nav .icon-btn:disabled{opacity:.3}.chat-search-deep{white-space:nowrap;flex-shrink:0}.chat-search-loading{font-size:.78rem;color:var(--text-muted);animation:pulse 1.5s infinite;white-space:nowrap;flex-shrink:0;display:flex;align-items:center;gap:.35rem}.chat-search-stop{border:none;background:#ffffff14;color:var(--text-muted);font-size:.72rem;font-weight:600;padding:.15rem .45rem;border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.chat-search-stop:hover{background:#ef535026;color:#ef5350}.bubble.search-match{box-shadow:inset 0 0 0 1.5px #e5393559,var(--shadow-bubble)}.msg-list.searching .bubble.search-match{cursor:pointer}.bubble.search-current{box-shadow:inset 0 0 0 2px var(--accent),0 0 16px #e5393533;z-index:1}.msg-list.searching .bubble:not(.search-match):not(.search-current){opacity:.35;transition:opacity .15s}.msg-list.searching .bubble.search-match,.msg-list.searching .bubble.search-current{opacity:1}.msg-list.searching .msg-date-sep{opacity:.5}.storage-page{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--bg-chat)}.storage-header{display:flex;align-items:center;gap:.6rem;padding:.55rem .85rem;padding-top:calc(.55rem + var(--safe-top));min-height:56px;background:#1e2c3ad9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle);flex-shrink:0}.storage-header-meta{display:flex;flex-direction:column;min-width:0}.storage-header-title{font-size:1rem;font-weight:700;color:var(--text)}.storage-header-sub{font-size:.75rem;color:var(--text-muted);font-weight:500}.storage-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:1rem 1.25rem 2rem;display:flex;flex-direction:column;gap:1rem;max-width:900px;width:100%;margin:0 auto;animation:fadeInUp .4s ease-out}.storage-dropzone{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:2rem 1rem;border:2px dashed rgba(229,57,53,.25);border-radius:var(--radius-lg);background:linear-gradient(135deg,#e539350a,#e5393514);color:var(--text-muted);cursor:pointer;text-align:center;transition:border-color .15s,background .15s,transform .15s}.storage-dropzone:hover{border-color:var(--accent);background:linear-gradient(135deg,#e5393514,#e5393524);color:var(--text)}.storage-dropzone.drag-over{border-color:var(--accent);background:#e539352e;color:var(--text);transform:scale(1.01)}.storage-dropzone svg{color:var(--accent);opacity:.85;margin-bottom:.25rem}.storage-dropzone-title{font-weight:700;font-size:.95rem;color:var(--text)}.storage-dropzone-sub{font-size:.8rem;color:var(--text-muted)}.storage-uploads{list-style:none;display:flex;flex-direction:column;gap:.5rem}.storage-upload-row{display:grid;grid-template-columns:1fr 160px 40px;gap:.75rem;align-items:center;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:12px;padding:.6rem .85rem}.storage-upload-name{font-size:.85rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.storage-upload-bar{position:relative;height:6px;background:#ffffff0f;border-radius:4px;overflow:hidden}.storage-upload-bar-fill{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,var(--accent),#ff6b6b);transition:width .15s}.storage-upload-percent{font-size:.78rem;color:var(--text-muted);text-align:right}.storage-upload-error{grid-column:2 / span 2;font-size:.8rem;color:#ff6b6b}.storage-error{background:#e539351f;border:1px solid rgba(229,57,53,.3);color:#ffbaba;border-radius:12px;padding:.7rem .9rem;font-size:.85rem}.storage-empty{padding:2rem 1rem;text-align:center;color:var(--text-muted);font-size:.9rem}.storage-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}.storage-item{display:flex;gap:.85rem;align-items:flex-start;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:.85rem 1rem;transition:border-color .15s,background .15s}.storage-item:hover{border-color:#e5393540;background:#1e2c3b}.storage-item-icon{width:40px;height:40px;border-radius:10px;background:#e539351f;color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}.storage-item-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:.2rem}.storage-item-name{background:none;border:none;padding:0;text-align:left;color:var(--text);font-weight:600;font-size:.95rem;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.storage-item-name:hover{color:var(--accent)}.storage-item-meta{font-size:.78rem;color:var(--text-muted)}.storage-share-status{font-size:.75rem;color:#7ed4a3;font-weight:600;margin-top:.15rem}.storage-share-status.expired{color:#ff9f43}.storage-item-actions{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap;justify-content:flex-end}.btn-icon-small{width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:#ffffff0a;border:1px solid var(--border-subtle);color:var(--text);border-radius:10px;transition:background .15s,color .15s}.btn-icon-small:hover{background:#e539351f;color:var(--accent);border-color:#e539354d}.icon-18{width:18px;height:18px}.btn-small-muted{padding:.5rem .75rem;border:1px solid var(--border-subtle);background:#ffffff0a;color:var(--text);border-radius:10px;font-size:.8rem;font-weight:600;transition:background .15s,color .15s}.btn-small-muted:hover{background:#e539351a;color:var(--accent);border-color:#e539354d}.btn-small-muted.copied{background:#7ed4a324;color:#7ed4a3;border-color:#7ed4a34d}.btn-small-ghost{padding:.5rem .65rem;background:transparent;border:1px solid transparent;color:var(--text-muted);border-radius:10px;font-size:.8rem;font-weight:500}.btn-small-ghost:hover{color:var(--text);background:#ffffff0a}.btn-small-danger{padding:.5rem .75rem;border:1px solid rgba(229,57,53,.25);background:#e5393514;color:#ffb4b4;border-radius:10px;font-size:.8rem;font-weight:600;transition:background .15s,color .15s}.btn-small-danger:hover{background:#e5393533;color:#fff;border-color:var(--accent)}.storage-share-wrap{position:relative}.storage-share-menu{position:absolute;right:0;top:calc(100% + .3rem);background:#1e2c3a;border:1px solid var(--border-subtle);border-radius:12px;padding:.4rem;box-shadow:var(--shadow-lg);z-index:20;min-width:170px;animation:scaleIn .15s ease-out}.storage-share-menu-title{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:.4rem .6rem .25rem;font-weight:600}.storage-share-menu-item{display:block;width:100%;text-align:left;background:transparent;border:none;color:var(--text);padding:.5rem .6rem;border-radius:8px;font-size:.85rem;font-weight:500;transition:background .1s,color .1s}.storage-share-menu-item:hover{background:#e539351f;color:var(--accent)}@media(max-width:720px){.storage-item{flex-wrap:wrap}.storage-item-actions{width:100%;justify-content:flex-start}.storage-upload-row{grid-template-columns:1fr 90px 40px}}@media(display-mode:standalone){.chat-sidebar-header{padding-top:calc(.75rem + var(--safe-top))}.chat-header{padding-top:calc(.55rem + var(--safe-top))}.composer{padding-bottom:calc(.55rem + var(--safe-bottom))}.sidebar-footnote{padding-bottom:calc(.65rem + var(--safe-bottom))}.auth-page{padding-top:calc(1.5rem + var(--safe-top));padding-bottom:calc(1.5rem + var(--safe-bottom))}.storage-header{padding-top:calc(.55rem + var(--safe-top))}}.call-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#080e15c7;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .2s ease-out;padding:1.25rem;padding-top:calc(1.25rem + var(--safe-top));padding-bottom:calc(1.25rem + var(--safe-bottom))}.call-card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);box-shadow:var(--shadow-lg);padding:2rem 1.5rem 1.5rem;width:100%;max-width:340px;display:flex;flex-direction:column;align-items:center;gap:.85rem;animation:scaleIn .25s ease-out}.call-avatar{width:96px;height:96px;border-radius:50%;background:linear-gradient(135deg,#2a3d51,#1a2836);border:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:center;font-size:2.4rem;font-weight:700;color:var(--text);letter-spacing:-.02em;box-shadow:0 8px 24px #0006}.call-peer{font-size:1.25rem;font-weight:700;color:var(--text);text-align:center;letter-spacing:-.01em;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.call-status{font-size:.95rem;color:var(--text-muted);font-variant-numeric:tabular-nums;min-height:1.4em}.call-actions{display:flex;align-items:center;justify-content:center;gap:1.25rem;margin-top:.85rem}.call-btn{width:58px;height:58px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;color:#fff;transition:transform .12s,background .15s,box-shadow .2s}.call-btn:hover{transform:translateY(-1px)}.call-btn:active{transform:scale(.95)}.call-btn-accept{background:#2e9c5b;box-shadow:0 6px 16px #2e9c5b59}.call-btn-accept:hover{background:#28854d}.call-btn-decline{background:var(--accent);box-shadow:0 6px 16px #e5393559}.call-btn-decline:hover{background:var(--accent-hover)}.call-btn-mute{background:#ffffff14;color:var(--text);border:1px solid var(--border-subtle)}.call-btn-mute:hover{background:#ffffff24}.call-btn-mute.muted{background:#e539352e;color:#ffb4b4;border-color:#e5393566}.call-btn-output{background:#ffffff14;color:var(--text);border:1px solid var(--border-subtle)}.call-btn-output:hover{background:#ffffff24}.call-btn-output.active{background:#2e9c5b2e;color:#9ee5b8;border-color:#2e9c5b73}.call-terminal-hint{color:var(--text-dim);font-size:.85rem}.call-status-warn{color:#ffb86b;animation:callPulse 1.4s ease-in-out infinite}@keyframes callPulse{0%,to{opacity:.85}50%{opacity:.55}}.call-quality{display:inline-flex;align-items:center;gap:.4rem;font-size:.78rem;color:var(--text-dim);padding:.2rem .55rem;border-radius:999px;background:#ffffff0a;border:1px solid var(--border-subtle);min-height:22px}.call-quality-bars{display:inline-flex;align-items:flex-end;gap:2px;height:14px}.call-quality-bar{display:inline-block;width:3px;background:#ffffff2e;border-radius:1px;transition:background .25s}.call-quality-bar:nth-child(1){height:4px}.call-quality-bar:nth-child(2){height:7px}.call-quality-bar:nth-child(3){height:10px}.call-quality-bar:nth-child(4){height:13px}.call-quality-excellent .call-quality-bar.on{background:#4ad987}.call-quality-excellent{color:#9ee5b8}.call-quality-good .call-quality-bar.on{background:#9ed944}.call-quality-good{color:#bce070}.call-quality-fair .call-quality-bar.on{background:#f4b942}.call-quality-fair{color:#ffd584}.call-quality-poor .call-quality-bar.on{background:#e85a4d;animation:callQualityPoor 1.6s ease-in-out infinite}.call-quality-poor{color:#ff9a90}.call-quality-unknown{color:var(--text-dim)}.call-quality-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}.call-quality-stat{color:var(--text-dim);font-variant-numeric:tabular-nums}@keyframes callQualityPoor{0%,to{opacity:1}50%{opacity:.55}}@media(max-width:380px){.call-quality-stat{display:none}.call-quality-text{max-width:160px}}.call-output-extra{margin-top:.6rem;width:100%;display:flex;flex-direction:column;align-items:stretch;gap:.4rem;position:relative}.call-output-toggle{background:transparent;border:1px solid var(--border-subtle);border-radius:8px;color:var(--text-muted);font-size:.85rem;padding:.45rem .7rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem;cursor:pointer;transition:background .15s,color .15s}.call-output-toggle:hover{background:#ffffff0d;color:var(--text)}.call-output-chevron{font-size:.7rem;opacity:.65}.call-output-menu{list-style:none;margin:0;padding:.25rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:8px;box-shadow:var(--shadow-lg);max-height:180px;overflow-y:auto}.call-output-menu li{margin:0}.call-output-item{width:100%;text-align:left;background:transparent;border:none;color:var(--text);font-size:.85rem;padding:.45rem .55rem;border-radius:6px;cursor:pointer;transition:background .12s}.call-output-item:hover{background:#ffffff12}.call-output-item.selected{background:#2e9c5b2e;color:#9ee5b8}.msg-call-row{display:inline-flex;align-items:center;gap:.55rem;padding:.35rem .6rem;border-radius:10px;background:#ffffff0a;border:1px solid var(--border-subtle);font-size:.9rem;color:var(--text-muted)}.msg-call-row .msg-call-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:#2e9c5b2e;color:#9ee5b8;flex-shrink:0}.msg-call-row.missed .msg-call-icon{background:#e539352e;color:#ffb4b4}.msg-call-row .msg-call-text{display:flex;flex-direction:column;line-height:1.2}.msg-call-row .msg-call-title{color:var(--text);font-size:.92rem;font-weight:500}.msg-call-row .msg-call-sub{color:var(--text-dim);font-size:.78rem}.btn-call{background:transparent;border:none;color:var(--text-muted);width:38px;height:38px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.btn-call:hover{background:#2e9c5b24;color:#2ed47a}.btn-call:disabled{opacity:.4;cursor:not-allowed}.lic-banner{padding:.65rem 1rem;font-size:.92rem;text-align:center;border-bottom:1px solid var(--border-subtle);line-height:1.45}.lic-banner code{background:#00000040;padding:.05rem .4rem;border-radius:4px;font-size:.85rem}.lic-banner--warn{background:linear-gradient(180deg,#3a2a14,#2c1f0e);color:#f6cc8d}.lic-banner--err{background:linear-gradient(180deg,#3a1414,#2c0e0e);color:#ffb4b4}.lic-banner--err strong{color:#ff7a7a;letter-spacing:.02em}.app-root-stack{display:flex;flex-direction:column;height:100%;width:100%}.app-root-stack>.app-shell{flex:1;min-height:0}.admin-page{padding:24px;max-width:1100px;margin:0 auto;height:100%;overflow-y:auto;color:var(--text)}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.admin-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:18px 20px;margin-bottom:20px}.admin-card h2{font-size:17px;margin:0 0 14px}.admin-form{display:flex;flex-direction:column;gap:12px}.admin-form .field{display:flex;flex-direction:column;gap:4px}.admin-form .field label{font-size:.85rem;color:var(--text-muted)}.admin-form input[type=text],.admin-form input[type=number],.admin-form input:not([type]){background:var(--bg-input);border:1px solid var(--border-subtle);color:var(--text);padding:.55rem .7rem;border-radius:8px;font-size:.95rem;width:100%;max-width:340px}.admin-form .checkbox-row{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text)}.admin-form .link-btn{background:transparent;border:none;color:var(--accent);cursor:pointer;text-decoration:underline;font-size:.85rem;padding:0}.issued-box{background:#0c1218;border:1px dashed #3a5a7a;border-radius:10px;padding:14px;margin-top:18px}.issued-box h3{margin:0 0 8px;color:#9ee5b8;font-size:15px}.issued-box h4{margin:14px 0 6px;font-size:13px;color:var(--text-muted)}.issued-box pre{background:#000;color:#f6e58d;padding:10px;border-radius:6px;font-size:13px;white-space:pre-wrap;word-break:break-all;margin:0 0 8px}.issued-box .jwt-pre{color:#cfe;font-size:11px;line-height:1.4;max-height:120px;overflow-y:auto}.admin-table-wrap{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:.88rem}.admin-table th,.admin-table td{text-align:left;padding:10px 8px;border-bottom:1px solid var(--border-subtle);vertical-align:top}.admin-table th{color:var(--text-muted);font-weight:500;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}.admin-table tr.row-revoked{opacity:.55}.admin-table tr.row-expired{color:#ffb4b4}.admin-table .muted{color:var(--text-dim);font-size:.78rem}.status{display:inline-block;padding:.15rem .55rem;border-radius:999px;font-size:.78rem;font-weight:600}.status-active{background:#2e9c5b2e;color:#9ee5b8}.status-expired{background:#e5393529;color:#ffb4b4}.status-revoked{background:#7878782e;color:#aaa}.btn-primary{background:var(--accent);color:#fff;border:none;padding:.55rem 1.1rem;border-radius:8px;font-weight:600;align-self:flex-start}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.scope-chip{display:inline-block;padding:.1rem .5rem;border-radius:6px;font-size:.72rem;font-weight:600;margin-right:4px;background:#7878782e;color:#aaa}.scope-chip.scope-app{background:#2e78c838;color:#9ec9ff}.scope-chip.scope-docs{background:#b4782e38;color:#ffd9a3}.row-actions{white-space:nowrap;display:flex;gap:6px;flex-wrap:wrap}.admin-table tr.row-expand td{background:#0a1016;border-top:none}.expand-block{padding:8px 4px}.expand-block h4{margin:0 0 6px;font-size:13px;color:var(--text-muted)}.expand-block pre{background:#000;color:#f6e58d;padding:10px;border-radius:6px;font-size:12px;white-space:pre-wrap;word-break:break-all;margin:0 0 8px}.usb-progress{margin-top:10px;display:flex;flex-direction:column;gap:4px}.usb-progress-bar{position:relative;height:10px;background:#ffffff14;border-radius:6px;overflow:hidden}.usb-progress-fill{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,#3a7bd5,#00d2ff);transition:width .3s ease}.usb-progress small{color:var(--text-muted)}
