*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#1a1a2e;color:#eee;height:100vh;overflow:hidden;-webkit-user-select:none;user-select:none}.container{padding:28px 28px 24px;height:100vh;display:flex;flex-direction:column}header{margin-bottom:24px}header h1{font-size:22px;font-weight:600;margin-bottom:4px}header .subtitle{color:#666;font-size:13px}header .version{color:#888;font-size:11px;margin-top:2px}.view{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}button{padding:12px 20px;border:none;border-radius:10px;font-size:15px;font-weight:500;cursor:pointer;transition:opacity .15s}button:hover{opacity:.85}button:active{opacity:.7}.btn-primary{background:#4f46e5;color:#fff}.btn-secondary{background:#252538;color:#ccc;border:1px solid #333350}.btn-danger{background:#dc2626;color:#fff}.action-row{display:flex;gap:12px;margin-bottom:24px}.action-row button{flex:1;padding:14px 16px;font-size:15px;display:inline-flex;align-items:center;justify-content:center;gap:6px}.section-divider{display:flex;align-items:center;gap:10px;margin-bottom:16px}.section-divider span{color:#555;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.section-divider:after{content:"";flex:1;height:1px;background:#2a2a40}.mic-selector label{font-size:13px;color:#888;display:block;margin-bottom:6px}.mic-selector select{width:100%;padding:10px 12px;border:1px solid #333350;border-radius:10px;background:#252538;color:#ccc;font-size:14px;outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23888' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;cursor:pointer}.mic-selector select:focus{border-color:#4f46e5}.mic-selector{margin-bottom:16px}.btn-mic-test{margin-top:12px;padding:8px 16px;font-size:13px;background:#252538;color:#ccc;border:1px solid #333350}.btn-mic-test.active{background:#16a34a;color:#fff;border-color:#16a34a}.noise-toggle{display:inline-flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-track{display:block;position:relative;width:34px;height:18px;border-radius:9px;background:#333350;transition:background .2s;flex-shrink:0}.toggle-track.on{background:#4f46e5}.toggle-thumb{display:block;position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#ccc;transition:transform .2s}.toggle-track.on .toggle-thumb{transform:translate(16px);background:#fff}.toggle-label{font-size:13px;color:#888}.mic-level-meter{margin-top:10px;height:6px;border-radius:3px;background:#252538;overflow:hidden}.mic-level-bar{height:100%;border-radius:3px;background:linear-gradient(90deg,#22c55e,#4ade80);transition:width .06s linear;min-width:0}input[type=text]{width:100%;padding:12px 16px;border:1px solid #333350;border-radius:10px;background:#252538;color:#eee;font-size:15px;outline:none;margin-bottom:12px}input[type=text]:focus{border-color:#4f46e5}input[type=text]::placeholder{color:#555}.form-label{font-size:13px;color:#888;margin-bottom:8px}.back-btn{display:inline-flex;align-items:center;gap:4px;color:#888;font-size:13px;cursor:pointer;margin-top:16px;text-align:center;background:none;border:none;padding:6px 0;align-self:center}.back-btn:hover{color:#aaa;opacity:1}.back-btn svg{vertical-align:middle}.room-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.room-header h2{font-size:18px;font-weight:600}.room-header-right{display:flex;align-items:center;gap:12px}.room-peer-count{font-size:13px;color:#888}.ping-indicator{display:inline-flex;align-items:center;gap:4px;font-size:12px}.ping-good{color:#22c55e}.ping-medium{color:#f59e0b}.ping-bad{color:#ef4444}.ping-none{color:#666}.room-subtitle{display:flex;align-items:center;gap:8px;margin-bottom:8px}.room-subtitle code{font-size:13px;color:#666;letter-spacing:1px}.room-subtitle .copy-btn{background:none;border:none;color:#666;cursor:pointer;font-size:12px;padding:2px 6px;display:inline-flex;align-items:center;gap:4px}.room-subtitle .copy-btn:hover{color:#4f46e5;opacity:1}.status-text{color:#888;font-size:13px;margin-bottom:8px;display:flex;align-items:center}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px;background:#888;flex-shrink:0}.status-dot.connecting{background:#f59e0b}.status-dot.connected{background:#22c55e}.status-dot.error{background:#ef4444}.room-divider{height:1px;background:#2a2a40;margin-bottom:12px}.room-controls-wrapper{margin-top:auto;padding-top:12px}.room-controls{display:flex;align-items:center;justify-content:center;gap:16px;padding-bottom:4px}.btn-mute-circle{width:56px;height:56px;border-radius:50%;border:2px solid #333350;background:#252538;color:#ccc;font-size:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;padding:0}.btn-mute-circle:hover{border-color:#4f46e5;opacity:1}.btn-mute-circle.muted{background:#dc2626;border-color:#dc2626;color:#fff}.btn-leave-circle{width:56px;height:56px;border-radius:50%;border:2px solid #333350;background:#252538;color:#ccc;font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;padding:0}.btn-leave-circle:hover{background:#dc2626;border-color:#dc2626;color:#fff;opacity:1}.btn-settings-circle{width:56px;height:56px;border-radius:50%;border:2px solid #333350;background:#252538;color:#888;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;padding:0}.btn-settings-circle:hover{border-color:#4f46e5;color:#ccc;opacity:1}.btn-settings-circle.active{border-color:#4f46e5;color:#eee}.room-settings-dropdown{background:#252538;border:1px solid #333350;border-radius:10px;padding:10px 12px;margin-bottom:12px}.participant-list{display:flex;flex-direction:column;gap:4px;margin-bottom:12px;flex:1;overflow-y:auto;min-height:0}.participant-item{display:flex;align-items:center;gap:12px;padding:8px 4px;font-size:14px;color:#ccc}.avatar{width:36px;height:36px;border-radius:50%;background:#333350;color:#a5b4fc;font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0;text-transform:uppercase;border:2px solid transparent;transition:border-color .15s,box-shadow .15s,opacity .15s}.avatar.speaking{border-color:#22c55e;box-shadow:0 0 8px #22c55e59}.avatar.muted{opacity:.5}.participant-info{display:flex;align-items:center;gap:6px;flex:1;min-width:0}.peer-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.you-tag{font-size:11px;color:#888}.host-crown{font-size:14px;flex-shrink:0;color:#f59e0b;display:inline-flex;align-items:center}.muted-indicator{color:#ef4444;display:inline-flex;align-items:center;flex-shrink:0}.participant-actions{display:flex;gap:6px;margin-left:auto;flex-shrink:0;opacity:0;transition:opacity .15s}.participant-item:hover .participant-actions{opacity:1}.participant-actions button{padding:4px 10px;font-size:11px;border-radius:6px}.btn-kick{background:#dc2626;color:#fff}.btn-force-mute{background:#f59e0b;color:#1a1a2e}.btn-lock{padding:8px 16px;font-size:13px;background:#252538;color:#ccc;border:1px solid #333350;width:100%}.btn-lock.locked{background:#f59e0b;color:#1a1a2e;border-color:#f59e0b}.notice-banner{display:none;background:#f59e0b;color:#1a1a2e;font-size:13px;font-weight:500;text-align:center;padding:8px 16px;border-radius:8px;margin-bottom:12px}.notice-banner.visible{display:block}.setting-group{margin-bottom:12px}.setting-label{font-size:13px;color:#888;display:block;margin-bottom:6px}.setting-group input[type=text]{margin-bottom:0}.password-group{margin-bottom:4px}.password-hint{color:#f59e0b;font-size:13px;margin-bottom:8px}.error-hint{color:#ef4444;font-size:13px;margin-bottom:8px}.password-row{display:flex;gap:8px}.input-room-password{flex:1;margin-bottom:0!important}.password-row .btn-lock{width:auto;white-space:nowrap}.room-tabs{display:flex;gap:4px;margin-bottom:12px}.room-tab{flex:1;padding:8px 12px;font-size:13px;font-weight:500;background:transparent;color:#666;border:none;border-radius:8px;cursor:pointer;position:relative;transition:color .15s,background .15s}.room-tab:hover{color:#aaa;opacity:1}.room-tab.active{color:#eee;background:#252538}.chat-unread-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#4f46e5;margin-left:4px;vertical-align:middle}.chat-panel{display:flex;flex-direction:column;flex:1;min-height:0}.chat-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:6px;padding:4px 0;min-height:0}.chat-bubble{max-width:85%;padding:8px 12px;border-radius:12px;font-size:14px;line-height:1.4;background:#252538;align-self:flex-start}.chat-bubble.self{background:#3730a3;align-self:flex-end}.chat-sender{font-size:11px;color:#a5b4fc;margin-bottom:2px;font-weight:500}.chat-content{color:#eee;word-break:break-word}.chat-input-row{display:flex;gap:8px;margin-top:8px;align-items:center}.chat-input{flex:1;margin-bottom:0!important}.chat-send-btn{width:40px;height:40px;border-radius:50%;background:#4f46e5;color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;flex-shrink:0;transition:opacity .15s}.chat-send-btn:disabled{opacity:.4;cursor:default}.chat-send-btn:not(:disabled):hover{opacity:.85}.chat-empty{color:#555;font-size:14px;text-align:center;margin:auto 0}body{background:#0f0f1a;height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}.window-shell{position:absolute;top:0;right:0;bottom:0;left:0;margin:auto;width:380px;height:600px;border-radius:12px;overflow:hidden;box-shadow:0 25px 60px #00000080,0 0 0 1px #ffffff0f;display:flex;flex-direction:column}.titlebar{height:36px;background:#16162a;display:flex;align-items:center;justify-content:space-between;padding:0 14px;cursor:grab;flex-shrink:0;-webkit-user-select:none;user-select:none;border-bottom:1px solid rgba(255,255,255,.04)}.titlebar:active{cursor:grabbing}.titlebar-title{font-size:12px;font-weight:500;color:#555;letter-spacing:.3px}.titlebar-dots{display:flex;gap:7px}.dot{width:11px;height:11px;border-radius:50%}.dot-red{background:#ff5f57}.dot-yellow{background:#febc2e}.dot-green{background:#28c840}.window-body{flex:1;min-height:0;overflow:hidden;background:#1a1a2e}.window-body .container{height:100%;padding:24px 24px 20px}
