*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}#root{width:100%;max-width:600px}.app-container{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;padding:32px}h1{color:#333;margin-bottom:8px;font-size:28px}.subtitle{color:#666;margin-bottom:24px;font-size:14px}.form-group{margin-bottom:20px}label{display:block;margin-bottom:8px;color:#333;font-weight:500;font-size:14px}input[type=text],select{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .2s}input[type=text]:focus,select:focus{outline:none;border-color:#667eea}select{cursor:pointer;background:#fff}.button{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.button:disabled{opacity:.6;cursor:not-allowed}.button-danger{background:linear-gradient(135deg,#f093fb,#f5576c)}.status{padding:12px;border-radius:8px;margin-bottom:20px;font-size:14px;display:flex;align-items:center;gap:8px}.status-connected{background:#d4edda;color:#155724}.status-disconnected{background:#f8d7da;color:#721c24}.status-connecting{background:#fff3cd;color:#856404}.status-indicator{width:10px;height:10px;border-radius:50%;background:currentColor}.participants-list{margin-top:24px}.participants-list h3{color:#333;margin-bottom:12px;font-size:18px}.participant-item{padding:12px;background:#f8f9fa;border-radius:8px;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center}.participant-name{font-weight:500;color:#333}.participant-lang{font-size:12px;color:#666;margin-top:4px}.empty-state{text-align:center;color:#999;padding:20px;font-size:14px}.error{background:#f8d7da;color:#721c24;padding:12px;border-radius:8px;margin-bottom:20px;font-size:14px}
