.message-status{display:inline-flex;align-items:center;gap:1px;color:#666;margin-left:4px}.message-status.pending{color:#999}.message-status.local,.message-status.syncing{color:#666}.message-status.synced{color:#4caf50}.message-status.error{color:#f44336;cursor:pointer}.message-status.error:hover{color:#d32f2f}.message-status.syncing svg:last-child,.message-status.synced svg:last-child{margin-left:-6px}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.1)}}.message-status .pulse{animation:pulse 1.5s ease-in-out infinite}.message-bubble.priority .message-content-wrapper{border-left:3px solid #f44336;padding-left:12px;border-radius:0 1rem 1rem 0;background-color:#f443360d}.message-bubble.own.priority .message-content-wrapper{background-color:#007aff;border-left:3px solid #f44336}.priority-prefix{color:#f44336;font-weight:600;margin-right:2px}.priority-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 6px;background-color:#f44336;color:#fff;border-radius:3px;font-size:10px;font-weight:600;text-transform:uppercase;margin-right:6px}.priority-badge svg{width:10px;height:10px}.message-bubble.transcript .message-content-wrapper{border-left:3px solid #6366f1;padding-left:12px;border-radius:0 1rem 1rem 0;background-color:#f5f3ff;font-style:italic}.message-bubble.own.transcript .message-content-wrapper{background-color:#eef2ff;border-left:3px solid #6366f1}.transcript-label{display:flex;align-items:center;gap:4px;font-size:.7rem;color:#6366f1;font-weight:600;margin-bottom:2px;text-transform:uppercase;letter-spacing:.05em;font-style:normal}.queue-dashboard{padding:16px;background:#f8f9fa;border-radius:8px}.dashboard-title{margin:0 0 16px;font-size:18px;font-weight:600}.queue-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:16px}.stat-card{padding:16px;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.stat-card.warning{border-left:4px solid #ffc107}.stat-card.critical{border-left:4px solid #f44336}.stat-value{font-size:28px;font-weight:700;color:#333}.stat-value.connected{color:#4caf50}.stat-value.offline{color:#f44336}.stat-label{font-size:12px;color:#666;text-transform:uppercase;letter-spacing:.5px}.stat-progress{height:4px;background:#e9ecef;border-radius:2px;margin-top:8px;overflow:hidden}.progress-bar{height:100%;background:#4caf50;border-radius:2px;transition:width .3s ease}.stat-card.warning .progress-bar{background:#ffc107}.stat-card.critical .progress-bar{background:#f44336}.stat-detail{font-size:11px;color:#999;margin-top:4px}.sync-progress{display:flex;align-items:center;gap:8px;padding:12px;background:#e3f2fd;border-radius:4px;margin-bottom:16px;font-size:14px}.sync-progress .spin{animation:spin 1s linear infinite}.failed-count{color:#f44336}.dashboard-actions{display:flex;gap:8px}.action-button{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:background-color .2s;background:#e9ecef;color:#333}.action-button:disabled{opacity:.5;cursor:not-allowed}.action-button.primary{background:#1976d2;color:#fff}.action-button.primary:hover:not(:disabled){background:#1565c0}.action-button.danger{background:#f44336;color:#fff}.action-button.danger:hover:not(:disabled){background:#d32f2f}.confirm-dialog{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.confirm-content{background:#fff;padding:24px;border-radius:8px;max-width:400px;text-align:center}.confirm-icon{color:#f44336;margin-bottom:16px}.confirm-content h4{margin:0 0 8px}.confirm-content p{color:#666;margin-bottom:16px}.clear-options{margin-bottom:16px}.clear-options input{width:80px;padding:6px;margin-left:8px;border:1px solid #ddd;border-radius:4px}.confirm-actions{display:flex;gap:8px;justify-content:center}.connection-indicator{display:inline-flex;align-items:center;gap:6px}.indicator-dot{width:8px;height:8px;border-radius:50%;transition:background-color .3s ease}.connection-indicator.connected .indicator-dot{background-color:#4caf50}.connection-indicator.syncing .indicator-dot{background-color:#ffc107;animation:pulse-dot 1.5s ease-in-out infinite}.connection-indicator.reconnecting .indicator-dot{background-color:#ffc107;animation:pulse-dot 1s ease-in-out infinite}.connection-indicator.offline .indicator-dot{background-color:#f44336}.indicator-label{font-size:12px;color:#666}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.5}}.offline-banner{display:flex;align-items:center;gap:8px;padding:8px 16px;background-color:#fff3cd;border-bottom:1px solid #ffc107;color:#856404;font-size:14px;transition:all .3s ease;z-index:100}.offline-banner.collapsed{padding:4px 12px;background-color:transparent;border:none;cursor:pointer}.offline-banner.collapsed:hover{background-color:#0000000d}.offline-banner.collapsed:focus{outline:2px solid #3B82F6;outline-offset:2px}.banner-icon{flex-shrink:0}.banner-icon.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.queue-count{margin-left:auto;font-size:12px;opacity:.8}.queue-warning-banner{display:flex;align-items:center;gap:10px;padding:10px 16px;font-size:14px;transition:background-color .3s ease}.queue-warning-banner.warning{background-color:#fff3cd;border-bottom:1px solid #ffc107;color:#856404}.queue-warning-banner.critical{background-color:#f8d7da;border-bottom:1px solid #f5c6cb;color:#721c24}.warning-icon{flex-shrink:0}.warning-content{display:flex;flex-direction:column;gap:2px}.warning-text{font-weight:500}.warning-subtext{font-size:12px;opacity:.8}.clear-button{display:flex;align-items:center;gap:4px;margin-left:auto;padding:6px 12px;background-color:#0000001a;border:none;border-radius:4px;color:inherit;font-size:12px;cursor:pointer;transition:background-color .2s}.clear-button:hover{background-color:#0003}.bridge-status{position:relative;display:inline-flex;align-items:center}.bridge-status-trigger{display:inline-flex;align-items:center;gap:6px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background-color .2s ease}.bridge-status-trigger:hover{background:#ffffff1a}.bridge-status-trigger:focus{outline:none;background:#ffffff26}.bridge-dot{width:8px;height:8px;border-radius:50%;transition:background-color .3s ease,box-shadow .3s ease}.bridge-dot.connected{background:#22c55e;box-shadow:0 0 4px #22c55e;animation:pulse-glow 2s ease-in-out infinite}.bridge-dot.disconnected{background:#ef4444}.bridge-dot.connecting{background:#eab308;animation:pulse-fast 1.5s ease-in-out infinite}.bridge-dot.muted{background:#f97316}.bridge-label{font-size:.75rem;color:#9ca3af;white-space:nowrap}.bridge-mute-icon{color:#f97316;margin-left:2px}.bridge-details{position:absolute;bottom:100%;left:0;margin-bottom:8px;background:#1f2937;border:1px solid #374151;border-radius:6px;padding:8px 12px;min-width:200px;z-index:100;box-shadow:0 4px 12px #0000004d}.bridge-detail-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:.75rem}.bridge-detail-row:not(:last-child){border-bottom:1px solid #374151}.bridge-detail-label{color:#9ca3af}.bridge-detail-value{font-weight:500}.latency-good{color:#22c55e}.latency-medium{color:#eab308}.latency-poor{color:#ef4444}.latency-unknown{color:#6b7280}.quality-good{color:#22c55e}.quality-degraded{color:#eab308}.quality-down{color:#ef4444}.quality-unknown{color:#6b7280}.bridge-sync-row{margin-top:4px}.bridge-sync-value{color:#60a5fa;animation:pulse-text 1.5s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 4px #22c55e}50%{box-shadow:0 0 8px #22c55e,0 0 12px #22c55e66}}@keyframes pulse-fast{0%,to{opacity:1}50%{opacity:.5}}@keyframes pulse-text{0%,to{opacity:1}50%{opacity:.7}}.bridge-mute-button{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:1px solid #374151;border-radius:6px;color:#9ca3af;cursor:pointer;transition:all .2s ease;padding:0}.bridge-mute-button:hover{background:#ffffff1a;color:#fff}.bridge-mute-button:focus{outline:2px solid #3B82F6;outline-offset:2px}.bridge-mute-button:active{transform:scale(.95)}.bridge-mute-button.muted{background:#ef444433;border-color:#ef4444;color:#ef4444}.bridge-mute-button.muted:hover{background:#ef44444d;border-color:#dc2626}.sync-progress-bar{background:#1e3a5f;padding:6px 16px;font-size:.8rem;color:#93c5fd;border-bottom:1px solid #2563EB}.sync-progress-text{margin-bottom:4px;font-weight:500}.sync-progress-track{height:3px;background:#1e293b;border-radius:2px;overflow:hidden}.sync-progress-fill{height:100%;background:#3b82f6;border-radius:2px;transition:width .3s ease}body{margin:0}.app-container{display:flex;height:100vh;width:100vw;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.room-sidebar{width:280px;min-width:200px;max-width:100%;background-color:#f5f5f5;border-right:1px solid #ddd;display:flex;flex-direction:column;flex-shrink:1}.sidebar-header{padding:1rem 1.25rem;background-color:#fff;border-bottom:1px solid #ddd}.sidebar-header h2{margin:0;font-size:1.25rem;font-weight:600;color:#1a1a1a}.room-list{flex:1;overflow-y:auto;padding:.5rem 0}.empty-rooms{padding:2rem 1rem;text-align:center;color:#666}.empty-rooms p{margin:0;font-size:.875rem}.room-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.25rem;cursor:pointer;transition:background-color .15s ease;position:relative}.room-item:hover{background-color:#0000000d}.room-item.active{border-left:3px solid currentColor;padding-left:calc(1.25rem - 3px)}.room-icon{font-size:1.5rem;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.room-info{flex:1;min-width:0}.room-name{font-weight:500;font-size:.9375rem;color:#1a1a1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unread-badge{min-width:1.25rem;height:1.25rem;border-radius:.625rem;color:#fff;font-size:.6875rem;font-weight:600;display:flex;align-items:center;justify-content:center;padding:0 .375rem;flex-shrink:0}.chat-room{flex:1;display:flex;flex-direction:column;background-color:#fff;min-width:0}.chat-header{padding:1rem 1.5rem;background-color:#fff;border-bottom:1px solid #ddd}.chat-header h2{margin:0;font-size:1.125rem;font-weight:600;color:#1a1a1a}.message-list-container{flex:1;overflow-y:auto;padding:1rem 1.5rem;background-color:#fafafa;display:flex;flex-direction:column}.message-list{display:flex;flex-direction:column;gap:.5rem}.load-more-button{align-self:center;margin-bottom:1rem;padding:.5rem 1rem;background-color:#f0f0f0;border:1px solid #ddd;border-radius:1rem;cursor:pointer;font-size:.875rem;color:#333;transition:background-color .15s ease}.load-more-button:hover{background-color:#e8e8e8}.load-more-button:disabled{opacity:.5;cursor:not-allowed}.empty-messages{flex:1;display:flex;align-items:center;justify-content:center;color:#666;font-size:.875rem}.new-messages-indicator{position:sticky;top:0;align-self:center;margin:.5rem 0;padding:.5rem 1rem;background-color:#007aff;color:#fff;border-radius:1rem;font-size:.75rem;font-weight:500;cursor:pointer;z-index:10;box-shadow:0 2px 4px #0000001a}.message-bubble{display:flex;flex-direction:column;max-width:70%;margin-bottom:.5rem}.message-bubble.own{align-self:flex-end;align-items:flex-end}.message-bubble.other{align-self:flex-start;align-items:flex-start}.message-sender{font-size:.75rem;color:#666;margin-bottom:.25rem;padding:0 .5rem}.message-content-wrapper{display:flex;flex-direction:column;background-color:#fff;border-radius:1rem;padding:.625rem .875rem;box-shadow:0 1px 2px #0000001a;word-wrap:break-word;overflow-wrap:break-word}.message-bubble.own .message-content-wrapper{background-color:#007aff;color:#fff}.message-text{font-size:.9375rem;line-height:1.4;margin:0;white-space:pre-wrap}.message-footer{display:flex;align-items:center;justify-content:flex-end;gap:4px;margin-top:.25rem}.message-timestamp{font-size:.6875rem;color:#00000073}.message-bubble.own .message-timestamp,.message-bubble.own .message-status{color:#ffffffb3}.message-bubble.own .message-status.synced{color:#ffffffe6}.message-input-container{padding:1rem 1.5rem;background-color:#fff;border-top:1px solid #ddd}.message-input-wrapper{display:flex;gap:.75rem;align-items:flex-end}.message-input{flex:1;padding:.75rem 1rem;border:1px solid #ddd;border-radius:1.5rem;font-size:.9375rem;font-family:inherit;resize:none;outline:none;transition:border-color .15s ease;min-height:2.5rem;max-height:8rem}.message-input:focus{border-color:#007aff}.message-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.send-button{padding:.75rem 1.25rem;background-color:#007aff;color:#fff;border:none;border-radius:1.5rem;font-size:.9375rem;font-weight:500;cursor:pointer;transition:background-color .15s ease;white-space:nowrap}.send-button:hover:not(:disabled){background-color:#0066d6}.send-button:disabled{opacity:.5;cursor:not-allowed}.room-chat-button{display:none}@media(max-width:800px){.room-sidebar{width:100%;position:relative;flex-shrink:0}.message-bubble{max-width:85%}.message-input-container{padding:.75rem 1rem}.room-chat-button{display:flex!important}}@media(max-width:480px){.controls-inner{padding:.5rem}.controls-header{flex-wrap:wrap}.sidebar-header{padding:.75rem 1rem}.voice-only-container{padding:1rem}}@media(max-width:800px){.room-sidebar{width:100%;min-width:unset}.main-content-area{flex-direction:column}.voice-controls-panel{background-color:#111827;border-top:none}.controls-inner{padding:.5rem}.voice-controls-box{border-radius:0!important}}*,*:before,*:after{box-sizing:border-box}.voice-primary-layout{display:flex;flex-direction:column;height:100vh;background-color:#f9fafb;font-family:system-ui,-apple-system,sans-serif}.speaker-indicator-banner{position:fixed;top:0;left:0;right:0;z-index:30;background-color:#1f2937;border-bottom:1px solid #374151;pointer-events:none}.speaker-indicator-banner>*{pointer-events:auto}.main-content-area{flex:1;display:flex;overflow:hidden;background-color:#f9fafb;min-width:0}.voice-controls-panel{flex-shrink:0;background-color:#1f2937;border-top:1px solid #374151}.controls-inner{max-width:800px;width:100%;margin:0 auto;padding:1rem}.controls-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;gap:.5rem}.icon-button{padding:.5rem;background-color:transparent;border:1px solid #9CA3AF;border-radius:4px;color:#e5e7eb;cursor:pointer;display:flex;align-items:center;justify-content:center}.icon-button:hover{background-color:#374151}.chat-toggle-icon{padding:.5rem;background-color:transparent;border:1px solid #9CA3AF;border-radius:4px;color:#e5e7eb;cursor:pointer;display:none}.chat-toggle-icon:hover{background-color:#374151}.admin-button{padding:.5rem 1rem;background-color:#3b82f6;color:#fff;border:none;border-radius:4px;cursor:pointer;fontSize:.875rem;font-weight:500}.admin-button:hover{background-color:#2563eb}.chat-panel{display:none;flex:1;min-width:0}.chat-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#fff;z-index:50;flex-direction:column}.chat-overlay-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background-color:#1f2937;color:#fff;border-bottom:1px solid #374151}.chat-overlay-header h3{margin:0;font-size:1.125rem;font-weight:600}.close-chat-button{padding:.5rem;background-color:transparent;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px}.close-chat-button:hover{background-color:#374151}.chat-overlay-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.voice-only-container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#f9fafb;padding:2rem}.voice-room-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;width:100%;max-width:600px}.voice-room-card{background-color:#fff;border:1px solid #E5E7EB;border-radius:12px;padding:1rem;text-align:center;transition:all .15s ease;cursor:pointer}.voice-room-card:hover{background-color:#f3f4f6;border-color:#d1d5db}.voice-room-card.speaking{background-color:#22c55e33;border:2px solid #22C55E}.voice-room-card.transmitting{background-color:#ef444433;border:2px solid #EF4444}.settings-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@keyframes speakingWave{0%,to{transform:scaleY(.5)}50%{transform:scaleY(1)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.2)}}@keyframes glow{0%,to{box-shadow:0 0 5px #ef444480}50%{box-shadow:0 0 20px #ef4444cc}}.ptt-transmitting{animation:glow 1s ease-in-out infinite}@media(max-width:800px){.chat-panel{display:none!important}.chat-toggle-icon,.chat-overlay{display:flex}}@media(min-width:801px){.chat-panel{display:flex}.chat-toggle-icon{display:none}.chat-overlay{display:none!important}}
