*{margin:0;padding:0}html,body,#root{height:100%}:root{--bg:#0f1117;--surface:#1a1d27;--surface-2:#252936;--border:#2e3345;--text:#e8eaef;--text-muted:#8b92a8;--accent:#6c5ce7;--accent-hover:#5b4cdb;--success:#00b894;--danger:#e17055;--own-bg:#2d3561;--radius:12px}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);min-height:100vh;margin:0;font-family:Segoe UI,system-ui,-apple-system,sans-serif}#root{min-height:100vh}.login-screen{background:radial-gradient(ellipse at top, #1e2240 0%, var(--bg) 60%);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:20px;width:100%;max-width:400px;padding:2.5rem 2rem}.logo{margin-bottom:.5rem;font-size:3rem}.login-card h1{margin:0 0 .25rem;font-size:2rem;font-weight:700}.subtitle{color:var(--text-muted);margin:0 0 2rem;font-size:.95rem}.login-card form{text-align:left;flex-direction:column;gap:1rem;display:flex}.login-card label{color:var(--text-muted);flex-direction:column;gap:.4rem;font-size:.85rem;display:flex}.login-card input{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-2);color:var(--text);padding:.75rem 1rem;font-size:1rem}.login-card input:focus{outline:2px solid var(--accent);border-color:#0000}.btn-primary{background:var(--accent);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;margin-top:.5rem;padding:.85rem;font-size:1rem;font-weight:600;transition:background .2s}.btn-primary:hover{background:var(--accent-hover)}.chat-app{flex-direction:column;max-width:1200px;height:100vh;margin:0 auto;display:flex}.chat-header{border-bottom:1px solid var(--border);background:var(--surface);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.header-actions{align-items:center;gap:.5rem;display:flex}.btn-users-toggle{background:var(--surface-2);border:1px solid var(--border);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:8px;padding:.5rem .85rem;font-size:.85rem}.btn-users-toggle:hover{border-color:var(--accent);color:var(--accent)}.chat-header h1{margin:0;font-size:1.25rem}.status{color:var(--text-muted);font-size:.8rem}.status.online{color:var(--success)}.btn-leave{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;padding:.5rem 1rem}.btn-leave:hover{border-color:var(--danger);color:var(--danger)}.chat-body{flex:1;display:flex;overflow:hidden}.user-list{border-right:1px solid var(--border);background:var(--surface);flex-shrink:0;width:220px;padding:1rem;overflow-y:auto}.user-list-top{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.user-list h3{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin:0;font-size:.85rem}.user-list-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:.25rem;font-size:1.1rem;display:none}.user-list ul{margin:0;padding:0;list-style:none}.user-list li{align-items:center;gap:.5rem;padding:.5rem 0;font-size:.9rem;display:flex}.user-list li.self .user-name{color:var(--accent)}.user-dot{background:var(--success);border-radius:50%;flex-shrink:0;width:8px;height:8px}.user-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.btn-call-small{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:6px;flex-shrink:0;padding:.35rem .55rem;font-size:.7rem;font-weight:600}.btn-call-small:hover:not(:disabled){background:var(--accent-hover)}.btn-call-small:disabled{opacity:.4;cursor:not-allowed}.call-bar{border-radius:var(--radius);background:linear-gradient(135deg,#2d3561 0%,#1e2240 100%);border:1px solid #3d4a7a;margin:.75rem 1.25rem 0;padding:.85rem 1rem}.call-bar-header{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.call-bar-icon{font-size:1.25rem}.call-bar-title{font-size:.95rem;font-weight:700}.call-bar-count{color:var(--text-muted);background:var(--surface-2);border-radius:999px;margin-left:auto;padding:.2rem .5rem;font-size:.75rem}.call-bar-hint{color:var(--text-muted);margin:0;font-size:.8rem;line-height:1.45}.call-bar-actions{flex-wrap:wrap;gap:.5rem;display:flex}.btn-video-call{background:var(--success);color:#fff;cursor:pointer;border:none;border-radius:8px;align-items:center;gap:.4rem;padding:.55rem 1rem;font-size:.9rem;font-weight:600;transition:filter .2s,transform .1s;display:inline-flex}.btn-video-call:hover:not(:disabled){filter:brightness(1.1)}.btn-video-call:active:not(:disabled){transform:scale(.98)}.btn-video-call:disabled{opacity:.5;cursor:not-allowed}.btn-video-call-icon{font-size:1rem}.user-hint{color:var(--text-muted);margin-top:1rem;font-size:.75rem;line-height:1.4}.chat-main{flex-direction:column;flex:1;min-width:0;display:flex}.message-list{flex-direction:column;flex:1;gap:.75rem;padding:1rem 1.25rem;display:flex;overflow-y:auto}.message{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);max-width:75%;padding:.65rem 1rem}.message.own{background:var(--own-bg);border-color:#3d4a7a;align-self:flex-end}.message.system{max-width:100%;color:var(--text-muted);background:0 0;border:none;align-self:center;padding:.25rem;font-size:.8rem}.message-author{color:var(--accent);margin-bottom:.25rem;font-size:.75rem;font-weight:600;display:block}.message.own .message-author{color:#a29bfe}.message-text{word-break:break-word;margin:0;line-height:1.45}.message-media{border-radius:8px;max-width:100%;max-height:280px;margin-top:.5rem;display:block}.message-time{color:var(--text-muted);text-align:right;margin-top:.35rem;font-size:.65rem;display:block}.typing-indicator{color:var(--text-muted);margin:0;padding:0 1.25rem .25rem;font-size:.8rem;font-style:italic}.message-input{border-top:1px solid var(--border);background:var(--surface);gap:.5rem;padding:1rem 1.25rem;display:flex}.message-input input[type=text]{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-2);color:var(--text);flex:1;padding:.75rem 1rem;font-size:.95rem}.message-input input:focus{outline:2px solid var(--accent)}.btn-icon{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;width:44px;font-size:1.1rem}.btn-send{background:var(--accent);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;padding:0 1.25rem;font-weight:600}.btn-send:disabled{opacity:.5;cursor:not-allowed}.video-call-overlay{z-index:100;background:#000000d9;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.video-call-overlay.video-call-fullscreen{background:#000;padding:0}.video-call-panel{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;max-width:900px;overflow:hidden}.video-call-panel.video-call-panel-fullscreen{background:#000;border:none;border-radius:0;width:100%;max-width:none;height:100%;position:fixed;inset:0}.call-banner{text-align:center;background:var(--surface-2);padding:1.25rem}.call-banner.incoming{border-bottom:1px solid var(--border)}.call-banner-overlay{z-index:10;background:linear-gradient(#000000bf,#0000);border:none;padding:1.5rem 1rem 2.5rem;position:absolute;top:0;left:0;right:0}.call-banner-overlay p{color:#fff;margin-bottom:.75rem}.call-banner p{margin:0 0 1rem}.call-actions{justify-content:center;gap:1rem;display:flex}.btn-accept{background:var(--success);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.65rem 1.5rem;font-weight:600}.btn-reject,.btn-end{background:var(--danger);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.65rem 1.5rem;font-weight:600}.video-grid{background:#000;width:100%;height:100%;position:absolute;inset:0}.video-remote{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.video-remote.video-placeholder{width:100%;height:100%;position:absolute;inset:0}.video-local{object-fit:cover;z-index:5;background:#000;border:2px solid #ffffff59;border-radius:12px;width:min(140px,28vw);height:min(186px,37vw);max-height:28vh;position:absolute;bottom:5.5rem;right:1rem;box-shadow:0 4px 24px #0009}.video-placeholder{color:var(--text-muted);background:#111;justify-content:center;align-items:center;font-size:.85rem;display:flex}.video-local.video-placeholder{z-index:5;border-radius:12px;width:min(140px,28vw);height:min(186px,37vw);max-height:28vh;bottom:5.5rem;right:1rem}.video-hidden{opacity:0;pointer-events:none}.call-controls{background:var(--surface-2);justify-content:center;gap:1rem;padding:1rem;display:flex}.call-controls-overlay{z-index:10;padding:1.25rem 1rem max(1.25rem, env(safe-area-inset-bottom));background:linear-gradient(#0000,#000000d9);border:none;position:absolute;bottom:0;left:0;right:0}.call-controls button{color:#fff;cursor:pointer;background:#1e1e28e6;border:1px solid #fff3;border-radius:50%;width:52px;height:52px;font-size:1.25rem}.call-controls-overlay button:hover{background:#323241f2}.call-controls .btn-end{background:var(--danger);border-color:#0000;border-radius:26px;width:auto;padding:0 1.5rem;font-size:.9rem;font-weight:600}@media (width<=768px){.user-list{z-index:50;width:min(280px,85vw);transition:transform .25s;position:fixed;top:0;bottom:0;left:0;transform:translate(-110%);box-shadow:4px 0 24px #0006}.user-list.open{transform:translate(0)}.user-list-close{display:block}.sidebar-backdrop{z-index:40;cursor:pointer;background:#00000080;border:none;position:fixed;inset:0}.message{max-width:90%}.call-bar-actions{flex-direction:column}.btn-video-call{justify-content:center;width:100%}}
