*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px}.container{max-width:1400px;margin:0 auto}header{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:20px 30px;border-radius:10px;margin-bottom:20px;box-shadow:0 4px 6px #0000001a}h1{color:#667eea;font-size:28px}.status{padding:8px 16px;border-radius:20px;font-weight:600;font-size:14px}.status.connected{background:#10b981;color:#fff}.status.disconnected{background:#ef4444;color:#fff}.section{background:#fff;padding:30px;border-radius:10px;box-shadow:0 4px 6px #0000001a}.hidden{display:none!important}#login-section{max-width:500px;margin:0 auto}#login-section h2{color:#333;margin-bottom:25px;text-align:center}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#555;font-weight:600}.form-group input{width:100%;padding:12px;border:2px solid #e5e7eb;border-radius:6px;font-size:16px;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#667eea}.btn{padding:12px 24px;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;display:inline-flex;align-items:center;gap:8px}.btn-primary{background:#667eea;color:#fff;width:100%}.btn-primary:hover{background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 8px #667eea4d}.btn-control{background:#10b981;color:#fff}.btn-control:hover{background:#059669}.btn-control.disabled{background:#6b7280;opacity:.6}.btn-control.recording{background:#ef4444;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}.controls{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}.video-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-bottom:20px}.video-container{position:relative;background:#000;border-radius:10px;overflow:hidden;aspect-ratio:16/9;box-shadow:0 4px 6px #0000001a}.video-container video{width:100%;height:100%;object-fit:cover}.video-label{position:absolute;bottom:10px;left:10px;background:#000000b3;color:#fff;padding:6px 12px;border-radius:4px;font-size:14px;font-weight:600}.participants-info{text-align:center;padding:15px;background:#f3f4f6;border-radius:8px}.participants-info h3{color:#333;font-size:18px}.participants-info span{color:#667eea}.icon{font-size:18px}.main-content{display:flex;gap:20px;margin-top:20px}.video-section{flex:2;min-width:0}.chat-section{flex:1;min-width:300px;max-width:400px;display:flex!important;flex-direction:column;background:#f9fafb;border-radius:8px;border:3px solid red;overflow:hidden}.chat-header{background:#667eea;color:#fff;padding:15px;text-align:center}.chat-header h3{margin:0;font-size:16px;font-weight:600}.chat-messages{flex:1;overflow-y:auto;padding:15px;display:flex;flex-direction:column;gap:10px;max-height:500px;min-height:300px}.chat-message{padding:10px 12px;border-radius:8px;max-width:85%;word-wrap:break-word;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message.sent{background:#667eea;color:#fff;align-self:flex-end;margin-left:auto}.chat-message.received{background:#e5e7eb;color:#333;align-self:flex-start}.chat-message.system{background:#fef3c7;color:#92400e;align-self:center;font-size:13px;font-style:italic;text-align:center;max-width:100%}.message-sender{font-weight:600;font-size:12px;margin-bottom:4px;display:block}.message-text{font-size:14px;line-height:1.4}.message-time{font-size:11px;opacity:.7;margin-top:4px;display:block}.chat-input-container{display:flex;gap:8px;padding:15px;background:#fff;border-top:1px solid #e5e7eb}#chat-input{flex:1;padding:10px 12px;border:2px solid #e5e7eb;border-radius:6px;font-size:14px;transition:border-color .3s}#chat-input:focus{outline:none;border-color:#667eea}#send-message{padding:10px 20px;white-space:nowrap}@media (max-width: 1024px){.main-content{flex-direction:column}.chat-section{max-width:100%;min-height:400px}}@media (max-width: 768px){header{flex-direction:column;gap:15px;text-align:center}.controls{justify-content:center;flex-wrap:wrap}.video-grid{grid-template-columns:1fr}.chat-messages{min-height:250px}}.chat-header{display:flex;justify-content:space-between;align-items:center}.chat-mode-badge{font-size:.7rem;padding:3px 8px;border-radius:12px;font-weight:600;text-transform:uppercase}.chat-mode-badge.persistent{background:linear-gradient(135deg,#00d4aa,#00b894);color:#fff}.chat-mode-badge.realtime{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.matrix-badge{font-size:.6rem;background:#00d4aa;color:#fff;padding:2px 6px;border-radius:8px;margin-left:8px;font-weight:600}.livekit-badge{font-size:.6rem;background:#667eea;color:#fff;padding:2px 6px;border-radius:8px;margin-left:8px;font-weight:600}.chat-message.history{opacity:.8}.chat-message.history .message-text{font-style:italic}.chat-message.system .message-text{font-size:.8rem;color:#888}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal.hidden{display:none!important}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:400px;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e5e7eb}.modal-header h3{margin:0;color:#333;font-size:18px}.btn-close{background:none;border:none;font-size:24px;color:#666;cursor:pointer;padding:0;line-height:1}.btn-close:hover{color:#333}.modal-body{padding:20px}.modal-body .form-group{margin-bottom:15px}.dial-hint{font-size:13px;color:#666;margin-top:10px}.modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:15px 20px;border-top:1px solid #e5e7eb;background:#f9fafb;border-radius:0 0 12px 12px}.btn-secondary{background:#6b7280;color:#fff}.btn-secondary:hover{background:#4b5563}.btn-control.calling{background:#f59e0b;animation:pulse 1.5s infinite}
