:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#1a1a1a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}#app{width:100%;max-width:800px;margin:0 auto;padding:2rem}.container{display:flex;flex-direction:column;gap:1.5rem}header{text-align:center;margin-bottom:1rem}h1{font-size:2.5rem;line-height:1.1;margin:0 0 .5rem;color:#646cff}h2{font-size:1.5rem;margin:0 0 1rem}.subtitle{margin:0;color:#888;font-size:1rem}.section{background:#242424;border:1px solid #333;border-radius:12px;padding:1.5rem}.hidden{display:none}.input-group{display:flex;gap:.5rem;margin-bottom:.75rem}input[type=text]{flex:1;padding:.75rem 1rem;font-size:1rem;font-family:inherit;border:1px solid #444;border-radius:8px;background:#1a1a1a;color:inherit;transition:border-color .2s}input[type=text]:focus{outline:none;border-color:#646cff}input[type=text]:disabled{opacity:.5;cursor:not-allowed}button{border-radius:8px;border:1px solid transparent;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;font-family:inherit;background-color:#646cff;color:#fff;cursor:pointer;transition:background-color .2s;white-space:nowrap}button:hover:not(:disabled){background-color:#535bf2}button:disabled{opacity:.5;cursor:not-allowed}.hint{margin:0;color:#888;font-size:.9rem}.chat-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;margin-bottom:1rem;border-bottom:1px solid #333;flex-wrap:wrap;gap:.5rem}.status{display:flex;align-items:center;gap:.5rem}.status-dot{width:10px;height:10px;border-radius:50%;background:#888}.status-dot.connected{background:#4ade80;box-shadow:0 0 8px #4ade80}.status-dot.connecting{background:#fbbf24;animation:pulse 2s infinite}.status-dot.disconnected{background:#ef4444}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.messages{height:400px;overflow-y:auto;border:1px solid #333;border-radius:8px;padding:1rem;background:#1a1a1a;margin-bottom:1rem;display:flex;flex-direction:column;gap:.75rem}.message{display:flex;flex-direction:column;gap:.25rem;max-width:75%}.message.self{align-self:flex-end;align-items:flex-end}.message.peer{align-self:flex-start;align-items:flex-start}.message-label{font-size:.75rem;color:#888;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.message-content{padding:.75rem 1rem;border-radius:12px;word-wrap:break-word}.message.self .message-content{background:#646cff;color:#fff}.message.peer .message-content{background:#333;color:#ffffffde}.leave-btn{background:#444;margin-top:.5rem}.leave-btn:hover{background:#555}.split-warning{background:#dc2626;color:#fff;padding:1rem;border-radius:8px;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem;animation:pulse 2s ease-in-out infinite}.split-warning.hidden{display:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.content-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}@media(max-width:1200px){.content-grid{grid-template-columns:1fr}}.chat-container{display:flex;flex-direction:column;min-height:500px}.graph-container{display:flex;flex-direction:column;background:#1a1a1a;border:1px solid #333;border-radius:12px;overflow:hidden}.graph-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #333;background:#242424}.graph-header h3{margin:0;font-size:1rem;color:#888}.toggle-btn{background:#444;border:none;padding:.5rem 1rem;border-radius:6px;color:#e5e5e5;font-size:.85rem;cursor:pointer;transition:background .2s}.toggle-btn:hover{background:#555}.network-graph{flex:1;min-height:500px;position:relative}.mesh-viz{margin-bottom:1rem}.mesh-viz h3{font-size:1rem;margin:0 0 .75rem;color:#888}.mesh-display{background:#1a1a1a;border:1px solid #333;border-radius:8px;padding:1rem;font-family:Courier New,monospace;font-size:.85rem;min-height:60px;max-height:200px;overflow-y:auto}.mesh-node{padding:.4rem 0;color:#888;white-space:nowrap;line-height:1.4}.mesh-node.me{color:#4ade80;font-weight:700}.info{background:#242424;border:1px solid #333;border-radius:12px;padding:1rem;font-size:.9rem}.info p{margin:.5rem 0}.info code{background:#1a1a1a;padding:.25rem .5rem;border-radius:4px;font-family:Courier New,monospace;font-size:.85rem;color:#4ade80}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#f5f5f5}.section,.info{background:#fff;border-color:#e5e5e5}input[type=text]{background:#fafafa;border-color:#ddd}.messages,.mesh-display{background:#fafafa;border-color:#e5e5e5}.mesh-node{color:#666}.mesh-node.me{color:#059669}.message.peer .message-content{background:#e5e5e5;color:#213547}.info code{background:#f5f5f5}.leave-btn{background:#e5e5e5;color:#213547}.leave-btn:hover{background:#d5d5d5}}@media(max-width:640px){#app{padding:1rem}h1{font-size:2rem}.messages{height:300px}.message{max-width:90%}}
