:root{--bg:#0f0f13;--surface:#1a1a24;--card:#22222f;--accent:#6366f1;--accent2:#818cf8;--text:#f0eeff;--muted:#7070a0;--danger:#ef4444;--border:#6366f133;--online:#22c55e;--offline:#4b5563}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);height:100vh;font-family:system-ui,-apple-system,sans-serif;overflow:hidden}.app-layout{height:100vh;display:flex}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:260px;min-width:200px;display:flex;overflow:hidden}@media (width<=600px){.sidebar{z-index:50;width:80vw;max-width:300px;transition:transform .25s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.sidebar-open{transform:translate(0)}.sidebar-backdrop{z-index:49;background:#00000080;position:fixed;inset:0}.mobile-topbar{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:.75rem;padding:.6rem .75rem;display:flex}.mobile-topbar-title{font-size:.95rem;font-weight:700}.chat-area{flex-direction:column}}@media (width>=601px){.mobile-topbar,.sidebar-backdrop{display:none}}.sidebar-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1rem;display:flex}.logo{color:var(--accent);letter-spacing:-1px;font-size:1.8rem;font-weight:800}.logo-small{color:var(--accent);font-size:1.2rem;font-weight:800}.subtitle{color:var(--muted);margin-bottom:1.5rem;font-size:.85rem}.identity-bar{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.5rem 1rem;display:flex}.username{color:var(--text);font-size:.9rem;font-weight:600}.chat-area{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.contact-list{flex:1;padding:.5rem;overflow-y:auto}.contact-list-section-label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;padding:.5rem .25rem;font-size:.7rem;font-weight:700}.contact-list-empty{color:var(--muted);padding:.5rem;font-size:.85rem}.contact-item-wrap{border-radius:8px;align-items:center;transition:background .1s;display:flex}.contact-item-wrap:hover{background:var(--card)}.contact-item-wrap.active{color:var(--accent2);background:#6366f126}.contact-item-wrap .contact-remove-btn{opacity:0;color:var(--muted);flex-shrink:0;padding:.25rem .5rem;font-size:1rem;transition:opacity .15s}.contact-item-wrap:hover .contact-remove-btn{opacity:1}@media (hover:none){.contact-item-wrap .contact-remove-btn{opacity:1}}.contact-remove-confirm{width:100%;color:var(--danger);align-items:center;gap:.4rem;padding:.4rem .75rem;font-size:.85rem;display:flex}.contact-item{color:inherit;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;flex:1;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.9rem;display:flex}.contact-name{flex:1}.unread-badge{background:var(--accent);color:#fff;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:.7rem;font-weight:700;display:flex}.presence-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.presence-dot.online{background:var(--online)}.presence-dot.offline{background:var(--offline)}.add-contact{border-top:1px solid var(--border);margin-top:.5rem;padding:.5rem}.online-user-item{color:var(--muted);align-items:center;gap:.5rem;padding:.25rem;font-size:.85rem;display:flex}.pending-requests{border-top:1px solid var(--border);margin-top:.5rem;padding:.5rem}.contact-request-item{justify-content:space-between;align-items:center;gap:.5rem;padding:.4rem .25rem;display:flex}.contact-request-name{color:var(--text);flex:1;font-size:.88rem}.contact-request-actions{gap:.35rem;display:flex}.btn-xs{border-radius:6px;padding:.25rem .6rem;font-size:.75rem}.chat-window{flex-direction:column;height:100%;display:flex}.chat-header{border-bottom:1px solid var(--border);background:var(--surface);flex-wrap:wrap;align-items:center;gap:.5rem;padding:.6rem 1rem;display:flex}.chat-header-row1{align-items:center;gap:.5rem;width:100%;display:flex}.chat-header-row2{flex-wrap:wrap;align-items:center;gap:.4rem;width:100%;display:flex}@media (width>=601px){.chat-header{flex-wrap:nowrap}.chat-header-row1,.chat-header-row2{width:auto}.chat-header-row1{flex:1}}.chat-with{flex:1;font-size:1rem;font-weight:700}.rtc-status{color:var(--muted);font-size:.8rem}.rtc-connecting{color:#f59e0b}.status-encrypted{color:var(--online);font-weight:600}.status-handshaking{color:#f59e0b}.status-plain{color:var(--danger)}.status-ended{color:var(--muted)}.message.system{background:0 0;align-self:center}.message-system{color:var(--muted);font-size:.78rem;font-style:italic}.message-list{flex-direction:column;flex:1;gap:.5rem;padding:1rem;display:flex;overflow-y:auto}.message{border-radius:12px;flex-direction:column;gap:.15rem;max-width:70%;padding:.5rem .75rem;font-size:.9rem;display:flex}.message.mine{background:#6366f133;border-bottom-right-radius:4px;align-self:flex-end}.message.theirs{background:var(--card);border-bottom-left-radius:4px;align-self:flex-start}.message-sender{color:var(--accent2);margin-bottom:.1rem;font-size:.72rem;font-weight:700}.message.mine .message-sender{color:var(--accent2);text-align:right;align-self:flex-end}.message-time{color:var(--muted);align-self:flex-end;font-size:.7rem}.chat-input-row{border-top:1px solid var(--border);background:var(--surface);gap:.5rem;padding:.75rem 1rem;display:flex}.no-chat{color:var(--muted);flex:1;justify-content:center;align-items:center;display:flex}.page-center{justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.card{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:16px;width:100%;max-width:380px;padding:2.5rem 2rem}.form{flex-direction:column;gap:.75rem;display:flex}.hint{color:var(--muted);margin-top:1rem;font-size:.8rem}.error{color:var(--danger);font-size:.85rem}.input{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text);border-radius:8px;outline:none;padding:.65rem .9rem;font-size:.9rem}.input:focus{border-color:var(--accent)}.input-sm{padding:.45rem .7rem;font-size:.85rem}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:.65rem 1.25rem;font-size:.9rem;font-weight:700;transition:opacity .15s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg, var(--accent), var(--accent2));color:#fff}.btn-ghost{color:var(--muted);border:1px solid var(--border);background:0 0}.btn-sm{padding:.4rem .75rem;font-size:.8rem}.btn-icon{color:var(--muted);border:none;padding:.25rem .4rem;font-size:1rem}.btn-icon:hover{color:var(--text)}.danger{color:var(--danger)!important}.settings-panel{background:var(--card);border-bottom:1px solid var(--border);padding:.75rem 1rem}.settings-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.settings-title{font-size:.9rem;font-weight:700}.settings-section-label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-size:.7rem;font-weight:700}.settings-toggle-row{cursor:pointer;justify-content:space-between;align-items:center;gap:1rem;display:flex}.settings-toggle-label{flex-direction:column;font-size:.88rem;display:flex}.settings-toggle-hint{color:var(--muted);font-size:.75rem;font-weight:400}.toggle{cursor:pointer;border:none;border-radius:11px;flex-shrink:0;width:40px;height:22px;transition:background .2s;position:relative}.toggle.off{background:var(--offline)}.toggle.on{background:var(--accent)}.toggle-thumb{background:#fff;border-radius:50%;width:16px;height:16px;transition:left .2s;position:absolute;top:3px}.toggle.off .toggle-thumb{left:3px}.toggle.on .toggle-thumb{left:21px}.message-text a{color:var(--accent);word-break:break-all;text-decoration:underline}.message-text a:hover{opacity:.8}.message-image{cursor:pointer;object-fit:contain;border:1px solid var(--border);border-radius:8px;max-width:260px;max-height:300px}.message-file{background:var(--card);border:1px solid var(--border);color:var(--text);word-break:break-all;border-radius:8px;align-items:center;gap:.3rem;padding:.4rem .75rem;font-size:.85rem;text-decoration:none;display:inline-flex}.message-file:hover{background:var(--surface)}.toast-stack{z-index:300;pointer-events:none;flex-direction:column;gap:.5rem;display:flex;position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%)}.toast{background:var(--card);border:1px solid var(--border);color:var(--text);pointer-events:all;cursor:pointer;white-space:nowrap;border-radius:999px;padding:.6rem 1.2rem;font-size:.9rem;animation:.2s toast-in;box-shadow:0 4px 16px #0006}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.contact-page-btn{opacity:0;flex-shrink:0;padding:.25rem .4rem;font-size:.85rem;transition:opacity .15s}.contact-item-wrap:hover .contact-page-btn{opacity:1}.contact-page-btn.paged{cursor:not-allowed;opacity:.4!important}@media (hover:none){.contact-page-btn{opacity:1}}.lightbox-overlay{z-index:200;background:#000000e6;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.lightbox-img{object-fit:contain;border-radius:6px;max-width:100%;max-height:100%}.lightbox-close{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:1.2rem;display:flex;position:absolute;top:1rem;right:1rem}.file-warning{color:#f59e0b;background:#f59e0b1a;border:1px solid #f59e0b4d;border-radius:6px;margin:.5rem 0;padding:.5rem .75rem;font-size:.82rem;line-height:1.5}.smp-status{font-size:.8rem;font-weight:600}.smp-verified{color:var(--online)}.smp-failed{color:var(--danger)}.smp-progress{color:#f59e0b}.smp-verified-btn{color:var(--online)!important;border-color:#22c55e4d!important}.smp-overlay{z-index:100;background:#000000b3;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.smp-modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;gap:1rem;width:100%;max-width:380px;padding:2rem;display:flex}.smp-modal-title{font-size:1.1rem;font-weight:800}.smp-modal-desc{color:var(--muted);font-size:.88rem;line-height:1.5}.smp-modal-actions{gap:.5rem;display:flex}.forge-btn{color:#f59e0b!important;border-color:#f59e0b4d!important}.forge-overlay{z-index:100;background:#000000b3;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.forge-panel{background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;width:100%;max-width:700px;max-height:90vh;display:flex;overflow:hidden}.forge-header{border-bottom:1px solid var(--border);background:var(--card);flex-direction:column;gap:.3rem;padding:.75rem 1rem;display:flex}.forge-title{color:#f59e0b;font-size:1rem;font-weight:800}.forge-subtitle{color:var(--muted);font-size:.85rem}.forge-header-row1{align-items:center;gap:.5rem;width:100%;margin-bottom:.4rem;display:flex}.forge-header-actions{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex}.forge-messages{flex-direction:column;flex:1;gap:.25rem;padding:1rem;display:flex;overflow-y:auto}.forge-empty{color:var(--muted);text-align:center;padding:2rem}.forge-message{background:var(--card);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:.5rem;padding:.75rem;display:flex}.forge-message-meta{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.forge-sender{flex-shrink:0;width:auto}.forge-timestamp{flex:1;width:auto;min-width:160px}.forge-encrypted-toggle{cursor:pointer;align-items:center;gap:.25rem;font-size:.85rem;display:flex}.forge-message-controls{gap:.25rem;margin-left:auto;display:flex}.forge-text{resize:vertical;min-height:52px;font-family:inherit}.forge-add-btn{border:1px dashed var(--border);color:var(--muted);cursor:pointer;text-align:center;background:0 0;border-radius:8px;width:100%;padding:.3rem .75rem;font-size:.8rem;transition:border-color .15s,color .15s}.forge-add-btn:hover{border-color:var(--accent);color:var(--accent)}.forge-add-inline{margin-top:.25rem}.forge-verify-banner{border-bottom:1px solid var(--border);padding:.75rem 1rem;font-size:.85rem}.verify-ok{color:var(--online);background:#22c55e1a}.verify-fail{color:var(--danger);background:#ef44441a}.forge-verify-title{justify-content:space-between;align-items:flex-start;gap:.5rem;font-weight:600;display:flex}.forge-verify-list{margin:.5rem 0 0 1rem;padding:0;font-family:monospace;font-size:.8rem;line-height:1.6;list-style:outside}
