:root{--bg: #f1f4f9;--panel: #ffffff;--panel2: #f3f6fb;--line: #e3e8ef;--line2: #eef1f6;--text: #1f2733;--muted: #647089;--accent: #1a73e8;--accent-d: #1667d0;--danger: #d93025;--ok: #1e8e3e;--warn: #e37400;--radius: 16px;--shadow: 0 1px 2px rgba(20,30,50,.06), 0 6px 24px rgba(20,30,50,.08);--shadow-sm: 0 1px 3px rgba(20,30,50,.1)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}a,button,.item,.iconbtn,.tabs button{outline:none}a:focus:not(:focus-visible),button:focus:not(:focus-visible),.item:focus:not(:focus-visible),.iconbtn:focus:not(:focus-visible){outline:none;box-shadow:none}a:focus-visible,button:focus-visible{outline:2px solid rgba(26,115,232,.5);outline-offset:2px}html,body,#root{height:100%;margin:0}body{font-family:Roboto,system-ui,-apple-system,Segoe UI,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.material-symbols-rounded{font-family:Material Symbols Rounded;font-weight:400;font-style:normal;line-height:1;letter-spacing:normal;text-transform:none;white-space:nowrap;direction:ltr;-webkit-font-smoothing:antialiased;font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24;vertical-align:middle;-webkit-user-select:none;user-select:none}.fill{font-variation-settings:"FILL" 1,"wght" 500,"GRAD" 0,"opsz" 24}button{font:inherit;font-weight:600;cursor:pointer;border:none;border-radius:999px;padding:.65rem 1.25rem;background:var(--accent);color:#fff;display:inline-flex;align-items:center;justify-content:center;gap:.4rem;transition:background .15s ease,box-shadow .15s ease,transform .05s ease}button:hover{background:var(--accent-d);box-shadow:var(--shadow-sm)}button:active{transform:translateY(1px)}button.secondary{background:var(--panel2);color:var(--text);border:1px solid var(--line)}button.secondary:hover{background:#e8edf5}button.ghost{background:transparent;color:var(--muted);box-shadow:none}button.ghost:hover{background:var(--panel2)}button.danger{background:var(--danger);color:#fff}button.danger:hover{background:#b5271d}button:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}input,textarea{font:inherit;width:100%;background:#fff;color:var(--text);border:1px solid var(--line);border-radius:12px;padding:.7rem .9rem;outline:none;transition:border-color .15s ease,box-shadow .15s ease}input:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1a73e826}input[type=file]{padding:.5rem;background:var(--panel2)}.badge{display:inline-flex;align-items:center;gap:.25rem;font-size:.72rem;font-weight:600;padding:.18rem .55rem;border-radius:999px;background:#1e8e3e1f;color:var(--ok)}.badge .material-symbols-rounded{font-size:14px}.badge.pending{background:#e374001f;color:var(--warn)}.badge.none{background:#6470891f;color:var(--muted)}.center{min-height:100%;display:grid;place-items:center;padding:1.2rem}.card{width:100%;max-width:420px;background:var(--panel);border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);padding:2rem}.brand{display:flex;align-items:center;gap:.6rem;margin-bottom:.4rem}.brand .logo{width:44px;height:44px;border-radius:13px;background:linear-gradient(135deg,var(--accent),#34a0f0);color:#fff;display:grid;place-items:center}.brand .logo .material-symbols-rounded{font-size:26px}.brand h1{font-size:1.5rem;margin:0;letter-spacing:-.01em;font-weight:700}.sub{color:var(--muted);margin:.3rem 0 1.5rem;font-size:.95rem;line-height:1.45}.stack{display:flex;flex-direction:column;gap:.8rem}.row{display:flex;gap:.6rem;align-items:center}.divider{display:flex;align-items:center;gap:.8rem;color:var(--muted);font-size:.78rem;margin:.2rem 0}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--line)}.err{color:var(--danger);font-size:.88rem}.okmsg{color:var(--ok);font-size:.88rem}.hint{color:var(--muted);font-size:.82rem;line-height:1.45}label.hint{display:flex;flex-direction:column;gap:.3rem}.shell{display:grid;grid-template-columns:340px 1fr;height:100%;background:var(--bg)}.sidebar{border-right:1px solid var(--line);background:var(--panel);display:flex;flex-direction:column;min-height:0}.side-head{padding:1rem 1.1rem .5rem;display:flex;align-items:center;justify-content:space-between}.side-head .brand h1{font-size:1.2rem}.tabs{display:flex;gap:.35rem;padding:0 .9rem .7rem}.tabs button{flex:1;background:transparent;color:var(--muted);border-radius:10px;padding:.5rem;font-weight:600;box-shadow:none}.tabs button:hover{background:var(--panel2)}.tabs button.active{background:#1a73e81a;color:var(--accent)}.list{overflow-y:auto;flex:1;min-height:0;padding:.4rem}.item{display:flex;gap:.75rem;align-items:center;padding:.6rem .7rem;border-radius:14px;cursor:pointer;transition:background .12s ease}.item:hover{background:var(--panel2)}.item.active{background:#1a73e817}.avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;background:linear-gradient(135deg,#e8eef7,#dbe6f5);display:grid;place-items:center;font-weight:700;color:var(--accent);flex:none;position:relative;overflow:visible}.avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.avatar .dot{position:absolute;right:-1px;bottom:-1px;width:12px;height:12px;border-radius:50%;background:#c3ccda;border:2px solid var(--panel)}.avatar .dot.online{background:var(--ok)}.item .meta{min-width:0;flex:1}.item .meta .name{font-weight:600;display:flex;align-items:center;gap:.4rem}.item .meta .call{color:var(--accent);font-size:.78rem;font-weight:700}.item .meta .snippet{color:var(--muted);font-size:.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unread{background:var(--accent);color:#fff;border-radius:999px;font-size:.72rem;font-weight:700;min-width:20px;height:20px;padding:0 .35rem;display:grid;place-items:center}.side-foot{border-top:1px solid var(--line);padding:.7rem;display:flex;align-items:center;gap:.6rem}.side-foot .meta{flex:1;min-width:0}.side-foot .name{font-weight:600;font-size:.9rem}.side-foot .call{color:var(--accent);font-size:.76rem;font-weight:700;display:flex;align-items:center;gap:.3rem}.main{display:flex;flex-direction:column;min-width:0;min-height:0;background:var(--bg)}.chat-head{display:flex;align-items:center;gap:.8rem;padding:.7rem 1rem;border-bottom:1px solid var(--line);background:var(--panel)}.chat-head .meta{flex:1;min-width:0}.chat-head .name{font-weight:700}.chat-head .call{color:var(--accent);font-size:.8rem;font-weight:700}.chat-head .actions{display:flex;gap:.5rem}.iconbtn{width:44px;height:44px;padding:0;border-radius:50%;background:var(--panel2);border:1px solid var(--line);color:var(--text);display:grid;place-items:center;box-shadow:none}.iconbtn:hover{background:#e8edf5}.iconbtn .material-symbols-rounded{font-size:22px}.iconbtn.call{background:#1e8e3e1f;color:var(--ok);border-color:#1e8e3e40}.iconbtn.call:hover{background:#1e8e3e33}.msgs{flex:1;overflow-y:auto;padding:1.2rem;display:flex;flex-direction:column;gap:.35rem}.bubble{max-width:min(72%,520px);padding:.55rem .85rem;border-radius:18px;line-height:1.4;word-wrap:break-word;font-size:.95rem;box-shadow:var(--shadow-sm)}.bubble.me{align-self:flex-end;background:var(--accent);color:#fff;border-bottom-right-radius:5px}.bubble.them{align-self:flex-start;background:var(--panel);border:1px solid var(--line);border-bottom-left-radius:5px}.bubble .time{display:block;font-size:.66rem;opacity:.7;margin-top:.18rem;text-align:right}.composer{display:flex;gap:.6rem;padding:.8rem;border-top:1px solid var(--line);background:var(--panel)}.composer .iconbtn.send{background:var(--accent);color:#fff;border:none}.composer .iconbtn.send:hover{background:var(--accent-d)}.empty{flex:1;display:grid;place-items:center;color:var(--muted);text-align:center;padding:2rem}.empty .big{color:var(--accent);margin-bottom:.6rem}.empty .big .material-symbols-rounded{font-size:64px}.call-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f1928b8;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:50;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.3rem;padding:1rem}.videos{position:relative;width:min(100%,900px);aspect-ratio:16/10;background:#0d1826;border-radius:22px;overflow:hidden;box-shadow:var(--shadow)}.videos video.remote{width:100%;height:100%;object-fit:cover;background:#0d1826}.videos video.local{position:absolute;right:14px;bottom:14px;width:26%;max-width:220px;border-radius:14px;border:2px solid rgba(255,255,255,.6);object-fit:cover;background:#17273b;z-index:2}.call-status{position:absolute;top:16px;left:0;right:0;text-align:center;color:#fff;font-weight:600;text-shadow:0 1px 6px rgba(0,0,0,.5);z-index:3}.call-controls{display:flex;gap:1rem}.call-controls button{width:62px;height:62px;border-radius:50%;padding:0;box-shadow:var(--shadow)}.call-controls button .material-symbols-rounded{font-size:28px}.call-controls .hang{background:var(--danger);color:#fff}.call-controls .hang:hover{background:#b5271d}.call-controls .accept{background:var(--ok);color:#fff}.call-controls .accept:hover{background:#17742f}.call-controls .mute{background:#fff;color:var(--text)}.call-controls .mute.off{background:var(--text);color:#fff}.incoming{text-align:center;color:#fff}.incoming .who{font-size:1.35rem;font-weight:700;margin:.5rem 0 .2rem}.incoming .who .call{color:#8fc0ff}.bigavatar{width:116px;height:116px;border-radius:50%;margin:0 auto;display:grid;place-items:center;font-size:2.8rem;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--accent),#34a0f0);box-shadow:var(--shadow)}.toasts{position:fixed;top:16px;right:16px;display:flex;flex-direction:column;gap:.5rem;z-index:60}.toast{background:var(--panel);border:1px solid var(--line);border-left:3px solid var(--accent);padding:.7rem 1rem;border-radius:12px;box-shadow:var(--shadow);max-width:320px;display:flex;align-items:center;gap:.5rem;font-size:.9rem}.toast .material-symbols-rounded{color:var(--accent);font-size:20px}.admin-grid{display:grid;gap:.8rem;padding:1.2rem;overflow-y:auto}.admin-grid h2{font-weight:700}.pend-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:1.1rem;display:flex;flex-direction:column;gap:.7rem;box-shadow:var(--shadow-sm)}.backbtn{display:none}@media (max-width: 780px){.shell{grid-template-columns:1fr}.sidebar{display:var(--side-display, flex)}.main{display:var(--main-display, none)}.shell.viewing{--side-display: none;--main-display: flex}.shell.viewing .backbtn{display:grid;position:fixed;left:10px;top:10px;z-index:40;box-shadow:var(--shadow)}.bubble{max-width:82%}.card{padding:1.5rem}}
