*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0d1117;--surface: #161b22;--surface2: #21262d;--border: #30363d;--accent: #58a6ff;--accent2: #3fb950;--danger: #f85149;--text: #e6edf3;--text-muted:#8b949e;--radius: 10px;--shadow: 0 4px 24px rgba(0,0,0,.45);--transition: .18s ease}body{background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,sans-serif;min-height:100vh;display:flex;align-items:flex-start;justify-content:center;padding:2rem 1rem}.app{width:100%;max-width:760px;display:flex;flex-direction:column;gap:.75rem}h1{font-size:1.8rem;font-weight:700;letter-spacing:-.5px;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{font-size:.75rem;color:var(--text-muted);margin-top:-.4rem}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.85rem 1rem;display:flex;flex-direction:column;gap:.5rem;box-shadow:var(--shadow)}.panel.row{flex-direction:row;align-items:center;gap:.5rem;flex-wrap:wrap}input{background:var(--surface2);border:1px solid var(--border);border-radius:6px;color:var(--text);padding:.5rem .75rem;font-size:.9rem;outline:none;transition:border-color var(--transition),box-shadow var(--transition);width:100%}input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #58a6ff26}label{font-size:.8rem;color:var(--text-muted);font-weight:500}.hint{font-weight:400;font-style:italic}button{padding:.5rem 1.1rem;border-radius:6px;border:none;font-size:.88rem;font-weight:600;cursor:pointer;transition:background var(--transition),transform var(--transition),box-shadow var(--transition);white-space:nowrap}button:active{transform:scale(.97)}button:disabled{opacity:.45;cursor:not-allowed}button:not(.secondary):not(.btn-video):not(.btn-call):not(.btn-end):not(.btn-secondary){background:var(--accent);color:#fff}button:not(.secondary):not(.btn-video):not(.btn-call):not(.btn-end):not(.btn-secondary):hover{background:#79baff;box-shadow:0 0 12px #58a6ff59}.secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.secondary:hover{background:var(--border)}.btn-video{background:#6e40c9;color:#fff}.btn-video:hover{background:#8a5cf7;box-shadow:0 0 12px #6e40c966}.btn-call{background:var(--accent2);color:#fff}.btn-call:hover{background:#56d364}.btn-end{background:var(--danger);color:#fff}.btn-end:hover{background:#ff6b63}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.toolbar{flex-wrap:nowrap}.messages{min-height:320px;max-height:480px;overflow-y:auto;gap:.4rem;padding:.75rem 1rem;scroll-behavior:smooth}.messages::-webkit-scrollbar{width:5px}.messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}.msg{display:flex;align-items:baseline;gap:.5rem;padding:.4rem .6rem;border-radius:8px;max-width:78%;animation:popIn .15s ease;position:relative}@keyframes popIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.msg-own{background:linear-gradient(135deg,#58a6ff2e,#3fb9501a);border:1px solid rgba(88,166,255,.2);margin-left:auto;flex-direction:row-reverse}.msg-other{background:var(--surface2);border:1px solid var(--border)}.who{font-size:.72rem;font-weight:700;color:var(--accent);flex-shrink:0}.msg-own .who{color:var(--accent2)}.content{font-size:.92rem;word-break:break-word}.tick{font-size:.65rem;margin-left:4px;flex-shrink:0;color:var(--text-muted);transition:color .3s}.tick-delivered{color:#8b949e}.tick-read{color:#58a6ff}.status{font-size:.78rem;color:var(--text-muted);padding:.3rem .5rem;background:var(--surface);border:1px solid var(--border);border-radius:6px;text-align:center;min-height:2rem;display:flex;align-items:center;justify-content:center}.video-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.video-modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:1.5rem;width:min(680px,96vw);box-shadow:0 24px 80px #0009;display:flex;flex-direction:column;gap:1rem}.video-header{display:flex;align-items:center;justify-content:space-between;font-weight:700;font-size:1rem}.call-state{font-size:.8rem;padding:.25rem .6rem;border-radius:99px}.call-state--connected{background:#3fb95033;color:var(--accent2)}.call-state--calling{background:#58a6ff33;color:var(--accent)}.call-state--incoming{background:#f8514933;color:var(--danger);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.video-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.video-box{position:relative;background:#000;border-radius:10px;overflow:hidden;aspect-ratio:4/3}.video-box video{width:100%;height:100%;object-fit:cover}.video-label{position:absolute;bottom:6px;left:8px;font-size:.72rem;color:#fffc;background:#00000080;padding:2px 6px;border-radius:4px}.video-controls{display:flex;gap:.6rem;justify-content:center}@media(max-width:500px){.video-grid{grid-template-columns:1fr}.msg{max-width:90%}}
