*{box-sizing:border-box;margin:0;padding:0}:root{--primary: #6366f1;--primary-dark: #4f46e5;--secondary: #64748b;--success: #10b981;--danger: #ef4444;--background: #0f172a;--surface: #1e293b;--surface-light: #334155;--text: #f1f5f9;--text-secondary: #94a3b8;--border: #334155;--shadow: rgba(0, 0, 0, .3)}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:var(--background);color:var(--text);line-height:1.6}.app{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#0f172a,#1e293b)}.container{width:100%;max-width:600px}.login-view{text-align:center}.logo{margin-bottom:2rem}.logo h1{font-size:3rem;margin-bottom:.5rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.logo h1 .emoji{font-size:3rem}.logo h1 .text{background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.logo p{color:var(--text-secondary);font-size:1.1rem}.form-card{background:var(--surface);border-radius:1rem;padding:2rem;box-shadow:0 10px 30px var(--shadow);border:1px solid var(--border)}.form-group{margin-bottom:1.5rem;text-align:left}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text);font-size:.9rem}.form-group input{width:100%;padding:.75rem 1rem;background:var(--background);border:1px solid var(--border);border-radius:.5rem;color:var(--text);font-size:1rem;transition:all .2s}.form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.input-group{display:flex;gap:.5rem}.input-group input{flex:1}.btn{padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}.btn-secondary{background:var(--surface-light);color:var(--text)}.btn-secondary:hover{background:var(--secondary)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 4px 12px #ef444466}.btn-large{width:100%;padding:1rem 1.5rem;font-size:1.1rem;margin-bottom:1rem}.info-text{color:var(--text-secondary);font-size:.9rem}.error-message{background:#ef44441a;border:1px solid var(--danger);color:var(--danger);padding:.75rem;border-radius:.5rem;margin-bottom:1rem;font-size:.9rem}.room-view{background:var(--surface);border-radius:1rem;padding:2rem;box-shadow:0 10px 30px var(--shadow);border:1px solid var(--border)}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.header-content h1{font-size:1.8rem;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.header-content h1 .emoji{font-size:1.8rem}.header-content h1 .text{background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.room-info{display:flex;gap:1rem;flex-wrap:wrap;font-size:.9rem;color:var(--text-secondary)}.room-id{background:var(--background);padding:.25rem .75rem;border-radius:.25rem;font-family:Courier New,monospace}.username{color:var(--primary);font-weight:500}.participants-section h2{font-size:1.2rem;margin-bottom:1rem;color:var(--text)}.participants-list{display:flex;flex-direction:column;gap:.75rem}.participant-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--background);border-radius:.5rem;border:1px solid var(--border);transition:all .2s}.participant-card:hover{border-color:var(--primary);transform:translate(4px)}.participant-card.speaking{border-color:var(--success);border-width:2px;box-shadow:0 0 12px #10b9814d}.participant-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--primary) 0%,#8b5cf6 100%);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:600;color:#fff}.participant-info{flex:1;display:flex;align-items:center;gap:.5rem}.sensitivity-wrapper{position:relative;display:inline-flex}.sensitivity-popover{position:absolute;bottom:calc(100% + .5rem);right:0;z-index:20;display:flex;flex-direction:column;gap:.6rem;padding:.9rem 1rem;min-width:240px;background:var(--bg-elevated, #1f2937);border:1px solid var(--border);border-radius:.6rem;box-shadow:0 12px 32px #00000073}.sensitivity-label{display:flex;justify-content:space-between;align-items:baseline;font-size:.85rem;color:var(--text-secondary);font-weight:500}.sensitivity-value{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.8rem;color:var(--text)}.sensitivity-popover input[type=range]{width:100%;accent-color:var(--primary)}.sensitivity-level{position:relative;height:6px;border-radius:3px;background:#ffffff14;overflow:hidden}.sensitivity-level-fill{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,var(--success),#34d399);transform-origin:left center;transform:scaleX(0);transition:transform 60ms linear}.sensitivity-threshold{position:absolute;top:-2px;bottom:-2px;width:2px;background:var(--primary);pointer-events:none}.settings-divider{border:0;border-top:1px solid var(--border);margin:.3rem 0 .1rem}.settings-toggle{display:flex;align-items:center;gap:.55rem;font-size:.88rem;color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none}.settings-toggle input[type=checkbox]{accent-color:var(--primary);width:16px;height:16px;cursor:pointer}.settings-toggle input[type=checkbox]:disabled{cursor:not-allowed}.settings-toggle:has(input:disabled){opacity:.55;cursor:not-allowed}.settings-hint{color:var(--text-secondary);font-size:.78rem}.participant-name{font-weight:500;color:var(--text)}.participant-badges{display:flex;gap:.5rem;align-items:center;margin-top:.25rem}.badge{background:var(--primary);color:#fff;padding:.125rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:500}.badge-muted{background:#ef4444}.badge-sharing{background:#3b82f6}.audio-indicator{display:flex;align-items:center}.pulse{width:12px;height:12px;background:var(--success);border-radius:50%;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.status-bar{margin-top:2rem;padding-top:1rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.mic-mode-toggle{display:inline-flex;gap:0;background:var(--bg-elevated, rgba(255, 255, 255, .05));border:1px solid var(--border);border-radius:.5rem;padding:2px}.btn-toggle{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:0;color:var(--text-secondary);padding:.4rem .85rem;font-size:.85rem;font-weight:500;border-radius:.4rem;cursor:pointer;transition:background .15s,color .15s}.btn-toggle:hover{color:var(--text-primary)}.btn-toggle.active{background:var(--primary);color:#fff}.kbd-hint{display:inline-block;margin-left:.5rem;padding:1px 6px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.7rem;background:#00000040;border:1px solid var(--border);border-radius:3px;color:inherit;opacity:.75;vertical-align:middle}.ptt-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;font-size:.95rem;font-weight:600;border-radius:.5rem;border:1px solid var(--border);background:var(--bg-elevated, rgba(255, 255, 255, .05));color:var(--text-primary);cursor:pointer;user-select:none;-webkit-user-select:none;touch-action:manipulation;transition:background .1s,transform .05s,box-shadow .1s}.ptt-button:hover{background:#ffffff14}.ptt-button.active{background:var(--success);color:#fff;border-color:var(--success);box-shadow:0 0 18px #10b98173;transform:scale(.98)}.status-indicator{display:inline-flex;align-items:center;gap:.5rem;color:var(--success);font-size:.9rem;font-weight:500}.status-dot{width:8px;height:8px;background:var(--success);border-radius:50%;animation:pulse 2s ease-in-out infinite}.empty-state{padding:2rem;text-align:center;color:var(--text-secondary)}.screen-share-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:.75rem;margin:1rem 0 1.25rem}.video-tile{position:relative;background:#000;border:1px solid var(--border);border-radius:.5rem;overflow:hidden;aspect-ratio:16 / 9}.video-tile video{width:100%;height:100%;object-fit:contain;background:#000}.video-tile-label{position:absolute;bottom:.4rem;left:.5rem;padding:.15rem .55rem;background:#0000008c;color:#fff;font-size:.78rem;border-radius:.3rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.video-tile-fullscreen{position:absolute;top:.4rem;right:.4rem;width:28px;height:28px;border:0;border-radius:.25rem;background:#0000008c;color:#fff;font-size:.95rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;opacity:0;transition:opacity .1s}.video-tile:hover .video-tile-fullscreen,.video-tile-fullscreen:focus-visible{opacity:1}.video-tile video:fullscreen{object-fit:contain;width:100%;height:100%;background:#000}.screen-share-toggle.active{background:#ef4444;color:#fff}.participant-info{flex:1;display:flex;flex-direction:column;gap:.3rem;min-width:0}.participant-header-row{display:flex;align-items:center;gap:.5rem}.quality-dot{display:inline-block;width:9px;height:9px;border-radius:50%;background:#6b7280;flex-shrink:0;box-shadow:0 0 4px #0006}.quality-dot--good{background:#22c55e}.quality-dot--fair{background:#f59e0b}.quality-dot--poor{background:#ef4444}.quality-dot--unknown{background:#6b7280}.participant-volume{display:flex;align-items:center;gap:.5rem;margin-top:.15rem}.participant-volume input[type=range]{flex:1;height:4px;accent-color:var(--primary)}.volume-icon{font-size:.85rem;opacity:.7;width:1.2rem;text-align:center}.version-tag{position:fixed;right:.65rem;bottom:.5rem;z-index:5;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.7rem;color:var(--text-secondary);opacity:.55;padding:.1rem .4rem;border-radius:.25rem;background:#00000040;pointer-events:auto;-webkit-user-select:text;user-select:text;transition:opacity .15s}.version-tag:hover{opacity:1}.reconnect-banner{display:flex;align-items:center;gap:.6rem;padding:.55rem .9rem;margin:.75rem 0;background:#f59e0b1f;border:1px solid rgba(245,158,11,.45);border-radius:.5rem;color:#f59e0b;font-size:.9rem;font-weight:500}.reconnect-spinner{width:14px;height:14px;border:2px solid rgba(245,158,11,.3);border-top-color:#f59e0b;border-radius:50%;animation:reconnect-spin .8s linear infinite}@keyframes reconnect-spin{to{transform:rotate(360deg)}}.chat-toggle{position:relative;font-size:1.1rem;line-height:1}.chat-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;font-size:.7rem;font-weight:700;color:#fff;background:#ef4444;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 0 0 2px var(--background, #0f172a)}.participant-card{position:relative;overflow:visible}.flying-reactions{position:absolute;top:-8px;right:12px;display:flex;gap:.25rem;pointer-events:none;z-index:5}.flying-reaction{display:inline-block;font-size:1.5rem;animation:fly-up 1.8s cubic-bezier(.2,.7,.3,1) forwards;filter:drop-shadow(0 1px 4px rgba(0,0,0,.4))}@keyframes fly-up{0%{opacity:0;transform:translateY(0) scale(.7)}15%{opacity:1;transform:translateY(-12px) scale(1.1)}to{opacity:0;transform:translateY(-64px) scale(1)}}.chat-panel{position:fixed;top:0;right:0;bottom:0;width:360px;max-width:90vw;background:var(--bg-elevated, #1f2937);border-left:1px solid var(--border);display:flex;flex-direction:column;z-index:30;transform:translate(100%);transition:transform .2s ease-out;box-shadow:-8px 0 24px #0000004d}.chat-panel--open{transform:translate(0)}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:.8rem 1rem;border-bottom:1px solid var(--border)}.chat-header h3{margin:0;font-size:1rem}.chat-close{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:0;color:var(--text-secondary);font-size:1.1rem;cursor:pointer;padding:.25rem .5rem;border-radius:.3rem}.chat-close:hover{background:#ffffff0f;color:var(--text)}.chat-messages{flex:1;overflow-y:auto;padding:.8rem 1rem;display:flex;flex-direction:column;gap:.6rem}.chat-empty{color:var(--text-secondary);font-size:.9rem;text-align:center;padding:2rem 0}.chat-message{display:flex;flex-direction:column;gap:.15rem;padding:.45rem .65rem;border-radius:.5rem;background:#ffffff0a;border:1px solid var(--border)}.chat-message--self{border-color:#6366f166;background:#6366f114}.chat-message-meta{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem;font-size:.75rem;color:var(--text-secondary)}.chat-username{font-weight:600;color:var(--text)}.chat-time{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.7rem;opacity:.7}.chat-message-text{white-space:pre-wrap;word-break:break-word;font-size:.92rem;color:var(--text)}.chat-reaction-row{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary)}.chat-reaction-emoji{font-size:1.1rem}.chat-reaction-row .chat-time{margin-left:auto}.chat-reactions-bar{display:flex;gap:.3rem;padding:.5rem 1rem;border-top:1px solid var(--border);flex-wrap:wrap}.reaction-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border);background:#ffffff0a;color:var(--text);font-size:1.2rem;width:36px;height:36px;border-radius:.4rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:transform .08s,background .1s}.reaction-btn:hover{background:#ffffff1a}.reaction-btn:active{transform:scale(.9)}.chat-composer{display:flex;flex-direction:column;gap:.4rem;padding:.6rem 1rem .9rem;border-top:1px solid var(--border)}.chat-composer textarea{width:100%;resize:vertical;min-height:48px;max-height:160px;background:#00000040;border:1px solid var(--border);border-radius:.4rem;color:var(--text);padding:.5rem .6rem;font-family:inherit;font-size:.92rem;line-height:1.35}.chat-composer textarea:focus{outline:none;border-color:var(--primary)}.chat-composer-footer{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.chat-counter{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.75rem;color:var(--text-secondary)}.chat-counter--warn{color:#f59e0b}.chat-send{padding:.45rem 1rem}.chat-send:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 640px){.chat-panel{width:100vw;max-width:100vw}}@media (max-width: 640px){.app{padding:1rem}.room-view,.form-card{padding:1.5rem}.header{flex-direction:column;gap:1rem;align-items:flex-start}.logo h1{font-size:2rem}.participant-card{padding:.75rem}.participant-avatar{width:40px;height:40px;font-size:1.25rem}}body{margin:0;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}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
