*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;position:fixed;overflow:hidden}body{color:#e0e0e0;-webkit-user-select:none;user-select:none;background:#1a1a2e;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}#root{flex-direction:column;display:flex}.app{flex-direction:column;height:100%;display:flex;overflow:hidden}.header{text-align:center;background:#16213e;border-bottom:1px solid #0f3460;flex-shrink:0;justify-content:center;align-items:center;gap:12px;padding:10px 16px;display:flex}.header h1{color:#e94560;font-size:1.05rem;font-weight:600}.room-badge{cursor:pointer;color:#4ecca3;letter-spacing:2px;background:#0f3460;border:1px solid #533483;border-radius:6px;padding:2px 10px;font-family:monospace;font-size:.75rem;transition:background .2s}.provider-badge{color:#4ecca3;background:#4ecca326;border:1px solid #4ecca34d;border-radius:6px;padding:2px 8px;font-size:.65rem}.qr-btn{color:#4ecca3;cursor:pointer;background:0 0;border:1px solid #533483;border-radius:6px;padding:4px 10px;font-size:.7rem;font-weight:600}.leave-btn{color:#e94560;cursor:pointer;background:0 0;border:1px solid #533483;border-radius:6px;padding:4px 10px;font-size:.7rem}.qr-overlay{z-index:100;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.qr-card{background:#16213e;border:1px solid #533483;border-radius:16px;flex-direction:column;align-items:center;gap:12px;padding:28px;display:flex}.qr-room-code{letter-spacing:4px;color:#4ecca3;font-family:monospace;font-size:1.4rem}.qr-hint{color:#888;font-size:.8rem}.qr-close{color:#e0e0e0;cursor:pointer;background:#0f3460;border:1px solid #533483;border-radius:8px;margin-top:4px;padding:8px 24px;font-size:.85rem}.room-screen{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:24px;padding:24px;display:flex}.room-screen h2{color:#e94560;font-size:1.4rem;font-weight:600}.room-form{flex-direction:column;gap:14px;width:100%;max-width:340px;display:flex}.room-form label{color:#aaa;font-size:.85rem}.room-form input,.room-form select{color:#e0e0e0;background:#0f3460;border:1px solid #533483;border-radius:8px;outline:none;width:100%;padding:10px 14px;font-size:1rem}.room-form input::placeholder{color:#666}.room-form .btn-group{gap:10px;margin-top:6px;display:flex}.room-form button{cursor:pointer;border:none;border-radius:8px;flex:1;padding:12px;font-size:.95rem;font-weight:600;transition:background .2s}.btn-create{color:#fff;background:#e94560}.btn-create:hover{background:#c73a52}.btn-join{color:#fff;background:#533483}.btn-join:hover{background:#6b44a8}.qr-scanner-wrapper{border:2px solid #533483;border-radius:8px;width:100%;position:relative;overflow:hidden}.qr-scanner-wrapper #qr-reader{width:100%}.qr-stop-btn{color:#fff;cursor:pointer;z-index:10;background:#e94560e6;border:none;border-radius:6px;padding:6px 14px;font-size:.8rem;position:absolute;top:8px;right:8px}.divider{color:#555;text-align:center;font-size:.8rem}.error-msg{color:#e94560;text-align:center;font-size:.85rem}.chat-screen{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.partner-status{text-align:center;background:#16213e;border-bottom:1px solid #0f3460;flex-shrink:0;padding:8px 16px;font-size:.8rem}.partner-status.waiting{color:#888}.partner-status.connected{color:#4ecca3}.messages{flex-direction:column;flex:1;gap:10px;min-height:0;padding:12px 16px;display:flex;overflow-y:auto}.message{background:#0f34604d;border-radius:0 10px 10px 0;max-width:92%;padding:8px 12px}.message.sent{border-right:3px solid #533483;border-radius:10px 0 0 10px;align-self:flex-end}.message.received{border-left:3px solid #4ecca3;align-self:flex-start}.message.system{color:#666;text-align:center;background:0 0;border:none;align-self:center;padding:4px 0;font-size:.75rem;font-style:italic}.message .original{color:#e0e0e0;-webkit-user-select:text;user-select:text;font-size:.95rem;line-height:1.4}.message .translated{color:#4ecca3;-webkit-user-select:text;user-select:text;border-top:1px solid #5334834d;margin-top:4px;padding-top:4px;font-size:.95rem;line-height:1.4}.message.sent .translated{color:#b8a9d4}.message .speaker-name{color:#888;margin-bottom:2px;font-size:.7rem}.message.incoming{opacity:.6}.typing-dots{gap:4px;padding:4px 0;display:flex}.typing-dots span{background:#4ecca3;border-radius:50%;width:8px;height:8px;animation:1.4s infinite typing}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{opacity:.3;transform:scale(.8)}30%{opacity:1;transform:scale(1)}}.partner-interim{color:#666;padding:4px 12px;font-size:.85rem;font-style:italic}.status-bar{text-align:center;color:#888;background:#16213e;border-top:1px solid #0f3460;flex-shrink:0;padding:6px 16px;font-size:.75rem}.settings-panel{background:#0f1a30;border-top:1px solid #533483;flex-wrap:wrap;flex-shrink:0;align-items:center;gap:10px;padding:10px 16px;display:flex}.settings-row{align-items:center;gap:6px;display:flex}.settings-row label{color:#888;white-space:nowrap;font-size:.7rem}.settings-row select{color:#e0e0e0;background:#0f3460;border:1px solid #533483;border-radius:4px;outline:none;padding:3px 6px;font-size:.75rem}.settings-clear{color:#e94560;cursor:pointer;background:0 0;border:1px solid #533483;border-radius:4px;margin-left:auto;padding:3px 10px;font-size:.7rem}.settings-btn{color:#888;cursor:pointer;background:#0f3460;border:2px solid #533483;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.2rem;transition:all .2s;display:flex}.settings-btn.active{color:#4ecca3;border-color:#4ecca3}.spinner{border:2px solid #fff3;border-top-color:#4ecca3;border-radius:50%;width:14px;height:14px;animation:.8s linear infinite spin;display:inline-block}.spinner.large{border-width:3px;width:28px;height:28px}@keyframes spin{to{transform:rotate(360deg)}}.status-bar.blocked{color:#e94560}.service-label{color:#4ecca3;font-size:.75rem}.record-btn.blocked{opacity:.3;border-color:#e94560}.status-bar.recording{color:#e94560;animation:1.5s infinite pulse}.status-bar.translating,.status-bar.speaking{color:#4ecca3}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.button-area{background:#16213e;flex-shrink:0;justify-content:center;align-items:center;gap:16px;padding:14px 16px 28px;display:flex}.record-btn{color:#e0e0e0;cursor:pointer;touch-action:none;-webkit-tap-highlight-color:transparent;background:#0f3460;border:4px solid #533483;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:120px;height:120px;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.record-btn .mic-icon{font-size:2rem}.record-btn .btn-label{text-transform:uppercase;letter-spacing:1px;font-size:.65rem}.record-btn:active,.record-btn.active{background:#e94560;border-color:#e94560;transform:scale(1.08);box-shadow:0 0 30px #e9456066}.record-btn:disabled{opacity:.3;cursor:not-allowed}.stop-speak-btn{color:#e0e0e0;cursor:pointer;opacity:.4;background:#0f3460;border:2px solid #533483;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.1rem;transition:all .2s;display:flex}.stop-speak-btn.active{opacity:1;border-color:#4ecca3}.mute-btn{color:#e0e0e0;cursor:pointer;background:#0f3460;border:2px solid #533483;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.1rem;transition:all .2s;display:flex}.mute-btn.muted{color:#e94560;border-color:#e94560}@media (width<=400px){.record-btn{width:100px;height:100px}.record-btn .mic-icon{font-size:1.6rem}}.translator-bar{background:#16213e;border-bottom:1px solid #0f3460;flex-shrink:0;align-items:center;gap:8px;padding:10px 12px;display:flex}.translator-back{color:#e0e0e0;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #533483;border-radius:6px;padding:6px 10px;font-size:.85rem}.translator-back:hover{background:#0f3460}.translator-langs{flex:1;justify-content:center;align-items:center;gap:6px;display:flex}.translator-lang-select{color:#e0e0e0;background:#0f3460;border:1px solid #533483;border-radius:6px;flex:1;min-width:0;max-width:180px;padding:6px 8px;font-size:.9rem}.translator-swap{color:#fff;cursor:pointer;background:#533483;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;transition:transform .2s,background .2s;display:flex}.translator-swap:hover{background:#6a42a8;transform:rotate(180deg)}@media (width<=400px){.translator-lang-select{padding:5px 6px;font-size:.8rem}.translator-back{padding:5px 8px;font-size:.8rem}}
