:root{--bg-darkest:#1e1f22;--bg-dark:#2b2d31;--bg-mid:#313338;--bg-light:#383a40;--accent:#5865f2;--accent-hover:#4752c4;--text:#dbdee1;--text-muted:#949ba4;--green:#23a55a;--red:#f23f43;--border:#1f2023}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg-mid);color:var(--text);font-family:gg sans,Segoe UI,system-ui,-apple-system,sans-serif;font-size:15px}button{cursor:pointer;font-family:inherit}input{font-family:inherit}.centered{flex-direction:column;justify-content:center;align-items:center;height:100%;display:flex}.muted{color:var(--text-muted)}.error{color:var(--red);margin:4px 0;font-size:13px}.link{color:var(--accent);background:0 0;border:none;padding:0;font-size:13px}.link:hover{text-decoration:underline}.auth-card{background:var(--bg-mid);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:6px;width:380px;padding:28px;display:flex;box-shadow:0 8px 24px #0006}.brand{text-align:center;color:#fff;letter-spacing:-.5px;margin:0;font-size:28px}.auth-card label{text-transform:uppercase;color:var(--text-muted);margin-top:12px;font-size:12px;font-weight:700}.auth-card input,.modal input,.inline-add input{background:var(--bg-darkest);border:1px solid var(--border);color:var(--text);border-radius:4px;padding:10px;font-size:15px}.auth-card input:focus,.modal input:focus{border-color:var(--accent);outline:none}.auth-card button[type=submit],.modal-actions button:last-child,.composer button,.inline-add button{background:var(--accent);color:#fff;border:none;border-radius:4px;margin-top:12px;padding:10px;font-weight:600}.auth-card button[type=submit]:hover{background:var(--accent-hover)}button:disabled{opacity:.5;cursor:not-allowed}.app{grid-template-columns:72px 240px 1fr;height:100%;display:grid}.guild-bar{background:var(--bg-darkest);flex-direction:column;align-items:center;gap:8px;padding:12px 0;display:flex;overflow-y:auto}.guild-pill{background:var(--bg-dark);width:48px;height:48px;color:var(--text);border:none;border-radius:24px;font-size:15px;font-weight:700;transition:border-radius .15s,background .15s}.guild-pill:hover,.guild-pill.active{background:var(--accent);color:#fff;border-radius:16px}.guild-pill.add{color:var(--green);font-size:24px}.guild-pill.add:hover{background:var(--green);color:#fff}.channel-bar{background:var(--bg-dark);flex-direction:column;min-height:0;display:flex}.channel-header{border-bottom:1px solid var(--border);flex-direction:column;gap:2px;padding:14px 16px;display:flex;box-shadow:0 1px #0003}.guild-name{color:#fff;font-weight:700}.guild-id{color:var(--text-muted);-webkit-user-select:all;user-select:all;font-size:11px}.channel-scroll{flex:1;padding:8px;overflow-y:auto}.section{margin-top:12px}.section-header{text-transform:uppercase;color:var(--text-muted);justify-content:space-between;align-items:center;padding:4px 8px;font-size:12px;font-weight:700;display:flex}.add-channel{color:var(--text-muted);background:0 0;border:none;font-size:18px;line-height:1}.add-channel:hover{color:#fff}.channel{text-align:left;width:100%;color:var(--text-muted);background:0 0;border:none;border-radius:4px;align-items:center;gap:6px;padding:8px;font-size:15px;display:flex}.channel:hover{background:var(--bg-light);color:var(--text)}.channel.active{background:var(--bg-light);color:#fff}.channel .hash,.channel .speaker{opacity:.6}.channel .badge{color:var(--green);text-transform:uppercase;margin-left:auto;font-size:10px;font-weight:700}.inline-add{gap:4px;padding:8px;display:flex}.inline-add input{flex:1;padding:6px}.inline-add button{margin:0;padding:6px 10px}.user-footer{background:var(--bg-darkest);align-items:center;gap:8px;padding:8px 12px;display:flex}.avatar{background:var(--accent);color:#fff;border-radius:16px;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:700;display:flex}.username{flex:1;font-size:14px;font-weight:600}.logout{color:var(--text-muted);font-size:18px}.main-panel{background:var(--bg-mid);flex-direction:column;min-height:0;display:flex}.chat{flex-direction:column;flex:1;min-height:0;display:flex}.chat-header{border-bottom:1px solid var(--border);color:#fff;padding:14px 16px;font-weight:700;box-shadow:0 1px #0003}.chat-header .hash{opacity:.5}.messages{flex-direction:column;flex:1;gap:2px;padding:16px;display:flex;overflow-y:auto}.empty{margin:auto}.message{padding:2px 0}.message.grouped{padding-left:0}.message-meta{align-items:baseline;gap:8px;margin-top:12px;display:flex}.author{color:#f2f3f5;font-weight:600}.author.me{color:var(--accent)}.ts{color:var(--text-muted);font-size:11px}.content{color:var(--text);white-space:pre-wrap;word-break:break-word;line-height:1.4}.composer{gap:8px;padding:16px;display:flex}.composer input{background:var(--bg-light);color:var(--text);border:none;border-radius:8px;flex:1;padding:12px;font-size:15px}.composer input:focus{outline:none}.composer button{margin:0;padding:0 18px}.voice-panel{border-top:1px solid var(--border);background:var(--bg-darkest);flex-direction:column;max-height:55%;display:flex}.voice-bar{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:10px 14px;display:flex}.voice-title{color:var(--green);font-weight:700}.spacer{flex:1}.vc-btn{background:var(--bg-light);color:var(--text);border:none;border-radius:6px;padding:8px 12px;font-size:13px;font-weight:600}.vc-btn:hover{background:#4a4d54}.vc-btn.on{background:var(--green);color:#fff}.vc-btn.off,.vc-btn.leave{background:var(--red);color:#fff}.voice-stage{flex-wrap:wrap;flex:1;align-content:flex-start;gap:12px;padding:16px;display:flex;overflow-y:auto}.tile{background:#000;border-radius:8px;width:320px;height:180px;position:relative;overflow:hidden}.tile video{object-fit:contain;background:#000;width:100%;height:100%}.tile video.mirror{transform:scaleX(-1)}.tile-label{background:#000000b3;border-radius:4px;padding:2px 8px;font-size:12px;font-weight:600;position:absolute;bottom:8px;left:8px}.voice-empty{text-align:center;flex-direction:column;gap:16px;margin:auto;display:flex}.roster{flex-wrap:wrap;justify-content:center;gap:16px;display:flex}.roster-chip{flex-direction:column;align-items:center;gap:6px;display:flex}.roster-chip .avatar{border-radius:28px;width:56px;height:56px;font-size:22px}.modal-backdrop{z-index:100;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-mid);border-radius:8px;flex-direction:column;gap:8px;width:360px;padding:24px;display:flex}.modal label{text-transform:uppercase;color:var(--text-muted);font-size:12px;font-weight:700}.tabs{gap:8px;margin-bottom:8px;display:flex}.tabs button{background:var(--bg-darkest);color:var(--text-muted);border:none;border-radius:4px;flex:1;padding:8px;font-weight:600}.tabs button.active{background:var(--accent);color:#fff}.modal-actions{justify-content:flex-end;align-items:center;gap:12px;margin-top:8px;display:flex}.modal-actions button:last-child{margin:0;padding:8px 16px}
