.pill-choice-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:radial-gradient(ellipse at center,#1a1a24,#0a0a0f)}.pill-choice-content{text-align:center;max-width:800px}.title{font-size:3.5rem;font-weight:200;letter-spacing:.5em;margin-bottom:.5rem;background:linear-gradient(135deg,#e4e4e7,#71717a);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.tagline{font-size:1.1rem;color:var(--text-secondary);margin-bottom:3rem;font-style:italic}.pills{display:flex;align-items:stretch;justify-content:center;gap:2rem;margin-bottom:2rem}.pill-divider{display:flex;align-items:center;color:var(--text-muted);font-size:.9rem}.pill{display:flex;flex-direction:column;align-items:center;padding:2.5rem 2rem;border-radius:16px;background:var(--bg-card);border:2px solid var(--border);min-width:240px;transition:all .3s ease;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.pill.disabled{opacity:.6;pointer-events:none}.pill:hover{transform:translateY(-4px)}.red-pill:hover,.red-pill.hovered{border-color:var(--red-pill);box-shadow:0 0 40px var(--red-pill-glow),0 0 80px var(--red-pill-glow)}.blue-pill:hover,.blue-pill.hovered{border-color:var(--blue-pill);box-shadow:0 0 40px var(--blue-pill-glow),0 0 80px var(--blue-pill-glow)}.pill-icon{font-size:3rem;margin-bottom:1rem;font-weight:700}.red-pill .pill-icon{color:var(--red-pill);text-shadow:0 0 20px var(--red-pill-glow)}.blue-pill .pill-icon{color:var(--blue-pill);text-shadow:0 0 20px var(--blue-pill-glow)}.pill-name{font-size:1.3rem;font-weight:600;letter-spacing:.1em;margin-bottom:.5rem}.red-pill .pill-name{color:var(--red-pill)}.blue-pill .pill-name{color:var(--blue-pill)}.pill-desc{color:var(--text-secondary);font-size:.95rem;margin-bottom:1.5rem}.pill-features{list-style:none;text-align:left;color:var(--text-muted);font-size:.85rem}.pill-features li{padding:.3rem 0}.pill-features li:before{content:">";margin-right:.5rem;opacity:.5}.switch-note{color:var(--text-muted);font-size:.85rem}@media (max-width: 640px){.pills{flex-direction:column}.pill-divider{padding:1rem 0}.title{font-size:2rem;letter-spacing:.3em}}.avatar{border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border:2px solid var(--border);flex-shrink:0}.avatar:hover{border-color:var(--accent)}.avatar img{width:100%;height:100%;object-fit:cover}.avatar-initial{font-weight:600;color:var(--text-secondary);text-transform:uppercase}.avatar-small{width:28px;height:28px;font-size:.75rem}.avatar-medium{width:40px;height:40px;font-size:1rem}.avatar-large{width:80px;height:80px;font-size:2rem}.notification-bell-container{position:relative}.notification-bell-btn{background:var(--bg-dark);border:1px solid var(--border);border-radius:8px;padding:.4rem .6rem;font-size:1rem;cursor:pointer;transition:all .2s;position:relative}.notification-bell-btn:hover{border-color:var(--accent)}.notification-bell-btn.has-unread{animation:bell-shake .5s ease-in-out}@keyframes bell-shake{0%,to{transform:rotate(0)}25%{transform:rotate(10deg)}75%{transform:rotate(-10deg)}}.bell-icon{font-size:1rem}.notification-badge{position:absolute;top:-4px;right:-4px;background:#f44336;color:#fff;font-size:.65rem;font-weight:600;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}.notification-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;width:320px;max-height:400px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 10px 40px #0000004d;overflow:hidden;z-index:1000}.notification-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--border)}.notification-header h3{margin:0;font-size:.9rem;font-weight:600;color:var(--text-primary)}.notification-actions{display:flex;gap:.5rem}.notification-action-btn{background:none;border:none;color:var(--accent);font-size:.75rem;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:all .2s}.notification-action-btn:hover{background:#8b5cf61a}.notification-action-btn.clear{color:var(--text-muted)}.notification-action-btn.clear:hover{color:#f44336;background:#f443361a}.notification-list{max-height:340px;overflow-y:auto}.notification-empty{padding:2rem;text-align:center;color:var(--text-muted)}.notification-item{display:flex;gap:.75rem;padding:.75rem 1rem;cursor:pointer;transition:background .2s;border-bottom:1px solid var(--border);position:relative}.notification-item:last-child{border-bottom:none}.notification-item:hover{background:#8b5cf60d}.notification-item.unread{background:#8b5cf614}.notification-item.unread:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent)}.notification-icon{font-size:1.25rem;flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-dark);border-radius:8px}.notification-content{flex:1;min-width:0}.notification-title{font-size:.85rem;font-weight:500;color:var(--text-primary);margin-bottom:.25rem}.notification-message{font-size:.8rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.25rem}.notification-time{font-size:.7rem;color:var(--text-muted)}.notification-delete-btn{background:none;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;padding:.25rem;opacity:0;transition:all .2s;flex-shrink:0}.notification-item:hover .notification-delete-btn{opacity:1}.notification-delete-btn:hover{color:#f44336}.notification-list::-webkit-scrollbar{width:6px}.notification-list::-webkit-scrollbar-track{background:transparent}.notification-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.notification-list::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:var(--bg-card);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.header-red{border-bottom-color:var(--red-pill)}.header-blue{border-bottom-color:var(--blue-pill)}.header-left{display:flex;align-items:center;gap:1.5rem}.header-title{font-size:1.2rem;font-weight:300;letter-spacing:.3em;color:var(--text-secondary)}.mode-toggle{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:20px;background:var(--bg-dark);border:1px solid var(--border);transition:all .2s}.mode-toggle.red{border-color:var(--red-pill);color:var(--red-pill)}.mode-toggle.blue{border-color:var(--blue-pill);color:var(--blue-pill)}.mode-toggle:hover{transform:scale(1.05)}.mode-indicator{font-weight:700;font-size:1.1rem}.mode-label{font-size:.75rem;font-weight:600;letter-spacing:.1em}.header-right{display:flex;align-items:center;gap:1rem}.new-article-btn{background:var(--accent);color:#fff;padding:.6rem 1.2rem;border-radius:8px;font-weight:500;font-size:.9rem;transition:all .2s}.new-article-btn:hover{background:#7c3aed;transform:translateY(-1px)}.header-identity{color:var(--text-muted);font-size:.8rem;padding:.4rem .8rem;background:var(--bg-dark);border-radius:4px}.header-profile-btn{display:flex;align-items:center;gap:.5rem;padding:.25rem .75rem .25rem .25rem;background:var(--bg-dark);border-radius:20px;border:1px solid var(--border);cursor:pointer;transition:all .2s}.header-profile-btn:hover{border-color:var(--accent)}.friends-btn{display:flex;align-items:center;gap:.4rem;background:var(--bg-dark);border:1px solid var(--border);border-radius:8px;padding:.4rem .6rem;font-size:.9rem;cursor:pointer;transition:all .2s}.friends-btn:hover{border-color:var(--accent)}.friends-icon{font-size:1rem}.friends-count{font-size:.75rem;font-weight:600;color:var(--accent);background:#8b5cf61a;padding:.1rem .35rem;border-radius:4px}.user-directory-btn{display:flex;align-items:center;background:var(--bg-dark);border:1px solid var(--border);border-radius:8px;padding:.4rem .6rem;font-size:.9rem;cursor:pointer;transition:all .2s}.user-directory-btn:hover{border-color:var(--accent)}.user-directory-icon{font-size:1rem}.theme-toggle-btn{background:var(--bg-dark);border:1px solid var(--border);border-radius:8px;padding:.4rem .6rem;font-size:1rem;cursor:pointer;transition:all .2s}.theme-toggle-btn:hover{border-color:var(--accent)}.account-settings-btn{background:var(--bg-dark);border:1px solid var(--border);border-radius:8px;padding:.4rem .6rem;font-size:1rem;cursor:pointer;transition:all .2s}.account-settings-btn:hover{border-color:var(--accent)}.header-profile{display:flex;align-items:center;gap:.5rem;padding:.25rem .75rem .25rem .25rem;background:var(--bg-dark);border-radius:20px;border:1px solid var(--border)}.header-profile-name{color:var(--text-secondary);font-size:.85rem;font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-profile.clickable{cursor:pointer;transition:all .2s}.header-profile.clickable:hover{border-color:var(--accent)}.header-karma{font-size:.75rem;font-weight:600;color:var(--accent);padding:.1rem .4rem;background:var(--bg-dark);border-radius:4px}.modules-btn{display:flex;align-items:center;gap:.4rem;background:var(--bg-dark);border:1px solid var(--border);border-radius:8px;padding:.4rem .6rem;font-size:.9rem;cursor:pointer;transition:all .2s}.modules-btn:hover{border-color:var(--accent)}.modules-icon{font-size:1rem}.modules-count{font-size:.75rem;font-weight:600;color:var(--text-secondary);background:#ffffff1a;padding:.1rem .35rem;border-radius:4px}.modules-running{font-size:.75rem;font-weight:600;color:var(--success, #00b894);background:#00b8941a;padding:.1rem .35rem;border-radius:4px}.clipboard-btn{display:flex;align-items:center;gap:.4rem;background:var(--bg-dark);border:1px solid var(--border);border-radius:8px;padding:.4rem .6rem;font-size:.9rem;cursor:pointer;transition:all .2s}.clipboard-btn:hover{border-color:var(--accent)}.clipboard-icon{font-size:1rem}.clipboard-count{font-size:.75rem;font-weight:600;color:var(--accent);background:#8b5cf61a;padding:.1rem .35rem;border-radius:4px}.messages-btn{display:flex;align-items:center;gap:.4rem;background:var(--bg-dark);border:1px solid var(--border);border-radius:8px;padding:.4rem .6rem;font-size:.9rem;cursor:pointer;transition:all .2s}.messages-btn:hover{border-color:var(--accent)}.messages-icon{font-size:1rem}.messages-count{font-size:.75rem;font-weight:600;color:#fff;background:var(--accent);padding:.1rem .4rem;border-radius:10px;min-width:1.1rem;text-align:center}.markdown-content{line-height:1.6;color:var(--text-primary, #e0e0e0)}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4,.markdown-content h5,.markdown-content h6{margin-top:1.5em;margin-bottom:.5em;font-weight:600;line-height:1.3;color:var(--text-primary, #fff)}.markdown-content h1{font-size:1.75em}.markdown-content h2{font-size:1.5em}.markdown-content h3{font-size:1.25em}.markdown-content h4{font-size:1.1em}.markdown-content h5{font-size:1em}.markdown-content h6{font-size:.9em}.markdown-content h1:first-child,.markdown-content h2:first-child,.markdown-content h3:first-child{margin-top:0}.markdown-content p{margin:.75em 0}.markdown-content p:first-child{margin-top:0}.markdown-content p:last-child{margin-bottom:0}.markdown-content a{color:var(--accent-color, #4a9eff);text-decoration:none}.markdown-content a:hover{text-decoration:underline}.markdown-content .unsafe-link{color:var(--text-secondary, #888);text-decoration:line-through}.markdown-content ul,.markdown-content ol{margin:.75em 0;padding-left:1.5em}.markdown-content li,.markdown-content ul ul,.markdown-content ol ol,.markdown-content ul ol,.markdown-content ol ul{margin:.25em 0}.markdown-content input[type=checkbox]{margin-right:.5em}.markdown-content blockquote{margin:.75em 0;padding:.5em 1em;border-left:3px solid var(--accent-color, #4a9eff);background:var(--bg-secondary, rgba(255, 255, 255, .05));color:var(--text-secondary, #aaa)}.markdown-content blockquote p{margin:0}.markdown-content .inline-code{padding:.15em .4em;font-family:Fira Code,Consolas,monospace;font-size:.9em;background:var(--bg-tertiary, rgba(255, 255, 255, .1));border-radius:3px}.markdown-content .code-block{position:relative;margin:1em 0;border-radius:6px;overflow:hidden}.markdown-content .code-language{position:absolute;top:0;right:0;padding:.25em .5em;font-size:.75em;color:var(--text-tertiary, #666);background:var(--bg-tertiary, rgba(0, 0, 0, .3));border-bottom-left-radius:4px}.markdown-content pre{margin:0;padding:1em;background:var(--bg-tertiary, #1a1a1a);overflow-x:auto}.markdown-content pre code{font-family:Fira Code,Consolas,monospace;font-size:.875em;line-height:1.5;color:var(--text-primary, #e0e0e0)}.markdown-content table{width:100%;margin:1em 0;border-collapse:collapse}.markdown-content th,.markdown-content td{padding:.5em .75em;border:1px solid var(--border-color, #333);text-align:left}.markdown-content th{background:var(--bg-secondary, rgba(255, 255, 255, .05));font-weight:600}.markdown-content tr:nth-child(2n){background:var(--bg-secondary, rgba(255, 255, 255, .02))}.markdown-content hr{margin:1.5em 0;border:none;border-top:1px solid var(--border-color, #333)}.markdown-content img{max-width:100%;height:auto;border-radius:4px}.markdown-content del{color:var(--text-secondary, #888)}.markdown-content strong{font-weight:600;color:var(--text-primary, #fff)}.markdown-content em{font-style:italic}.markdown-content .truncated{color:var(--text-secondary, #888);font-style:italic}.markdown-content.inline{display:inline}.markdown-content.inline .inline-code{padding:.1em .3em}.article-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.5rem;margin-bottom:1rem;transition:border-color .2s}.article-card:hover{border-color:var(--text-muted)}.headline{display:flex;justify-content:space-between;align-items:center;padding:.35rem .75rem;cursor:pointer;border-bottom:1px solid var(--border)}.headline:last-child{border-bottom:none}.headline:hover{background:#8b5cf60d}.headline-title{font-size:.9rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.headline-meta{font-size:.7rem;color:var(--text-muted);white-space:nowrap;margin-left:.75rem;flex-shrink:0}.headline-votes{margin-left:.4rem;color:var(--accent)}.headline-reply{padding-left:1rem;background:#00000005}.headline-reply .headline-title{font-size:.85rem;color:var(--text-secondary)}.article-card.dev-mode{border-left:3px solid var(--red-pill)}.article-card.clean-mode{border-left:3px solid var(--blue-pill)}.article-card.is-reply{border-left-width:2px;opacity:.95}.reply-indicator,.reply-indicator-collapsed{font-size:.8rem;color:var(--text-muted);margin-bottom:.5rem}.reply-indicator-collapsed{margin-bottom:.25rem}.reply-btn{color:var(--accent)!important}.article-header{margin-bottom:1rem}.article-header-top{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.collapse-btn{background:var(--bg-dark);color:var(--text-muted);width:28px;height:28px;border-radius:4px;border:1px solid var(--border);font-size:.9rem;flex-shrink:0;transition:all .2s}.collapse-btn:hover{color:var(--accent);border-color:var(--accent)}.article-title{font-size:1.25rem;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}.article-tags{display:flex;flex-wrap:wrap;gap:.5rem}.tag{font-size:.8rem;color:var(--accent);background:#8b5cf61a;padding:.2rem .6rem;border-radius:4px}.article-body{color:var(--text-secondary);line-height:1.7;white-space:pre-wrap;margin-bottom:1rem}.expand-btn{background:none;color:var(--accent);font-size:.9rem;margin-left:.5rem}.expand-btn:hover{text-decoration:underline}.expand-collapse-btn{background:none;color:var(--text-muted);font-size:.8rem;padding:.25rem .5rem;flex-shrink:0;transition:color .2s}.expand-collapse-btn:hover{color:var(--accent)}.expand-collapse-btn.collapse{position:absolute;top:1rem;right:1rem}.article-header{position:relative}.article-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid var(--border)}.article-meta{display:flex;gap:1rem;color:var(--text-muted);font-size:.85rem}.meta-item.creator{color:var(--text-secondary)}.meta-item.creator.clickable{cursor:pointer;transition:color .2s}.meta-item.creator.clickable:hover{color:var(--accent)}.author-link{color:var(--text-secondary)}.author-link.clickable{cursor:pointer;transition:color .2s}.author-link.clickable:hover{color:var(--accent)}.article-actions{display:flex;gap:.5rem}.action-btn{background:none;color:var(--text-muted);font-size:.85rem;padding:.3rem .6rem;border-radius:4px;transition:all .2s}.action-btn:hover{color:var(--accent);background:#8b5cf61a}.delete-btn{color:var(--text-muted)!important}.delete-btn:hover{color:#f44336!important;background:#f443361a!important}.article-votes{display:flex;align-items:center;gap:.5rem}.vote-btn{background:var(--bg-dark);color:var(--text-secondary);padding:.4rem .8rem;border-radius:6px;font-size:.85rem;border:1px solid var(--border);transition:all .2s}.vote-btn:hover{border-color:var(--text-muted)}.vote-btn.upvote:hover{color:#22c55e;border-color:#22c55e}.vote-btn.downvote:hover{color:#ef4444;border-color:#ef4444}.vote-total{font-weight:600;color:var(--text-primary);min-width:2rem;text-align:center}.article-debug{margin-top:1rem;padding-top:1rem;border-top:1px dashed var(--border)}.debug-row{display:flex;gap:.5rem;margin-bottom:.3rem;font-size:.75rem}.debug-label{color:var(--text-muted);min-width:3rem}.debug-value{color:var(--red-pill);word-break:break-all;opacity:.8}.feed{max-width:800px;margin:0 auto;padding:1rem}.feed-stats{display:flex;gap:2rem;padding:1rem;margin-bottom:1rem;background:#dc26260d;border:1px solid rgba(220,38,38,.2);border-radius:8px}.stat{display:flex;align-items:baseline;gap:.5rem}.stat-value{font-size:1.1rem;font-weight:600;color:var(--red-pill)}.stat-label{font-size:.85rem;color:var(--text-muted)}.feed-empty{text-align:center;padding:4rem 2rem;color:var(--text-muted)}.feed-empty p:first-child{font-size:1.2rem;color:var(--text-secondary);margin-bottom:.5rem}.feed-empty-hint{font-size:.9rem}.feed-articles{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;overflow:hidden}.composer{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.composer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.composer-header h3{font-size:1.1rem;font-weight:500}.composer-cancel{background:transparent;color:var(--text-muted);padding:.5rem 1rem;border-radius:6px;font-size:.9rem}.composer-cancel:hover{color:var(--text-primary);background:var(--border)}.composer-title{width:100%;font-size:1.2rem;font-weight:500;margin-bottom:1rem}.composer-body{width:100%;resize:vertical;min-height:150px;margin-bottom:1rem;line-height:1.6}.composer-tags{width:100%;margin-bottom:1rem;font-size:.9rem}.composer-footer{display:flex;justify-content:space-between;align-items:center}.composer-author{color:var(--text-muted);font-size:.85rem}.composer-publish{background:var(--accent);color:#fff;padding:.75rem 1.5rem;border-radius:8px;font-weight:500;transition:all .2s}.composer-publish:hover:not(:disabled){background:#7c3aed;transform:translateY(-1px)}.composer-publish:disabled{opacity:.5;cursor:not-allowed}.composer-reply-to{background:var(--bg-dark);border:1px solid var(--border);border-radius:6px;padding:.75rem 1rem;margin-bottom:1rem;font-size:.9rem;color:var(--text-secondary)}.composer-reply-to strong{color:var(--text-primary)}.peer-status{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;margin-bottom:1rem}.peer-status-header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;cursor:pointer}.peer-status-header:hover{background:#ffffff05}.peer-status-minimal{display:flex;align-items:center;gap:.5rem;padding:.5rem 0;color:var(--text-muted);font-size:.85rem}.status-dot{width:10px;height:10px;border-radius:50%;background:var(--text-muted);flex-shrink:0}.status-dot.mesh-healthy{background:#22c55e;box-shadow:0 0 8px #22c55e80;animation:pulse-green 2s ease-in-out infinite}.status-dot.mesh-limited{background:#eab308;box-shadow:0 0 8px #eab30880}.status-dot.mesh-offline{background:#71717a}.status-dot.connected{background:#22c55e;box-shadow:0 0 8px #22c55e80}.status-dot.disconnected{background:#71717a}@keyframes pulse-green{0%,to{opacity:1}50%{opacity:.7}}.peer-count{color:var(--text-secondary);font-size:.9rem}.refresh-btn{margin-left:auto;background:var(--bg-dark);color:var(--text-secondary);padding:.3rem .6rem;border-radius:4px;font-size:.75rem;border:1px solid var(--border)}.refresh-btn:hover{color:var(--text-primary);border-color:var(--text-muted)}.expand-icon{color:var(--text-muted);font-size:1.2rem;width:1.5rem;text-align:center}.mesh-badge{padding:.2rem .5rem;border-radius:4px;font-size:.65rem;font-weight:600;letter-spacing:.05em}.mesh-badge-healthy{background:#22c55e26;color:#22c55e}.mesh-badge-limited{background:#eab30826;color:#eab308}.mesh-badge-offline{background:#71717a26;color:#71717a}.p2p-badge{background:#22c55e26;color:#22c55e;padding:.2rem .5rem;border-radius:4px;font-size:.65rem;font-weight:600;letter-spacing:.05em}.peer-list{border-top:1px solid var(--border);padding:.5rem}.no-peers{padding:1rem;text-align:center;color:var(--text-muted);font-size:.85rem}.peer-item{display:flex;align-items:center;gap:.75rem;padding:.5rem;border-radius:4px}.peer-item:hover{background:#ffffff05}.peer-id{color:var(--text-secondary);font-size:.8rem}.peer-state{font-size:.7rem;padding:.2rem .4rem;border-radius:3px;text-transform:uppercase}.peer-state.discovered{background:#8b5cf633;color:var(--accent)}.peer-state.connecting{background:#eab30833;color:#eab308}.peer-state.connected{background:#22c55e33;color:#22c55e}.peer-state.disconnected{background:#71717a33;color:var(--text-muted)}.connect-btn,.disconnect-btn{margin-left:auto;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;border:1px solid var(--border)}.connect-btn{background:#22c55e1a;color:#22c55e;border-color:#22c55e4d}.connect-btn:hover{background:#22c55e33}.disconnect-btn{background:#ef44441a;color:#ef4444;border-color:#ef44444d}.disconnect-btn:hover{background:#ef444433}.profile-setup-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:radial-gradient(ellipse at center,#1a1a24,#0a0a0f)}.profile-setup-content{text-align:center;max-width:400px;width:100%}.profile-setup-title{font-size:2rem;font-weight:300;letter-spacing:.1em;margin-bottom:.5rem;color:var(--text-primary)}.profile-setup-tagline{font-size:1rem;color:var(--text-secondary);margin-bottom:2rem}.avatar-section{display:flex;flex-direction:column;align-items:center;margin-bottom:2rem}.avatar-picker{width:100px;height:100px;border-radius:50%;border:3px dashed var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;transition:all .3s ease;background:var(--bg-card)}.avatar-picker:hover{border-color:var(--accent);border-style:solid}.avatar-preview-img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{display:flex;flex-direction:column;align-items:center;gap:.25rem}.avatar-placeholder-icon{font-size:2rem;color:var(--text-muted)}.avatar-placeholder-text{font-size:.75rem;color:var(--text-muted)}.avatar-hint{margin-top:.5rem;font-size:.75rem;color:var(--text-muted)}.avatar-error{margin-top:.5rem;font-size:.75rem;color:var(--red-pill)}.profile-form{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.profile-input{width:100%;background:var(--bg-card);border:2px solid var(--border);border-radius:8px;padding:.875rem 1rem;color:var(--text-primary);font-size:1rem;transition:border-color .2s}.profile-input::placeholder{color:var(--text-muted)}.profile-actions{display:flex;gap:1rem;justify-content:center}.skip-btn{padding:.875rem 1.5rem;border-radius:8px;background:transparent;border:2px solid var(--border);color:var(--text-secondary);font-size:1rem;transition:all .2s;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.skip-btn:hover:not(:disabled){border-color:var(--text-muted);color:var(--text-primary)}.skip-btn:disabled{opacity:.5;cursor:not-allowed}.save-btn{padding:.875rem 2rem;border-radius:8px;background:var(--accent);border:none;color:#fff;font-size:1rem;font-weight:500;transition:all .2s;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.save-btn:hover:not(:disabled){background:#9d7df8;transform:translateY(-1px)}.save-btn:disabled{opacity:.5;cursor:not-allowed}.profile-note{margin-top:1.5rem;font-size:.85rem;color:var(--text-muted)}@media (max-width: 480px){.profile-setup-title{font-size:1.5rem}.profile-actions{flex-direction:column}.skip-btn,.save-btn{width:100%}}.profile-editor-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.profile-editor-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;width:100%;max-width:400px;max-height:90vh;overflow-y:auto}.profile-editor-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border)}.profile-editor-header h2{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.close-btn{background:none;color:var(--text-muted);font-size:1.2rem;width:32px;height:32px;border-radius:50%;transition:all .2s}.close-btn:hover{background:var(--bg-dark);color:var(--text-primary)}.profile-editor-content{padding:1.5rem}.avatar-edit-section{display:flex;flex-direction:column;align-items:center;margin-bottom:1.5rem}.avatar-edit-picker{position:relative;cursor:pointer}.avatar-edit-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0009;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.85rem;font-weight:500;opacity:0;transition:opacity .2s}.avatar-edit-picker:hover .avatar-edit-overlay{opacity:1}.avatar-error{margin-top:.5rem;font-size:.8rem;color:var(--red-pill)}.profile-edit-form{display:flex;flex-direction:column;gap:1rem}.form-label{display:flex;flex-direction:column;gap:.5rem;font-size:.85rem;color:var(--text-secondary)}.profile-input{width:100%;background:var(--bg-dark);border:1px solid var(--border);border-radius:8px;padding:.75rem;color:var(--text-primary);font-size:1rem}.profile-input:focus{outline:none;border-color:var(--accent)}.bio-input{resize:vertical;min-height:80px}.profile-editor-actions{display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.5rem;border-top:1px solid var(--border)}.cancel-btn{padding:.6rem 1.2rem;border-radius:6px;background:transparent;border:1px solid var(--border);color:var(--text-secondary);font-size:.9rem;transition:all .2s}.cancel-btn:hover:not(:disabled){border-color:var(--text-muted);color:var(--text-primary)}.save-btn{padding:.6rem 1.2rem;border-radius:6px;background:var(--accent);border:none;color:#fff;font-size:.9rem;font-weight:500;transition:all .2s}.save-btn:hover:not(:disabled){background:#7c3aed}.save-btn:disabled,.cancel-btn:disabled{opacity:.5;cursor:not-allowed}.profile-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.profile-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;width:100%;max-width:360px;max-height:90vh;overflow-y:auto;position:relative;padding:1.5rem}.modal-close-btn{position:absolute;top:1rem;right:1rem;background:none;color:var(--text-muted);font-size:1.2rem;width:32px;height:32px;border-radius:50%;transition:all .2s}.modal-close-btn:hover{background:var(--bg-dark);color:var(--text-primary)}.profile-modal-header{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:1rem}.profile-modal-name{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-top:.75rem;margin-bottom:.5rem}.profile-modal-stats{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary)}.stat-item{color:var(--text-secondary)}.stat-divider{color:var(--text-muted)}.profile-modal-bio{text-align:center;color:var(--text-secondary);font-size:.95rem;line-height:1.5;margin-bottom:1rem;padding:0 .5rem}.profile-modal-activity{display:flex;justify-content:center;gap:1.5rem;font-size:.85rem;color:var(--text-muted);margin-bottom:1rem}.profile-modal-actions{display:flex;gap:.75rem;justify-content:center;margin-bottom:1rem}.action-btn{padding:.5rem 1rem;border-radius:6px;font-size:.85rem;font-weight:500;transition:all .2s}.friend-btn{background:var(--accent);color:#fff;border:none}.friend-btn:hover{background:#7c3aed}.friend-btn.active{background:var(--bg-dark);border:1px solid var(--accent);color:var(--accent)}.block-btn{background:transparent;border:1px solid var(--border);color:var(--text-muted)}.block-btn:hover{border-color:var(--red-pill);color:var(--red-pill)}.block-btn.active{background:#dc26261a;border-color:var(--red-pill);color:var(--red-pill)}.profile-modal-posts{border-top:1px solid var(--border);padding-top:1rem;margin-bottom:1rem}.profile-modal-posts h3{font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-bottom:.75rem}.recent-posts-list{list-style:none}.recent-post-item{padding:.5rem 0;font-size:.9rem;color:var(--text-primary);border-bottom:1px solid var(--border);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-post-item:last-child{border-bottom:none}.profile-modal-pubkey{text-align:center;padding-top:1rem;border-top:1px solid var(--border)}.profile-modal-pubkey .mono{font-size:.75rem;color:var(--text-muted)}.friends-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.friends-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;width:100%;max-width:400px;max-height:80vh;overflow-y:auto;position:relative;padding:1.5rem}.friends-modal .modal-close-btn{position:absolute;top:1rem;right:1rem;background:none;color:var(--text-muted);font-size:1.5rem;width:32px;height:32px;border-radius:50%;transition:all .2s;display:flex;align-items:center;justify-content:center}.friends-modal .modal-close-btn:hover{background:var(--bg-dark);color:var(--text-primary)}.friends-modal-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:1.5rem;text-align:center}.friends-section,.blocked-section{margin-bottom:1.5rem}.section-title{font-size:.9rem;font-weight:600;color:var(--text-secondary);margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.75rem}.online-count{font-size:.75rem;font-weight:500;color:#22c55e;background:#22c55e1a;padding:.15rem .5rem;border-radius:10px}.empty-message{color:var(--text-muted);font-size:.85rem;padding:.5rem 0}.user-list{list-style:none}.user-item{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--border)}.user-item:last-child{border-bottom:none}.user-info{display:flex;align-items:center;gap:.75rem;background:none;border:none;cursor:pointer;padding:.25rem;border-radius:6px;transition:background .2s}button.user-info:hover{background:var(--bg-dark)}.user-item.is-online .user-name{color:var(--text-primary)}.user-name{color:var(--text-primary);font-size:.9rem;font-weight:500}.user-name.blocked{color:var(--text-muted);text-decoration:line-through}.action-btn{padding:.35rem .75rem;border-radius:6px;font-size:.8rem;font-weight:500;transition:all .2s}.remove-btn{background:transparent;border:1px solid var(--border);color:var(--text-muted)}.remove-btn:hover{border-color:var(--text-secondary);color:var(--text-secondary)}.unblock-btn{background:var(--accent);border:none;color:#fff}.unblock-btn:hover{background:#7c3aed}.permission-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.permission-modal{background:var(--bg-primary, #1a1a2e);border-radius:12px;width:100%;max-width:500px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0006;border:1px solid var(--border-color, #333)}.permission-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color, #333)}.permission-modal-header h2{margin:0;font-size:1.25rem;color:var(--text-primary, #fff)}.permission-modal-header .close-btn{background:none;border:none;color:var(--text-secondary, #888);font-size:1.5rem;cursor:pointer;padding:0;line-height:1}.permission-modal-header .close-btn:hover{color:var(--text-primary, #fff)}.permission-modal-body{flex:1;overflow-y:auto;padding:1.5rem}.module-info{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color, #333)}.module-name{font-size:1.5rem;font-weight:600;color:var(--text-primary, #fff);margin-bottom:.5rem}.module-meta{display:flex;gap:.75rem;margin-bottom:.75rem}.module-id{font-family:monospace;font-size:.85rem;color:var(--accent-color, #6c5ce7);background:var(--bg-secondary, #252542);padding:.25rem .5rem;border-radius:4px}.module-version{font-size:.85rem;color:var(--text-secondary, #888)}.module-description{color:var(--text-secondary, #aaa);font-size:.95rem;line-height:1.5;margin-bottom:.75rem}.module-author{font-size:.85rem;color:var(--text-secondary, #888)}.author-key{font-family:monospace;color:var(--text-primary, #fff)}.module-signers{font-size:.85rem;color:var(--success-color, #00b894);margin-top:.5rem}.permissions-container h3{font-size:1rem;color:var(--text-primary, #fff);margin:0 0 1rem}.permission-section{margin-bottom:1rem;border-radius:8px;overflow:hidden}.section-header{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;font-weight:500}.section-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem}.permission-section.safe{background:#00b8941a;border:1px solid rgba(0,184,148,.3)}.permission-section.safe .section-header{color:var(--success-color, #00b894)}.permission-section.safe .section-icon{background:var(--success-color, #00b894);color:#fff}.permission-section.prompt{background:#fdcb6e1a;border:1px solid rgba(253,203,110,.3)}.permission-section.prompt .section-header{color:var(--warning-color, #fdcb6e)}.permission-section.prompt .section-icon{background:var(--warning-color, #fdcb6e);color:#000}.permission-section.dangerous{background:#d630311a;border:1px solid rgba(214,48,49,.3)}.permission-section.dangerous .section-header{color:var(--error-color, #d63031)}.permission-section.dangerous .section-icon{background:var(--error-color, #d63031);color:#fff}.danger-warning{padding:.75rem 1rem;font-size:.85rem;color:var(--error-color, #d63031);background:#d630311a;border-top:1px solid rgba(214,48,49,.2)}.permission-section.unknown{background:#636e721a;border:1px solid rgba(99,110,114,.3)}.permission-section.unknown .section-header{color:var(--text-secondary, #636e72)}.permission-section.unknown .section-icon{background:var(--text-secondary, #636e72);color:#fff}.unknown-warning{padding:.75rem 1rem;font-size:.85rem;color:var(--text-secondary, #636e72)}.permission-list{list-style:none;margin:0;padding:0}.permission-list.disabled{opacity:.6}.permission-item{padding:.5rem 1rem;border-top:1px solid rgba(255,255,255,.05)}.permission-item:first-child{border-top:none}.permission-item label{display:flex;align-items:flex-start;gap:.75rem;cursor:pointer}.permission-item input[type=checkbox]{margin-top:.25rem;accent-color:var(--accent-color, #6c5ce7)}.permission-name{font-family:monospace;font-size:.9rem;color:var(--text-primary, #fff);white-space:nowrap}.permission-desc{font-size:.85rem;color:var(--text-secondary, #888);margin-left:auto;text-align:right;flex-shrink:1}.permission-modal-footer{display:flex;gap:1rem;padding:1rem 1.5rem;border-top:1px solid var(--border-color, #333);justify-content:flex-end}.permission-modal-footer button{padding:.75rem 1.5rem;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-deny{background:var(--bg-secondary, #252542);border:1px solid var(--border-color, #333);color:var(--text-primary, #fff)}.btn-deny:hover{background:var(--bg-tertiary, #2a2a4a)}.btn-approve{background:var(--accent-color, #6c5ce7);border:none;color:#fff}.btn-approve:hover:not(:disabled){background:var(--accent-hover, #5b4cdb)}.btn-approve:disabled{opacity:.5;cursor:not-allowed}.btn-approve.has-dangerous{background:var(--warning-color, #fdcb6e);color:#000}.btn-approve.has-dangerous:hover:not(:disabled){background:#f0b849}[data-theme=light] .permission-modal{background:#fff;border-color:#e0e0e0}[data-theme=light] .permission-modal-header{border-color:#e0e0e0}[data-theme=light] .permission-modal-header h2{color:#1a1a2e}[data-theme=light] .module-info{border-color:#e0e0e0}[data-theme=light] .module-name{color:#1a1a2e}[data-theme=light] .module-id{background:#f0f0f5}[data-theme=light] .permission-item label,[data-theme=light] .permission-name{color:#1a1a2e}[data-theme=light] .permission-modal-footer{border-color:#e0e0e0}[data-theme=light] .btn-deny{background:#f0f0f5;border-color:#e0e0e0;color:#1a1a2e}[data-theme=light] .btn-deny:hover{background:#e0e0e5}.module-host-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.module-host{background:var(--bg-primary, #1a1a2e);border-radius:12px;width:100%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0006;border:1px solid var(--border-color, #333)}.module-host-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color, #333)}.module-host-header h2{margin:0;font-size:1.25rem;color:var(--text-primary, #fff)}.module-host-header .close-btn{background:none;border:none;color:var(--text-secondary, #888);font-size:1.5rem;cursor:pointer;padding:0;line-height:1}.module-host-header .close-btn:hover{color:var(--text-primary, #fff)}.module-host-tabs{display:flex;border-bottom:1px solid var(--border-color, #333)}.module-host-tabs .tab{flex:1;padding:.75rem 1rem;background:none;border:none;color:var(--text-secondary, #888);font-size:.95rem;cursor:pointer;transition:all .2s;border-bottom:2px solid transparent}.module-host-tabs .tab:hover{color:var(--text-primary, #fff);background:var(--bg-secondary, #252542)}.module-host-tabs .tab.active{color:var(--accent-color, #6c5ce7);border-bottom-color:var(--accent-color, #6c5ce7)}.module-host-content{flex:1;overflow-y:auto;padding:1rem}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center}.empty-icon{font-size:3rem;margin-bottom:1rem}.empty-text{font-size:1.1rem;color:var(--text-primary, #fff);margin-bottom:.5rem}.empty-hint{font-size:.9rem;color:var(--text-secondary, #888)}.module-list{display:flex;flex-direction:column;gap:.75rem}.module-card{background:var(--bg-secondary, #252542);border-radius:8px;border:1px solid var(--border-color, #333);overflow:hidden;transition:border-color .2s}.module-card.running{border-color:var(--success-color, #00b894)}.module-card-header{display:flex;align-items:center;padding:1rem;cursor:pointer;transition:background .2s}.module-card-header:hover{background:var(--bg-tertiary, #2a2a4a)}.module-card-info{flex:1}.module-card-name{font-size:1rem;font-weight:500;color:var(--text-primary, #fff);display:flex;align-items:center;gap:.5rem}.running-badge{font-size:.7rem;padding:.2rem .5rem;border-radius:4px;background:var(--success-color, #00b894);color:#fff;font-weight:600;text-transform:uppercase}.module-card-meta{display:flex;gap:.75rem;margin-top:.25rem}.module-card-id{font-family:monospace;font-size:.8rem;color:var(--text-secondary, #888)}.module-card-version{font-size:.8rem;color:var(--text-secondary, #888)}.expand-btn{background:none;border:none;color:var(--text-secondary, #888);font-size:.75rem;cursor:pointer;padding:.5rem}.module-card-details{padding:0 1rem 1rem;border-top:1px solid var(--border-color, #333)}.detail-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.05)}.detail-row:last-of-type{border-bottom:none}.detail-label{font-size:.85rem;color:var(--text-secondary, #888)}.detail-value{font-size:.85rem;color:var(--text-primary, #fff)}.detail-value.mono{font-family:monospace}.permissions-preview{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-color, #333)}.permission-tag{font-size:.75rem;font-family:monospace;padding:.25rem .5rem;border-radius:4px;background:var(--bg-tertiary, #2a2a4a);color:var(--text-secondary, #888)}.module-card-actions{display:flex;gap:.75rem;margin-top:1rem}.module-card-actions button{flex:1;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s}.btn-run{background:var(--accent-color, #6c5ce7);border:none;color:#fff}.btn-run:hover{background:var(--accent-hover, #5b4cdb)}.btn-stop{background:var(--warning-color, #fdcb6e);border:none;color:#000}.btn-stop:hover{background:#f0b849}.btn-uninstall{background:var(--bg-tertiary, #2a2a4a);border:1px solid var(--border-color, #333);color:var(--text-secondary, #888)}.btn-uninstall:hover{border-color:var(--error-color, #d63031);color:var(--error-color, #d63031)}.btn-uninstall.confirm{background:var(--error-color, #d63031);border-color:var(--error-color, #d63031);color:#fff}.running-module-card{background:var(--bg-secondary, #252542);border-radius:8px;border:1px solid var(--success-color, #00b894);overflow:hidden}.running-module-header{display:flex;align-items:center;padding:.75rem 1rem;gap:.75rem;background:#00b8941a}.running-indicator{width:10px;height:10px;border-radius:50%;background:var(--success-color, #00b894);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.running-module-info{flex:1}.running-module-name{font-size:.95rem;font-weight:500;color:var(--text-primary, #fff)}.running-module-id{font-family:monospace;font-size:.8rem;color:var(--text-secondary, #888)}.btn-stop-small{padding:.4rem .75rem;border-radius:4px;font-size:.8rem;background:var(--warning-color, #fdcb6e);border:none;color:#000;cursor:pointer}.btn-stop-small:hover{background:#f0b849}.running-module-output{padding:1rem;min-height:100px;background:var(--bg-primary, #1a1a2e)}.output-placeholder{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-secondary, #666);font-size:.9rem;font-style:italic}[data-theme=light] .module-host{background:#fff;border-color:#e0e0e0}[data-theme=light] .module-host-header{border-color:#e0e0e0}[data-theme=light] .module-host-header h2{color:#1a1a2e}[data-theme=light] .module-host-tabs{border-color:#e0e0e0}[data-theme=light] .module-host-tabs .tab:hover{background:#f5f5f5}[data-theme=light] .empty-text{color:#1a1a2e}[data-theme=light] .module-card{background:#f5f5f5;border-color:#e0e0e0}[data-theme=light] .module-card-header:hover{background:#eee}[data-theme=light] .module-card-name{color:#1a1a2e}[data-theme=light] .module-card-details{border-color:#e0e0e0}[data-theme=light] .detail-value{color:#1a1a2e}[data-theme=light] .permissions-preview{border-color:#e0e0e0}[data-theme=light] .permission-tag{background:#e0e0e0;color:#666}[data-theme=light] .btn-uninstall{background:#f5f5f5;border-color:#e0e0e0}[data-theme=light] .running-module-card{background:#f5f5f5}[data-theme=light] .running-module-output{background:#fff}[data-theme=light] .running-module-name{color:#1a1a2e}.module-installer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.module-installer{background:var(--bg-primary, #1a1a2e);border-radius:12px;width:100%;max-width:450px;box-shadow:0 20px 60px #0006;border:1px solid var(--border-color, #333)}.module-installer-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color, #333)}.module-installer-header h2{margin:0;font-size:1.25rem;color:var(--text-primary, #fff)}.module-installer-header .close-btn{background:none;border:none;color:var(--text-secondary, #888);font-size:1.5rem;cursor:pointer;padding:0;line-height:1}.module-installer-header .close-btn:hover:not(:disabled){color:var(--text-primary, #fff)}.module-installer-header .close-btn:disabled{opacity:.5;cursor:not-allowed}.module-installer-body{padding:1.5rem}.input-group{margin-bottom:1.5rem}.input-group label{display:block;font-size:.9rem;color:var(--text-primary, #fff);margin-bottom:.5rem;font-weight:500}.input-group input{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color, #333);border-radius:8px;background:var(--bg-secondary, #252542);color:var(--text-primary, #fff);font-size:.95rem;font-family:monospace;transition:border-color .2s}.input-group input:focus{outline:none;border-color:var(--accent-color, #6c5ce7)}.input-group input:disabled{opacity:.7;cursor:not-allowed}.input-group input::placeholder{color:var(--text-secondary, #666);font-family:monospace}.input-hint{margin-top:.5rem;font-size:.8rem;color:var(--text-secondary, #888)}.error-message,.success-message{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.error-message{background:#d630311a;border:1px solid rgba(214,48,49,.3);color:var(--error-color, #d63031)}.error-icon{flex-shrink:0}.error-text{white-space:pre-wrap;word-break:break-word}.success-message{background:#00b8941a;border:1px solid rgba(0,184,148,.3);color:var(--success-color, #00b894)}.success-icon{flex-shrink:0}.module-installer-actions{display:flex;gap:1rem}.module-installer-actions button{flex:1;padding:.75rem 1rem;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-cancel{background:var(--bg-secondary, #252542);border:1px solid var(--border-color, #333);color:var(--text-primary, #fff)}.btn-cancel:hover:not(:disabled){background:var(--bg-tertiary, #2a2a4a)}.btn-cancel:disabled{opacity:.5;cursor:not-allowed}.btn-install{background:var(--accent-color, #6c5ce7);border:none;color:#fff}.btn-install:hover:not(:disabled){background:var(--accent-hover, #5b4cdb)}.btn-install:disabled{opacity:.5;cursor:not-allowed}.module-installer-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-color, #333);background:var(--bg-secondary, #252542);border-radius:0 0 12px 12px}.security-note{display:flex;align-items:flex-start;gap:.75rem;font-size:.8rem;color:var(--text-secondary, #888)}.security-icon{flex-shrink:0}[data-theme=light] .module-installer{background:#fff;border-color:#e0e0e0}[data-theme=light] .module-installer-header{border-color:#e0e0e0}[data-theme=light] .module-installer-header h2,[data-theme=light] .input-group label{color:#1a1a2e}[data-theme=light] .input-group input{background:#f5f5f5;border-color:#e0e0e0;color:#1a1a2e}[data-theme=light] .input-group input::placeholder{color:#999}[data-theme=light] .btn-cancel{background:#f5f5f5;border-color:#e0e0e0;color:#1a1a2e}[data-theme=light] .btn-cancel:hover:not(:disabled){background:#eee}[data-theme=light] .module-installer-footer{background:#f5f5f5;border-color:#e0e0e0}.file-uploader{width:100%}.drop-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;border:2px dashed var(--border-color, #444);border-radius:8px;background:var(--bg-secondary, #1a1a1a);cursor:pointer;transition:all .2s ease;min-height:150px}.drop-zone:hover{border-color:var(--accent-color, #4a9eff);background:var(--bg-hover, #252525)}.drop-zone.drag-over{border-color:var(--accent-color, #4a9eff);background:var(--accent-bg, rgba(74, 158, 255, .1));transform:scale(1.02)}.drop-zone.success{border-color:var(--success-color, #4caf50);background:#4caf501a}.drop-zone.error{border-color:var(--error-color, #f44336);background:#f443361a}.drop-icon,.progress-icon,.success-icon,.error-icon{font-size:2.5rem;margin-bottom:.5rem}.success-icon{color:var(--success-color, #4caf50)}.error-icon{color:var(--error-color, #f44336)}.drop-text{display:flex;flex-direction:column;align-items:center;gap:.25rem;margin-bottom:.5rem}.drop-text strong{font-size:1rem;color:var(--text-primary, #fff)}.drop-text span{font-size:.875rem;color:var(--text-secondary, #888)}.drop-hint{font-size:.75rem;color:var(--text-tertiary, #666)}.progress-text,.success-text,.error-text{font-size:.875rem;color:var(--text-primary, #fff);margin-bottom:.5rem}.error-detail{font-size:.75rem;color:var(--text-secondary, #888);margin-bottom:.5rem}.progress-bar{width:100%;max-width:200px;height:4px;background:var(--bg-tertiary, #333);border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:var(--accent-color, #4a9eff);transition:width .2s ease}.retry-btn{margin-top:.5rem;padding:.5rem 1rem;font-size:.875rem;color:var(--text-primary, #fff);background:var(--bg-tertiary, #333);border:1px solid var(--border-color, #444);border-radius:4px;cursor:pointer;transition:background .2s ease}.retry-btn:hover{background:var(--bg-hover, #444)}.file-uploader.compact{display:inline-block}.file-upload-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;color:var(--text-primary, #fff);background:var(--bg-secondary, #252525);border:1px solid var(--border-color, #444);border-radius:4px;cursor:pointer;transition:all .2s ease}.file-upload-btn:hover:not(:disabled){background:var(--bg-hover, #333);border-color:var(--accent-color, #4a9eff)}.file-upload-btn:disabled{opacity:.6;cursor:not-allowed}.pdf-preview{position:relative;display:inline-flex;flex-direction:column;align-items:center;background:var(--bg-secondary, #1a1a1a);border:1px solid var(--border-color, #333);border-radius:8px;overflow:hidden;transition:all .2s ease}.pdf-preview.clickable{cursor:pointer}.pdf-preview.clickable:hover{border-color:var(--accent-color, #4a9eff);transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.pdf-preview.clickable:hover .pdf-overlay{opacity:1}.pdf-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:.75rem;color:var(--text-secondary, #888);min-width:150px;min-height:200px}.pdf-spinner{width:32px;height:32px;border:3px solid var(--border-color, #333);border-top-color:var(--accent-color, #4a9eff);border-radius:50%;animation:pdf-spin 1s linear infinite}@keyframes pdf-spin{to{transform:rotate(360deg)}}.pdf-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:.5rem;color:var(--error-color, #f44336);min-width:150px;min-height:200px}.pdf-error-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;font-size:1.5rem;font-weight:700;background:#f4433633;border-radius:50%}.pdf-thumbnail{display:block;max-width:100%;height:auto}.pdf-info{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem;width:100%;background:var(--bg-tertiary, #222)}.pdf-filename{font-size:.8rem;color:var(--text-primary, #fff);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pdf-pages{font-size:.7rem;color:var(--text-secondary, #888)}.pdf-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:#0009;opacity:0;transition:opacity .2s ease;pointer-events:none}.pdf-overlay span{padding:.5rem 1rem;background:var(--accent-color, #4a9eff);color:#fff;font-size:.875rem;font-weight:500;border-radius:4px}.pdf-viewer-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.pdf-viewer{display:flex;flex-direction:column;max-width:90vw;max-height:90vh;background:var(--bg-primary, #121212);border-radius:12px;overflow:hidden;box-shadow:0 20px 60px #00000080}.pdf-viewer-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--bg-secondary, #1a1a1a);border-bottom:1px solid var(--border-color, #333)}.pdf-viewer-title{font-size:.9rem;font-weight:500;color:var(--text-primary, #fff);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pdf-viewer-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;font-size:1.5rem;color:var(--text-secondary, #888);background:none;border:none;border-radius:4px;cursor:pointer;transition:all .2s ease}.pdf-viewer-close:hover{color:var(--text-primary, #fff);background:var(--bg-tertiary, #333)}.pdf-viewer-content{flex:1;overflow:auto;display:flex;align-items:center;justify-content:center;padding:1rem;background:var(--bg-tertiary, #222)}.pdf-viewer-canvas{max-width:100%;height:auto;box-shadow:0 4px 20px #0000004d}.pdf-viewer-nav{display:flex;align-items:center;justify-content:center;gap:1rem;padding:.75rem 1rem;background:var(--bg-secondary, #1a1a1a);border-top:1px solid var(--border-color, #333)}.pdf-nav-btn{padding:.5rem 1rem;font-size:.875rem;color:var(--text-primary, #fff);background:var(--bg-tertiary, #333);border:1px solid var(--border-color, #444);border-radius:4px;cursor:pointer;transition:all .2s ease}.pdf-nav-btn:hover:not(:disabled){background:var(--accent-color, #4a9eff);border-color:var(--accent-color, #4a9eff)}.pdf-nav-btn:disabled{opacity:.5;cursor:not-allowed}.pdf-page-info{font-size:.875rem;color:var(--text-secondary, #888);min-width:120px;text-align:center}.pdf-viewer-hint{font-size:.75rem;color:var(--text-tertiary, #666);text-align:center;padding:.5rem;background:var(--bg-secondary, #1a1a1a)}.clipboard-panel{display:flex;flex-direction:column;height:100%;background:var(--bg-secondary, #1a1a2e);color:var(--text-primary, #e0e0e0);border-radius:8px;overflow:hidden}.clipboard-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid var(--border-color, #333)}.clipboard-header h2{margin:0;font-size:18px;font-weight:600}.clipboard-header .close-btn{background:none;border:none;color:var(--text-secondary, #999);font-size:24px;cursor:pointer;padding:0;line-height:1}.clipboard-header .close-btn:hover{color:var(--text-primary, #fff)}.clipboard-tabs{display:flex;border-bottom:1px solid var(--border-color, #333)}.clipboard-tabs .tab{flex:1;padding:12px;background:none;border:none;color:var(--text-secondary, #999);cursor:pointer;font-size:14px;transition:all .2s}.clipboard-tabs .tab:hover{background:#ffffff0d}.clipboard-tabs .tab.active{color:var(--accent-color, #7c3aed);border-bottom:2px solid var(--accent-color, #7c3aed)}.clipboard-error{padding:12px 16px;background:#ef44441a;color:#ef4444;font-size:13px;border-bottom:1px solid rgba(239,68,68,.2)}.clipboard-loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--text-secondary, #999)}.clipboard-history{flex:1;display:flex;flex-direction:column;overflow:hidden}.clipboard-filter{display:flex;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border-color, #333)}.clipboard-filter select{flex:1;padding:8px 12px;background:var(--bg-tertiary, #252540);border:1px solid var(--border-color, #333);border-radius:6px;color:var(--text-primary, #e0e0e0);font-size:13px}.clipboard-filter .refresh-btn,.clipboard-filter .paste-browser-btn{padding:8px 12px;background:var(--bg-tertiary, #252540);border:1px solid var(--border-color, #333);border-radius:6px;color:var(--text-primary, #e0e0e0);cursor:pointer;font-size:13px;white-space:nowrap}.clipboard-filter .paste-browser-btn{background:var(--accent-color, #7c3aed);border-color:var(--accent-color, #7c3aed)}.clipboard-filter .refresh-btn:hover,.clipboard-filter .paste-browser-btn:hover{opacity:.9}.clipboard-stats{display:flex;gap:16px;padding:8px 16px;font-size:12px;color:var(--text-secondary, #999);border-bottom:1px solid var(--border-color, #333)}.clipboard-list{flex:1;overflow-y:auto}.clipboard-empty{padding:40px 16px;text-align:center;color:var(--text-secondary, #999)}.clipboard-entry{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border-color, #333);cursor:pointer;transition:background .2s}.clipboard-entry:hover{background:#ffffff08}.clipboard-entry.selected{background:#7c3aed1a}.entry-icon{font-size:24px;width:40px;text-align:center}.entry-info{flex:1;min-width:0}.entry-label{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.entry-meta{display:flex;gap:12px;margin-top:4px;font-size:12px;color:var(--text-secondary, #999)}.entry-tags{display:flex;gap:4px;margin-top:4px}.tag{padding:2px 6px;background:#7c3aed33;border-radius:4px;font-size:11px;color:var(--accent-color, #7c3aed)}.entry-actions{display:flex;gap:4px}.action-btn{padding:6px 10px;background:none;border:none;cursor:pointer;font-size:16px;opacity:.6;transition:opacity .2s}.action-btn:hover{opacity:1}.action-btn.delete-btn:hover{color:#ef4444}.clipboard-paste{flex:1;overflow-y:auto;padding:16px}.paste-section{margin-bottom:20px}.paste-section h3{margin:0 0 8px;font-size:14px;font-weight:600}.paste-section p{margin:0 0 12px;font-size:13px;color:var(--text-secondary, #999)}.paste-browser-btn.large{display:block;width:100%;padding:16px;background:var(--accent-color, #7c3aed);border:none;border-radius:8px;color:#fff;font-size:15px;cursor:pointer}.paste-divider{text-align:center;padding:16px 0;color:var(--text-secondary, #999);font-size:13px}.paste-textarea{width:100%;padding:12px;background:var(--bg-tertiary, #252540);border:1px solid var(--border-color, #333);border-radius:8px;color:var(--text-primary, #e0e0e0);font-family:monospace;font-size:13px;resize:vertical;box-sizing:border-box}.paste-options{display:flex;gap:8px;margin:12px 0}.paste-input{flex:1;padding:10px 12px;background:var(--bg-tertiary, #252540);border:1px solid var(--border-color, #333);border-radius:6px;color:var(--text-primary, #e0e0e0);font-size:13px}.paste-submit-btn{width:100%;padding:12px;background:var(--accent-color, #7c3aed);border:none;border-radius:8px;color:#fff;font-size:14px;cursor:pointer}.paste-submit-btn:disabled{opacity:.5;cursor:not-allowed}.clipboard-details{flex:1;overflow-y:auto;padding:16px}.details-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.details-icon{font-size:36px}.details-title h3{margin:0;font-size:16px;font-weight:600}.details-type{font-size:12px;color:var(--text-secondary, #999);font-family:monospace}.details-meta{background:var(--bg-tertiary, #252540);border-radius:8px;padding:12px;margin-bottom:20px}.meta-row{display:flex;justify-content:space-between;padding:6px 0;font-size:13px}.meta-row:not(:last-child){border-bottom:1px solid var(--border-color, #333)}.meta-label{color:var(--text-secondary, #999)}.meta-value{font-family:monospace}.meta-value .tag{margin-left:4px}.details-preview{margin-bottom:20px}.details-preview h4{margin:0 0 12px;font-size:14px;font-weight:600}.preview-loading,.preview-unavailable{padding:20px;text-align:center;color:var(--text-secondary, #999);background:var(--bg-tertiary, #252540);border-radius:8px}.preview-image{max-width:100%;max-height:300px;border-radius:8px}.preview-text{margin:0;padding:12px;background:var(--bg-tertiary, #252540);border-radius:8px;font-size:12px;overflow-x:auto;white-space:pre-wrap;word-break:break-all;max-height:300px;overflow-y:auto}.details-actions{display:flex;gap:8px}.details-actions button{flex:1;padding:10px 16px;background:var(--bg-tertiary, #252540);border:1px solid var(--border-color, #333);border-radius:6px;color:var(--text-primary, #e0e0e0);font-size:13px;cursor:pointer}.details-actions button:first-child{background:var(--accent-color, #7c3aed);border-color:var(--accent-color, #7c3aed)}.details-actions button:hover{opacity:.9}.details-actions button.delete-btn{background:transparent;border-color:#ef4444;color:#ef4444}.details-actions button.delete-btn:hover{background:#ef44441a}.preview-downloading{padding:24px;background:var(--bg-tertiary, #252540);border-radius:8px;text-align:center}.download-status{font-size:14px;color:var(--text-primary, #e0e0e0);margin-bottom:16px}.download-progress-bar{height:8px;background:var(--bg-secondary, #1a1a2e);border-radius:4px;overflow:hidden;margin-bottom:12px}.download-progress-fill{height:100%;background:var(--accent-color, #7c3aed);border-radius:4px;transition:width .3s ease}.download-progress-fill.fetching{background:#f59e0b;animation:pulse 1.5s ease-in-out infinite}.download-progress-fill.downloading{background:var(--accent-color, #7c3aed)}.download-progress-fill.complete{background:#22c55e}.download-progress-fill.error{background:#ef4444}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.download-stats{font-size:12px;color:var(--text-secondary, #999);font-family:monospace}.account-settings{display:flex;flex-direction:column;min-height:400px;max-height:80vh;overflow-y:auto}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid var(--border-color, #333)}.settings-header h2{margin:0;font-size:1.25rem}.close-btn{background:none;border:none;font-size:1.5rem;color:var(--text-secondary, #888);cursor:pointer;padding:.25rem;line-height:1}.close-btn:hover{color:var(--text-primary, #fff)}.settings-main{padding:1rem}.identity-info{margin-bottom:1.5rem;padding:1rem;background:var(--bg-secondary, #1a1a1a);border-radius:8px}.identity-info h3{margin:0 0 .75rem;font-size:1rem;color:var(--text-primary, #fff)}.info-row{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.75rem}.info-row:last-child{margin-bottom:0}.info-label{font-size:.75rem;color:var(--text-secondary, #888);text-transform:uppercase}.info-value{font-size:.875rem;color:var(--text-primary, #e0e0e0);word-break:break-all}.info-value code{font-family:Fira Code,monospace;font-size:.8rem}.no-identity{color:var(--text-secondary, #888);font-style:italic}.settings-actions{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.action-btn{display:flex;flex-direction:column;align-items:flex-start;padding:1rem;background:var(--bg-secondary, #252525);border:1px solid var(--border-color, #444);border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:left;font-size:1rem;color:var(--text-primary, #fff)}.action-btn:hover:not(:disabled){border-color:var(--accent-color, #4a9eff);background:var(--bg-hover, #2a2a2a)}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn.export{border-left:3px solid var(--accent-color, #4a9eff)}.action-btn.import{border-left:3px solid var(--success-color, #4caf50)}.action-desc{font-size:.8rem;color:var(--text-secondary, #888);margin-top:.25rem}.settings-warning{padding:.75rem;background:#ffc1071a;border:1px solid rgba(255,193,7,.3);border-radius:6px;font-size:.8rem;color:var(--text-secondary, #ccc)}.settings-warning strong{color:#ffc107}.settings-export,.settings-import{padding:1rem}.back-btn{background:none;border:none;color:var(--accent-color, #4a9eff);cursor:pointer;padding:0;margin-bottom:1rem;font-size:.875rem}.back-btn:hover{text-decoration:underline}.settings-export h3,.settings-import h3{margin:0 0 .5rem;font-size:1.1rem}.settings-export p,.settings-import p{margin:0 0 1rem;color:var(--text-secondary, #aaa);font-size:.875rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-size:.875rem;color:var(--text-secondary, #aaa)}.form-group input,.form-group textarea{width:100%;padding:.75rem;background:var(--bg-secondary, #1a1a1a);border:1px solid var(--border-color, #444);border-radius:6px;color:var(--text-primary, #fff);font-size:.875rem;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-color, #4a9eff)}.form-group input:disabled,.form-group textarea:disabled{opacity:.6}.form-group textarea{font-family:Fira Code,monospace;resize:vertical}.generate-btn,.restore-btn{width:100%;padding:.875rem;background:var(--accent-color, #4a9eff);border:none;border-radius:6px;color:#fff;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s ease}.generate-btn:hover:not(:disabled),.restore-btn:hover:not(:disabled){background:var(--accent-hover, #3a8eef)}.generate-btn:disabled,.restore-btn:disabled{opacity:.6;cursor:not-allowed}.backup-result{margin-top:1rem}.backup-code{margin-bottom:1rem}.backup-code textarea{width:100%;padding:.75rem;background:var(--bg-secondary, #1a1a1a);border:1px solid var(--border-color, #444);border-radius:6px;color:var(--text-primary, #fff);font-family:Fira Code,monospace;font-size:.75rem;resize:none}.backup-actions{display:flex;gap:.5rem;margin-bottom:1rem}.backup-actions button{flex:1;padding:.75rem;background:var(--bg-secondary, #252525);border:1px solid var(--border-color, #444);border-radius:6px;color:var(--text-primary, #fff);font-size:.875rem;cursor:pointer;transition:all .2s ease}.backup-actions button:hover{background:var(--bg-hover, #333);border-color:var(--accent-color, #4a9eff)}.backup-warning,.import-warning{padding:.75rem;background:#f443361a;border:1px solid rgba(244,67,54,.3);border-radius:6px;font-size:.8rem;color:var(--text-secondary, #ccc)}.backup-warning strong,.import-warning strong{color:#f44336}.file-drop-hint{margin-top:.5rem;font-size:.8rem;color:var(--text-secondary, #888)}.file-label span{color:var(--accent-color, #4a9eff);cursor:pointer}.file-label span:hover{text-decoration:underline}.message{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;margin:1rem;border-radius:6px;font-size:.875rem}.message.error{background:#f443361a;border:1px solid rgba(244,67,54,.3);color:#f44336}.message.success{background:#4caf501a;border:1px solid rgba(76,175,80,.3);color:#4caf50}.message button{background:none;border:none;color:inherit;cursor:pointer;font-size:1rem;padding:0;margin-left:.5rem}.call-panel{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;background:#000}.call-panel.incoming{background:#000000d9}.call-overlay{display:flex;align-items:center;justify-content:center;height:100%}.incoming-call-card{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:2rem 3rem;background:var(--bg-card);border-radius:16px;animation:pulse-ring 2s ease-out infinite}@keyframes pulse-ring{0%{box-shadow:0 0 #8b5cf666}70%{box-shadow:0 0 0 20px #8b5cf600}to{box-shadow:0 0 #8b5cf600}}.caller-info{text-align:center}.caller-info h3{margin:0;font-size:1.5rem;color:var(--text-primary)}.caller-info .call-type{margin:.5rem 0 0;color:var(--text-muted)}.incoming-actions{display:flex;gap:2rem;margin-top:1rem}.call-btn{width:64px;height:64px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s,background .2s}.call-btn:hover{transform:scale(1.1)}.call-btn.accept{background:#22c55e;color:#fff}.call-btn.accept:hover{background:#16a34a}.call-btn.decline{background:#ef4444;color:#fff}.call-btn.decline:hover{background:#dc2626}.btn-icon{font-size:1.5rem}.call-panel.active{display:flex;flex-direction:column}.call-videos{flex:1;position:relative;overflow:hidden}.remote-video-container{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center}.remote-video{width:100%;height:100%;object-fit:cover}.waiting-for-video{display:flex;flex-direction:column;align-items:center;gap:1rem;color:var(--text-muted)}.local-video-container{position:absolute;bottom:100px;right:20px;width:150px;height:200px;border-radius:12px;overflow:hidden;border:2px solid rgba(255,255,255,.3);background:#222}.local-video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.call-info-bar{position:absolute;top:0;left:0;right:0;padding:1rem;background:linear-gradient(to bottom,rgba(0,0,0,.7),transparent)}.call-peer-info{display:flex;align-items:center;gap:1rem}.peer-name{font-size:1.1rem;font-weight:500;color:#fff}.call-duration{font-size:.9rem;color:#ffffffb3;font-family:monospace}.call-controls{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:center;gap:1.5rem;padding:1.5rem;background:linear-gradient(to top,rgba(0,0,0,.8),transparent)}.control-btn{width:56px;height:56px;border-radius:50%;border:none;background:#fff3;color:#fff;font-size:1.5rem;cursor:pointer;transition:background .2s,transform .2s;display:flex;align-items:center;justify-content:center}.control-btn:hover{background:#ffffff4d;transform:scale(1.1)}.control-btn.off{background:#ffffff1a;opacity:.7}.control-btn.end-call{background:#ef4444;transform:rotate(135deg)}.control-btn.end-call:hover{background:#dc2626}.call-buttons{display:flex;gap:.5rem}.call-action-btn{width:36px;height:36px;border-radius:50%;border:none;background:var(--bg-dark);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:background .2s}.call-action-btn:hover:not(:disabled){background:var(--accent)}.call-action-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 600px){.local-video-container{width:100px;height:140px;bottom:120px;right:10px}.call-controls{gap:1rem}.control-btn{width:48px;height:48px;font-size:1.25rem}.incoming-call-card{margin:1rem;padding:1.5rem 2rem}}.chat-panel{display:flex;flex-direction:column;height:100%;max-height:600px;background:var(--bg-card);border-radius:12px;overflow:hidden}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.chat-header h2{margin:0;font-size:1.1rem;font-weight:600}.chat-header .close-btn{background:none;border:none;font-size:1.5rem;color:var(--text-muted);cursor:pointer;padding:0;line-height:1}.chat-header .close-btn:hover{color:var(--text-primary)}.chat-body{display:flex;flex:1;min-height:0}.conversation-list{width:250px;border-right:1px solid var(--border);overflow-y:auto;flex-shrink:0}.conversation-list-header{padding:.75rem 1rem;font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);background:var(--bg-dark)}.no-conversations{padding:2rem 1rem;text-align:center;color:var(--text-muted)}.no-conversations .hint{font-size:.8rem;margin-top:.5rem}.conversation-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:none;border:none;border-bottom:1px solid var(--border);cursor:pointer;text-align:left;transition:background .2s}.conversation-item:hover{background:var(--bg-dark)}.conversation-item.selected{background:#8b5cf61a;border-left:3px solid var(--accent);padding-left:calc(1rem - 3px)}.conversation-item.unread{background:#8b5cf60d}.conversation-item .avatar-with-status{position:relative;flex-shrink:0}.conversation-item .online-dot{position:absolute;bottom:0;right:0;width:8px;height:8px;background:#22c55e;border:2px solid var(--bg-card);border-radius:50%}.conversation-info{flex:1;min-width:0}.conversation-name{font-size:.9rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-preview{font-size:.8rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:.15rem}.conversation-preview .you{color:var(--text-secondary)}.conversation-preview.new{color:var(--accent);font-style:italic}.conversation-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem;flex-shrink:0}.conversation-time{font-size:.7rem;color:var(--text-muted)}.unread-badge{background:var(--accent);color:#fff;font-size:.65rem;font-weight:600;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 5px}.chat-view{flex:1;display:flex;flex-direction:column;min-width:0}.no-chat-selected{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted)}.chat-view-header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);background:var(--bg-dark)}.chat-view-header .back-btn{background:none;border:none;color:var(--text-muted);font-size:1.25rem;cursor:pointer;padding:.25rem;display:none}.chat-view-header .avatar-with-status{position:relative}.chat-view-header .online-dot{position:absolute;bottom:0;right:0;width:10px;height:10px;background:#22c55e;border:2px solid var(--bg-dark);border-radius:50%}.chat-peer-info{flex:1}.chat-peer-name{font-size:.95rem;font-weight:500;color:var(--text-primary)}.chat-peer-status{font-size:.75rem;color:var(--text-muted)}.messages-container{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.5rem}.loading-messages,.no-messages{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted)}.no-messages .hint{font-size:.8rem;margin-top:.5rem}.message{max-width:75%;padding:.6rem .9rem;border-radius:12px;position:relative}.message.sent{align-self:flex-end;background:var(--accent);color:#fff;border-bottom-right-radius:4px}.message.received{align-self:flex-start;background:var(--bg-dark);color:var(--text-primary);border-bottom-left-radius:4px}.message-content{font-size:.9rem;line-height:1.4;word-break:break-word}.message-content p{margin:0}.message-time{font-size:.65rem;opacity:.7;margin-top:.25rem;text-align:right}.chat-input{display:flex;gap:.5rem;padding:.75rem 1rem;border-top:1px solid var(--border);background:var(--bg-dark)}.chat-input textarea{flex:1;padding:.6rem .9rem;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;color:var(--text-primary);font-size:.9rem;font-family:inherit;resize:none;min-height:38px;max-height:100px}.chat-input textarea:focus{outline:none;border-color:var(--accent)}.chat-input .send-btn{padding:.6rem 1.25rem;background:var(--accent);color:#fff;border:none;border-radius:20px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s;flex-shrink:0}.chat-input .send-btn:hover:not(:disabled){background:#7c3aed}.chat-input .send-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 600px){.conversation-list{width:100%;display:block}.chat-view{display:none;position:absolute;top:0;left:0;right:0;bottom:0;background:var(--bg-card)}.chat-panel:has(.chat-view:not(.no-chat-selected)) .conversation-list{display:none}.chat-panel:has(.chat-view:not(.no-chat-selected)) .chat-view{display:flex}.chat-view-header .back-btn{display:block}}.conversation-list::-webkit-scrollbar,.messages-container::-webkit-scrollbar{width:6px}.conversation-list::-webkit-scrollbar-track,.messages-container::-webkit-scrollbar-track{background:transparent}.conversation-list::-webkit-scrollbar-thumb,.messages-container::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.conversation-list::-webkit-scrollbar-thumb:hover,.messages-container::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.message-attachments{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.attachment-preview{display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:#ffffff1a;border-radius:4px;font-size:.75rem}.attachment-icon{font-size:1rem}.attachment-hash{color:var(--text-muted);font-family:monospace}.selected-attachments{display:flex;gap:.5rem;padding:.5rem 1rem;border-top:1px solid var(--border);overflow-x:auto}.selected-attachment{position:relative;width:60px;height:60px;border-radius:8px;overflow:hidden;background:var(--bg-secondary);flex-shrink:0}.selected-attachment img{width:100%;height:100%;object-fit:cover}.selected-attachment .attachment-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:1.5rem}.selected-attachment .remove-attachment{position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:50%;background:#000000b3;color:#fff;border:none;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center}.attachment-picker{position:absolute;bottom:100%;left:0;right:0;background:var(--bg-card);border:1px solid var(--border);border-radius:8px 8px 0 0;max-height:200px;overflow-y:auto;z-index:10}.attachment-picker-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;border-bottom:1px solid var(--border);font-size:.85rem;font-weight:500}.attachment-picker-header button{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1.25rem}.attachment-picker-list{padding:.5rem}.attachment-option{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem;background:none;border:none;border-radius:4px;cursor:pointer;color:var(--text-primary);text-align:left}.attachment-option:hover:not(:disabled){background:var(--bg-hover)}.attachment-option:disabled{opacity:.5;cursor:not-allowed}.attachment-type-icon{font-size:1.25rem}.attachment-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.85rem}.no-attachments{text-align:center;padding:1rem;color:var(--text-muted);font-size:.85rem}.chat-input{position:relative}.attachment-btn{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.5rem;opacity:.7;transition:opacity .2s}.attachment-btn:hover{opacity:1}.user-directory{display:flex;flex-direction:column;height:100%;max-height:600px;background:var(--bg-card);border-radius:12px;overflow:hidden}.directory-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.directory-header h2{margin:0;font-size:1.1rem;font-weight:600}.directory-header .close-btn{background:none;border:none;font-size:1.5rem;color:var(--text-muted);cursor:pointer;padding:0;line-height:1}.directory-header .close-btn:hover{color:var(--text-primary)}.directory-search{padding:.75rem 1rem;border-bottom:1px solid var(--border)}.search-input{width:100%;padding:.6rem .9rem;background:var(--bg-dark);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.9rem}.search-input:focus{outline:none;border-color:var(--accent)}.search-input::placeholder{color:var(--text-muted)}.directory-filters{display:flex;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);background:var(--bg-dark)}.filter-group{display:flex;align-items:center;gap:.5rem}.filter-group label{font-size:.8rem;color:var(--text-muted)}.filter-group select{padding:.4rem .6rem;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:.85rem}.directory-stats{padding:.5rem 1rem;font-size:.75rem;color:var(--text-muted);border-bottom:1px solid var(--border)}.search-hint{margin-left:.5rem;font-style:italic}.user-list{flex:1;overflow-y:auto}.no-users{padding:2rem;text-align:center;color:var(--text-muted)}.user-card{display:flex;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--border);transition:background .2s}.user-card:hover{background:var(--bg-dark)}.user-card-main{flex:1;display:flex;align-items:center;gap:.75rem;cursor:pointer;min-width:0}.avatar-with-status{position:relative;flex-shrink:0}.online-indicator{position:absolute;bottom:0;right:0;width:10px;height:10px;background:#22c55e;border:2px solid var(--bg-card);border-radius:50%}.user-info{flex:1;min-width:0}.user-name{font-size:.95rem;font-weight:500;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.friend-badge{font-size:.65rem;padding:.15rem .4rem;background:var(--accent);color:#fff;border-radius:4px;font-weight:600;text-transform:uppercase}.user-bio{font-size:.8rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:.15rem}.user-meta{display:flex;gap:.75rem;margin-top:.25rem;font-size:.75rem;color:var(--text-muted)}.user-pubkey{font-family:monospace}.user-karma{color:var(--accent)}.user-card-actions{display:flex;gap:.5rem;position:relative}.action-btn{width:32px;height:32px;border-radius:50%;border:none;background:var(--bg-dark);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:background .2s}.action-btn:hover{background:var(--border)}.action-btn.add-friend{background:var(--accent);color:#fff;font-weight:700}.action-btn.add-friend:hover{background:#7c3aed}.action-btn.chat:hover{background:var(--accent)}.actions-dropdown{position:absolute;top:100%;right:0;margin-top:.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;overflow:hidden;z-index:10;min-width:140px;box-shadow:0 4px 12px #0000004d}.actions-dropdown button{display:block;width:100%;padding:.6rem .9rem;background:none;border:none;text-align:left;color:var(--text-primary);font-size:.85rem;cursor:pointer}.actions-dropdown button:hover{background:var(--bg-dark)}.actions-dropdown button.danger{color:#ef4444}.actions-dropdown button.danger:hover{background:#ef44441a}.user-list::-webkit-scrollbar{width:6px}.user-list::-webkit-scrollbar-track{background:transparent}.user-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.user-list::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media (max-width: 500px){.directory-filters{flex-direction:column;gap:.5rem}.filter-group{width:100%}.filter-group select{flex:1}.user-bio{display:none}}.app{min-height:100vh;display:flex;flex-direction:column}.app-main{flex:1;padding:2rem;max-width:900px;margin:0 auto;width:100%}.app-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--text-secondary)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.version-info{font-size:.75rem;color:var(--text-secondary);opacity:.6;margin-top:.5rem}.focused-article-view{margin-top:1rem}.back-to-feed-btn{display:inline-flex;align-items:center;gap:.5rem;background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);padding:.5rem 1rem;border-radius:6px;font-size:.9rem;margin-bottom:1rem;transition:all .2s}.back-to-feed-btn:hover{border-color:var(--accent);color:var(--accent)}.article-not-found{text-align:center;padding:3rem;color:var(--text-muted)}.article-not-found p:first-child{font-size:1.1rem;margin-bottom:.5rem}.article-not-found .mono{font-size:.85rem;color:var(--text-muted)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.clipboard-modal{width:100%;max-width:600px;max-height:80vh;overflow:hidden;border-radius:12px;box-shadow:0 20px 60px #00000080}.account-settings-modal{width:100%;max-width:500px;max-height:85vh;overflow:hidden;border-radius:12px;box-shadow:0 20px 60px #00000080;background:var(--bg-primary, #121212)}.chat-modal{width:100%;max-width:800px;height:80vh;max-height:600px;overflow:hidden;border-radius:12px;box-shadow:0 20px 60px #00000080}.user-directory-modal{width:100%;max-width:500px;height:80vh;max-height:600px;overflow:hidden;border-radius:12px;box-shadow:0 20px 60px #00000080}:root{--bg-dark: #0a0a0f;--bg-card: #12121a;--text-primary: #e4e4e7;--text-secondary: #a1a1aa;--text-muted: #71717a;--red-pill: #dc2626;--red-pill-glow: rgba(220, 38, 38, .3);--blue-pill: #2563eb;--blue-pill-glow: rgba(37, 99, 235, .3);--border: #27272a;--accent: #8b5cf6}[data-theme=light]{--bg-dark: #f8fafc;--bg-card: #ffffff;--text-primary: #1e293b;--text-secondary: #475569;--text-muted: #94a3b8;--red-pill: #dc2626;--red-pill-glow: rgba(220, 38, 38, .2);--blue-pill: #2563eb;--blue-pill-glow: rgba(37, 99, 235, .2);--border: #e2e8f0;--accent: #7c3aed}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:var(--bg-dark);color:var(--text-primary);min-height:100vh;line-height:1.6}#root{min-height:100vh}button{cursor:pointer;border:none;font-family:inherit}input,textarea{font-family:inherit;background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);border-radius:8px;padding:12px;font-size:1rem}input:focus,textarea:focus{outline:none;border-color:var(--accent)}.mono{font-family:SF Mono,Monaco,Cascadia Code,monospace;font-size:.85em}
