:root{color:#172033;background:#f6f8fb;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0}button,select,input{font:inherit}button{cursor:pointer;border:0;font-weight:700}button:disabled{cursor:not-allowed;opacity:.55}#app{min-height:100vh}.entry-view{align-content:center;place-items:center;gap:24px;min-height:100vh;padding:24px;display:grid}h1,h2,p{margin:0}h1{font-size:28px;line-height:1.2}.join-button,#request-button{color:#fff;background:#0f766e;border-radius:8px;min-width:160px;padding:14px 22px;box-shadow:0 10px 24px #0f766e2e}.room-view{grid-template-columns:minmax(0,440px);place-content:center;place-items:center;gap:24px;min-height:100vh;padding:24px 24px 112px;display:grid;position:relative}.request-panel{gap:16px;width:min(440px,100%);display:grid}.request-panel h2{text-align:center;font-size:22px}.request-idle{gap:12px;display:grid}#song-select{width:100%;min-height:180px;color:inherit;background:#fff;border:1px solid #c9d3df;border-radius:8px;padding:10px}.request-playing{background:#fff;border:1px solid #d7e1ea;border-radius:8px;justify-items:center;gap:10px;padding:24px;display:grid}.stop-button{color:#fff;background:#be123c;border-radius:8px;min-width:140px;padding:12px 18px}.request-playing p{color:#607086;font-weight:700}#playing-title{font-size:24px}.playing-lyrics{color:#172033;text-align:center;white-space:pre-line;width:100%;max-height:min(46vh,420px);font-size:18px;font-weight:700;line-height:1.9;overflow:auto}.device-panel{z-index:4;background:#fff;border:1px solid #d7e1ea;border-radius:8px;gap:14px;width:min(360px,100% - 48px);padding:18px;display:grid;position:fixed;bottom:92px;right:24px}.device-panel h2{font-size:18px}.audio-processing-fieldset{border:1px solid #d7e1ea;border-radius:8px;gap:10px;margin:0;padding:12px;display:grid}.audio-processing-fieldset legend{color:#334155;padding:0 4px;font-size:14px;font-weight:700}.audio-processing-fieldset label{color:#334155;align-items:center;gap:10px;font-size:14px;font-weight:700;display:flex}.audio-processing-fieldset input{accent-color:#0f766e;width:18px;height:18px}.field{color:#334155;gap:8px;font-size:14px;font-weight:700;display:grid}.field span{justify-content:space-between;align-items:center;gap:12px;display:flex}#mic-device-select{color:#172033;background:#fff;border:1px solid #c9d3df;border-radius:8px;width:100%;min-height:42px;padding:8px 10px}#mic-gain{width:100%}.level-meter{background:#e2e8f0;border-radius:999px;height:12px;position:relative;overflow:hidden}.level-meter span{border-radius:inherit;background:linear-gradient(90deg,#0f766e 0%,#65a30d 60%,#eab308 82%,#be123c 100%);width:0%;height:100%;transition:width 80ms linear;display:block}.bottom-controls{justify-content:center;align-items:center;gap:12px;display:inline-flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.signal-indicator{color:#172033;place-items:center;gap:2px;width:48px;min-height:52px;display:grid}.signal-bars{align-items:end;gap:3px;height:24px;display:inline-flex}.signal-bars span{background:#cbd5e1;border-radius:2px 2px 0 0;width:5px;display:block}.signal-bars span:first-child{height:7px}.signal-bars span:nth-child(2){height:12px}.signal-bars span:nth-child(3){height:17px}.signal-bars span:nth-child(4){height:22px}.signal-indicator[data-level="1"] .signal-bars span:nth-child(-n+1),.signal-indicator[data-level="2"] .signal-bars span:nth-child(-n+2),.signal-indicator[data-level="3"] .signal-bars span:nth-child(-n+3),.signal-indicator[data-level="4"] .signal-bars span:nth-child(-n+4){background:#0f766e}.signal-indicator[data-level="0"] .signal-bars span{background:#f43f5e}.signal-percent{text-align:center;min-width:44px;font-size:12px;font-weight:800;line-height:1}.audio-settings-toggle,.mic-button{color:#fff;background:#172033;border-radius:999px;justify-content:center;align-items:center;display:inline-flex;box-shadow:0 12px 28px #17203338}.audio-settings-toggle{width:52px;height:52px;padding:0}.audio-settings-toggle[aria-expanded=true]{background:#0f766e}.audio-settings-toggle svg{fill:currentColor;width:24px;height:24px}.mic-button{gap:10px;min-width:168px;padding:14px 18px}.mic-button.is-on{background:#be123c}.mic-icon{place-items:center;width:24px;height:24px;display:grid}.mic-icon svg{fill:currentColor;width:24px;height:24px}.error-banner{color:#9f1239;background:#fff1f2;border:1px solid #fecdd3;border-radius:8px;width:min(520px,100% - 32px);padding:12px 14px;font-weight:700;position:fixed;top:16px;left:50%;transform:translate(-50%)}.log-toggle{color:#172033;background:#fff;border-radius:8px;padding:9px 12px;position:fixed;top:16px;right:16px;box-shadow:0 6px 18px #1720331f}.log-panel{background:#fff;border:1px solid #d7e1ea;border-radius:8px;gap:10px;width:min(460px,100% - 32px);max-height:min(520px,100vh - 92px);padding:14px;display:grid;position:fixed;top:60px;right:16px;overflow:hidden;box-shadow:0 16px 42px #1720332e}.log-panel h2{font-size:16px}#log{background:#f8fafc;border-radius:6px;min-height:0;margin:0;padding:10px 10px 10px 30px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px;overflow:auto}#log li{margin:5px 0}#log .ok{color:#047857}#log .error{color:#be123c}[hidden]{display:none!important}@media (width<=820px){.room-view{grid-template-columns:minmax(0,1fr);place-items:stretch stretch;padding-bottom:120px}.request-panel{width:100%}.device-panel{width:calc(100% - 32px);max-height:calc(100vh - 124px);bottom:92px;right:16px;overflow:auto}}
