:root{--accent: #ff5680;--accent-ink: #ffffff;--live: #46bdbd;--font-sans: "Kanit", "Hanken Grotesk", system-ui, sans-serif;--font-mono: "DM Mono", ui-monospace, "SF Mono", monospace;--r-sm: 10px;--r: 14px;--r-lg: 20px;--pad-page: clamp(.9rem, 4vw, 2.5rem);--gap: clamp(.9rem, 2.5vw, 1.5rem)}:root,:root[data-theme=dark]{--bg: #241a21;--surface: #2e2230;--surface-2: #382a37;--surface-3: #46343f;--text: #f7eff2;--text-dim: #c6adb8;--text-faint: #93808b;--border: #43323f;--border-strong: #58414f;--accent: #ff7a9c;--shadow: 0 1px 2px rgba(0,0,0,.4), 0 12px 32px rgba(0,0,0,.4)}:root[data-theme=light]{--bg: #fff3f6;--surface: #ffffff;--surface-2: #fff5f8;--surface-3: #ffe9ef;--text: #34344f;--text-dim: #6b6b85;--text-faint: #a89bb0;--border: #ffdde6;--border-strong: #ffc9d6;--accent: #ff5680;--shadow: 0 1px 2px rgba(180,120,140,.08), 0 12px 30px rgba(255,140,165,.18)}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;font-family:var(--font-sans);background:var(--bg);color:var(--text);min-height:100dvh;overflow-x:clip;line-height:1.5;font-size:16px;-webkit-font-smoothing:antialiased;transition:background .3s ease,color .3s ease}:root[data-theme=light] body{background:radial-gradient(900px 600px at 10% 8%,#ffe3ec 0%,transparent 60%),radial-gradient(900px 700px at 92% 95%,#fff0df 0%,transparent 55%),linear-gradient(125deg,#ffe9ef,#fff3ea 55%,#fdeede);background-attachment:fixed}:root[data-theme=dark] body{background:radial-gradient(800px 600px at 88% 100%,#3a2433 0%,transparent 60%),var(--bg);background-attachment:fixed}::selection{background:var(--accent);color:var(--accent-ink)}.muted{color:var(--text-dim)}.error{color:var(--accent);font-weight:500}.error.small,.small{font-size:.82rem}.mono{font-family:var(--font-mono)}button{font:inherit;font-family:var(--font-sans);cursor:pointer;border:1px solid var(--border-strong);color:var(--text);background:var(--surface-2);border-radius:var(--r-sm);padding:.6rem 1rem;font-weight:600;font-size:.92rem;transition:background .15s ease,border-color .15s ease,transform .06s ease,opacity .15s ease}button:hover:not(:disabled){background:var(--surface-3)}button:active:not(:disabled){transform:translateY(1px)}button:disabled{opacity:.45;cursor:default}button.primary{background:var(--accent);color:var(--accent-ink);border-color:transparent}button.primary:hover:not(:disabled){background:var(--accent);filter:brightness(1.08)}button.secondary{background:var(--surface-2)}button.small{padding:.42rem .7rem;font-size:.82rem}.link-btn{background:transparent;border:none;color:var(--text-dim);font-weight:600;font-size:.9rem;padding:.4rem .5rem}.link-btn:hover{background:transparent;color:var(--text)}.icon-btn{display:grid;place-items:center;width:38px;height:38px;padding:0;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);font-size:1rem;color:var(--text)}.theme-toggle{display:grid;place-items:center;width:38px;height:38px;padding:0;background:var(--surface);border:1px solid var(--border);border-radius:50%;font-size:.9rem;color:var(--accent)}.theme-toggle:hover{background:var(--surface-2);filter:brightness(.99)}.topbar-pill{display:inline-flex;align-items:center;gap:.45rem;background:var(--surface);border:1px solid var(--border);color:var(--text-dim);border-radius:999px;padding:.42rem .95rem;font-weight:600;font-size:.85rem}.topbar-pill i{color:var(--accent);font-size:.8rem}.topbar-pill:hover{background:var(--surface-2);color:var(--text)}input{font:inherit;font-family:var(--font-sans);background:var(--surface);border:1px solid var(--border-strong);color:var(--text);border-radius:var(--r-sm);padding:.7rem .85rem;width:100%;outline:none;transition:border-color .15s ease,box-shadow .15s ease}input::placeholder{color:var(--text-faint)}input:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 18%,transparent)}.label{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-faint)}.app{width:100%;max-width:1120px;margin:0 auto;min-height:100dvh;padding:0 var(--pad-page) clamp(2rem,6vw,4rem);display:flex;flex-direction:column}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:.8rem;padding:.9rem 0;margin-bottom:clamp(1.2rem,4vw,2.4rem);background:transparent}.topbar:before{content:"";position:absolute;inset:0 calc(50% - 50vw);z-index:-1;background:color-mix(in srgb,var(--bg) 78%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);box-shadow:0 4px 18px #0000000a;opacity:0;pointer-events:none;transition:opacity .25s ease}.topbar.scrolled:before{opacity:1}.topbar-actions{display:flex;align-items:center;gap:.5rem}.app-footer{display:flex;align-items:center;justify-content:center;gap:.55rem;flex-wrap:wrap;margin-top:auto;padding:1.5rem 1rem 1.6rem;font-size:.74rem;color:var(--text-faint);text-align:center}.app-version{color:var(--text-dim);letter-spacing:.02em}.app-version:before{content:"·";margin-right:.55rem;color:var(--text-faint)}.brand{background:transparent;border:none;padding:0;display:inline-flex;align-items:center;gap:.6rem;cursor:pointer}.brand-logo{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,#ff8aa8,var(--accent));color:#fff;font-size:.85rem;box-shadow:0 5px 14px color-mix(in srgb,var(--accent) 38%,transparent)}.brand-name{display:inline-flex;align-items:baseline;gap:.4rem;font-size:1.18rem;font-weight:800;letter-spacing:-.02em;color:var(--text)}.brand small{display:none}.app-body{flex:1}.home{display:grid;gap:clamp(1.6rem,5vw,3rem);max-width:640px;margin:clamp(1rem,6vw,4rem) auto 0}.hero{text-align:center}.hero h1{font-size:clamp(2.1rem,8vw,3.5rem);font-weight:800;letter-spacing:-.035em;line-height:1.04;margin:0 0 .7rem}.hero h1 em{font-style:normal;color:var(--accent)}.hero p{color:var(--text-dim);max-width:30rem;margin:0 auto;font-size:clamp(.98rem,2.5vw,1.1rem)}.dial-strip{display:none}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:clamp(1.2rem,4vw,2rem);display:grid;gap:1.4rem;box-shadow:var(--shadow)}.field{display:grid;gap:.45rem}.field span,.split-col h3{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-faint);font-weight:500}.split{display:grid;grid-template-columns:1fr auto 1fr;gap:1.2rem;align-items:stretch}.split-col{display:grid;gap:.6rem;align-content:start}.split-col h3{margin:0}.divider{display:grid;place-items:center;position:relative}.divider:before{content:"";position:absolute;top:0;bottom:0;width:1px;background:var(--border)}.divider span{background:var(--surface);padding:.4rem 0;z-index:1;font-family:var(--font-mono);font-size:.72rem;color:var(--text-faint)}.room-loading,.room-error{text-align:center;margin:clamp(3rem,12vw,6rem) auto;display:grid;gap:1.2rem;place-items:center;color:var(--text-dim);font-size:1rem}.room-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:var(--gap)}.station-plate{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;min-width:0;flex:1 1 auto}.station-plate h2{margin:0;font-size:clamp(1.25rem,4vw,1.6rem);font-weight:700;letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60vw}.freq-readout{font-family:var(--font-mono);background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:.3rem .8rem;color:var(--text);display:inline-flex;align-items:baseline;gap:.45rem}.freq-readout small{font-size:.6rem;letter-spacing:.12em;color:var(--text-faint);text-transform:uppercase}.freq-readout strong{font-size:.95rem;letter-spacing:.08em;font-weight:500}.share-btns{display:inline-flex;gap:.4rem}.copy-link{display:inline-flex;align-items:center;gap:.4rem}.room-head-right{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap}.members-wrap{position:relative}.members{display:flex;align-items:center;background:transparent;border:none;box-shadow:none;padding:.2rem .3rem;border-radius:999px;cursor:pointer}.members:hover{background:var(--surface-2)}.avatar{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-size:.78rem;font-weight:700;color:var(--accent-ink);background:var(--surface-3);color:var(--text);border:2px solid var(--bg);margin-left:-8px;flex-shrink:0}.avatar.me{background:var(--accent);color:var(--accent-ink)}.member-count{margin-left:.6rem;font-family:var(--font-mono);font-size:.72rem;color:var(--text-dim)}.listeners-pop{position:absolute;top:calc(100% + 8px);right:0;z-index:30;min-width:248px;max-width:360px;max-height:320px;overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);padding:.5rem}.listeners-head{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint);padding:.3rem .5rem .5rem}.listeners-pop ul{list-style:none;margin:0;padding:0;display:grid;gap:.1rem}.listeners-pop li{display:flex;align-items:center;gap:.5rem;padding:.4rem .5rem;border-radius:var(--r-sm)}.listeners-pop li:hover{background:var(--surface-2)}.listeners-pop .avatar{margin-left:0}.listener-name{font-size:.9rem;display:flex;align-items:center;gap:.4rem;min-width:0}.listener-name>:first-child{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.listeners-pop li .listener-name{flex:1}.you-tag,.host-tag{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;border-radius:999px;padding:.05rem .4rem;flex-shrink:0;white-space:nowrap}.you-tag{color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 40%,transparent)}.host-tag{color:var(--text-dim);border:1px solid var(--border-strong)}.kick-btn{flex-shrink:0;background:transparent;border:none;box-shadow:none;color:var(--text-faint);padding:.25rem .4rem;font-size:.8rem;border-radius:var(--r-sm)}.kick-btn:hover{background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent)}.room-grid{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:var(--gap);align-items:start}.stage{display:grid;gap:.9rem;min-width:0}.video-wrap{position:relative;aspect-ratio:16 / 9;border-radius:var(--r);overflow:hidden;background:#000;border:1px solid var(--border)}.video,.video iframe,.video-cf,.video-cf iframe{width:100%;height:100%}.video-cf{position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none}.cf-toggle{flex-shrink:0;width:38px;height:38px;padding:0;display:grid;place-items:center;border-radius:50%;border:1px solid var(--border);background:var(--surface-2);color:var(--text-faint);font-size:.82rem}.cf-toggle.active{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 45%,var(--border))}.cf-control{position:relative;flex-shrink:0}.cf-popover{position:absolute;bottom:calc(100% + 8px);right:0;z-index:30;width:210px;padding:.7rem .8rem .6rem;border-radius:var(--r);background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow)}.cf-pop-head{display:flex;align-items:baseline;justify-content:space-between;font-size:.8rem;font-weight:600;margin-bottom:.5rem}.cf-val{color:var(--accent);font-size:.78rem}.cf-slider{width:100%;accent-color:var(--accent);cursor:pointer}.cf-pop-foot{font-size:.66rem;margin-top:.45rem}.video-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-content:center;text-align:center;gap:.3rem;padding:1rem;z-index:1;color:#d6d6d6}.video-empty p:first-child{font-size:1.1rem;font-weight:600;color:#fff}.video-empty .muted{color:#9a9a98;font-size:.9rem}.gesture-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;border:none;border-radius:0;background:#08080ac7;color:#fff;font-size:1.05rem;font-weight:600;gap:.7rem;display:flex;flex-direction:column;align-items:center;justify-content:center}.gesture-play{display:grid;place-items:center;width:64px;height:64px;border-radius:50%;background:var(--accent);color:var(--accent-ink);font-size:1.4rem;padding-left:4px}.now-playing{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.2rem .1rem}.np-title{display:grid;gap:.1rem;overflow:hidden;min-width:0}.np-title strong{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.np-title .muted{font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.np-time{font-family:var(--font-mono);font-size:.82rem;color:var(--text-dim);white-space:nowrap}.player{display:flex;flex-direction:column;gap:.7rem}.controls{display:grid}.control-row{display:flex;align-items:center;justify-content:center;gap:.6rem;flex-wrap:wrap}.control-row button{width:44px;height:44px;padding:0;border-radius:50%;font-size:1rem;background:var(--surface-2);border:1px solid var(--border);display:grid;place-items:center}.control-row button:hover:not(:disabled){background:var(--surface-3)}.play-btn{width:58px!important;height:58px!important;font-size:1.3rem!important;background:var(--accent)!important;color:var(--accent-ink)!important;border:none!important}.play-btn:hover:not(:disabled){filter:brightness(1.08)}.mode-btn{font-size:.95rem}.mode-btn.active{background:var(--accent)!important;color:var(--accent-ink)!important;border-color:transparent!important}.mode-btn.active:hover{filter:brightness(1.08)}.loop-btn{position:relative}.loop-one{position:absolute;top:6px;right:8px;font-size:.55rem;font-weight:800;line-height:1;font-family:var(--font-mono)}.seek-row{display:flex;align-items:center;gap:.9rem}.seek-row .seekbar{flex:1;min-width:0}.volume-control{position:relative;flex-shrink:0}.vol-popover{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);z-index:30;display:grid;gap:.5rem;place-items:center;padding:.7rem .5rem .5rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow)}.vslider{position:relative;width:30px;height:120px;touch-action:none;cursor:pointer}.vslider:before{content:"";position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%);width:6px;border-radius:999px;background:var(--surface-3)}.vslider-fill{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:6px;border-radius:999px;background:var(--text);pointer-events:none}.vslider-thumb{position:absolute;left:50%;width:15px;height:15px;border-radius:50%;background:var(--text);border:2px solid var(--bg);transform:translate(-50%,50%);box-shadow:0 1px 3px #0000004d;pointer-events:none}.voice-listen{display:inline-flex;align-items:center;gap:.4rem;padding:.2rem .5rem;border-radius:999px;background:var(--surface-2);border:1px solid var(--border)}.voice-listen .volbar{max-width:110px}.voice-listen .vol-btn{width:30px;height:28px;border:none;background:transparent}.voice-listen .vol-pct{width:2.4ch}.vol-btn{width:40px;height:36px;padding:0;border-radius:var(--r-sm);font-size:1rem;background:var(--surface-2);border:1px solid var(--border)}.vol-btn.active{color:var(--accent)}.vol-step{width:32px;height:36px;padding:0;border-radius:var(--r-sm);background:var(--surface-2);border:1px solid var(--border);font-size:1.2rem;line-height:1;color:var(--text-dim)}.vol-step:hover{color:var(--text)}.volbar{width:100%;max-width:200px;background:linear-gradient(to right,var(--text) var(--pct),var(--surface-3) var(--pct))}.volbar::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--text);border:2px solid var(--bg)}.volbar::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--text);border:2px solid var(--bg)}.volbar::-moz-range-progress{background:var(--text);height:6px;border-radius:999px}.vol-pct{font-family:var(--font-mono);font-size:.78rem;color:var(--text-dim);width:2ch;text-align:right}.seekbar,.volbar{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:6px;border-radius:999px;cursor:pointer;outline:none;--pct: 0%}.seekbar{width:100%;background:linear-gradient(to right,var(--accent) var(--pct),var(--surface-3) var(--pct))}.seekbar:disabled{background:var(--surface-3);cursor:default}.seekbar::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:15px;height:15px;border-radius:50%;background:var(--accent);border:2px solid var(--bg);box-shadow:0 1px 3px #0000004d}.seekbar::-moz-range-thumb{width:15px;height:15px;border-radius:50%;background:var(--accent);border:2px solid var(--bg)}.seekbar::-moz-range-progress{background:var(--accent);height:6px;border-radius:999px}.voicebar{display:flex;align-items:center;gap:.8rem 1rem;flex-wrap:wrap;padding:.85rem 1rem;border-radius:var(--r);background:var(--surface);border:1px solid var(--border)}.voice-left{display:flex;gap:.5rem;align-items:center}.voice-join{display:inline-flex;align-items:center;gap:.4rem}.voice-mute{display:inline-flex;align-items:center;gap:.45rem;background:var(--surface-2);border:1px solid var(--border-strong)}.voice-mute:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--live)}.voice-mute.muted{color:var(--text-dim)}.voice-mute.muted:before{background:var(--text-faint)}.onair-lamp{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint);padding:.3rem .6rem;border-radius:999px;border:1px solid var(--border)}.onair-lamp:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--text-faint)}.onair-lamp.live{color:var(--live);border-color:color-mix(in srgb,var(--live) 40%,transparent)}.onair-lamp.live:before{background:var(--live);box-shadow:0 0 0 3px color-mix(in srgb,var(--live) 22%,transparent);animation:pulse 1.4s ease-in-out infinite}@keyframes pulse{50%{box-shadow:0 0 0 5px color-mix(in srgb,var(--live) 0%,transparent)}}.voice-people{display:flex;gap:.45rem;flex-wrap:wrap;align-items:center;flex:1;min-width:0}.voice-people .small{font-family:var(--font-mono);font-size:.74rem}.voice-foot{width:100%;display:flex;flex-wrap:wrap;align-items:center;gap:.4rem 1.1rem;border-top:1px solid var(--border);padding-top:.6rem;margin-top:.1rem;color:var(--text-dim);font-size:.78rem}.voice-hint,.voice-stats{display:inline-flex;align-items:center;gap:.4rem}.voice-stats{font-family:var(--font-mono)}.voice-stats.warn{color:var(--accent)}.talker{display:inline-flex;align-items:center;gap:.5rem;background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:.32rem .7rem .32rem .55rem}.talker.live{border-color:color-mix(in srgb,var(--live) 45%,transparent)}.talker-dot{width:7px;height:7px;border-radius:50%;background:var(--text-faint);transition:background .12s}.talker.live .talker-dot{background:var(--live)}.talker-name{font-size:.82rem;font-weight:600;max-width:9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.talker-meter{width:34px;height:5px;border-radius:999px;background:var(--surface-3);overflow:hidden}.talker-meter i{display:block;height:100%;width:100%;background:var(--live);transform-origin:left;transform:scaleX(0);transition:transform .09s linear;border-radius:999px}.side{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;height:clamp(420px,62vh,600px)}.tabs{display:flex;padding:.4rem;gap:.3rem;border-bottom:1px solid var(--border)}.tabs button{flex:1;background:transparent;border:none;border-radius:var(--r-sm);color:var(--text-dim);font-weight:600;padding:.55rem}.tabs button:hover{background:var(--surface-2)}.tabs button.active{background:var(--surface-2);color:var(--text)}.pane{display:none;flex:1;min-height:0}.pane.show{display:flex;flex-direction:column}.playlist{display:flex;flex-direction:column;min-height:0;flex:1}.add-song{display:flex;gap:.5rem;padding:.75rem;border-bottom:1px solid var(--border)}.songs{list-style:none;margin:0;padding:.4rem;overflow-y:auto;flex:1;display:grid;gap:.15rem;align-content:start}.song{display:flex;align-items:center;gap:.5rem;padding:.4rem;border-radius:var(--r-sm)}.song:hover,.song.playing{background:var(--surface-2)}.song.dragging{background:var(--surface-3);opacity:.85;box-shadow:0 4px 14px #00000059}.drag-handle{background:transparent;border:none;box-shadow:none;padding:.25rem .1rem;color:var(--text-faint);cursor:grab;touch-action:none;flex-shrink:0;font-size:.85rem;display:grid;place-items:center}.drag-handle:hover{background:transparent;color:var(--text-dim)}.drag-handle:active{cursor:grabbing}.song .thumb{width:52px;height:36px;object-fit:cover;border-radius:5px;flex-shrink:0}.song-main{background:transparent;border:none;box-shadow:none;text-align:left;flex:1;min-width:0;display:grid;gap:.1rem;padding:0;overflow:hidden;font-weight:400}.song-main:hover{background:transparent}.song-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;font-size:.88rem;font-weight:500}.song.playing .song-title{color:var(--accent)}.song-meta{font-family:var(--font-mono);font-size:.66rem;color:var(--text-faint)}.song-dur{flex-shrink:0;font-size:.74rem;color:var(--text-dim);font-variant-numeric:tabular-nums;letter-spacing:.02em}.songs-summary{display:flex;align-items:center;justify-content:space-between;padding:.1rem .45rem .5rem;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint)}.songs-total{color:var(--text-dim);text-transform:none;letter-spacing:.02em;font-variant-numeric:tabular-nums}.song-remove{background:transparent;border:none;box-shadow:none;color:var(--text-faint);padding:.3rem .45rem;font-size:.9rem}.song-remove:hover{background:transparent;color:var(--accent)}.empty{padding:1.6rem 1rem;text-align:center;font-size:.85rem}.chat{display:flex;flex-direction:column;flex:1;min-height:0}.messages{flex:1;overflow-y:auto;padding:.85rem;display:flex;flex-direction:column;gap:.5rem}.msg{display:grid;gap:.12rem;max-width:88%}.msg-name{font-size:.68rem;font-weight:600;color:var(--text-dim)}.msg-text{background:var(--surface-2);padding:.45rem .7rem;border-radius:4px 12px 12px;font-size:.9rem;word-break:break-word}.msg.mine{margin-left:auto}.msg.mine .msg-text{background:var(--accent);color:var(--accent-ink);border-radius:12px 4px 12px 12px}.msg.mine .msg-name{text-align:right}.msg.system,.msg.system span{max-width:100%;text-align:center;font-family:var(--font-mono);font-size:.7rem;color:var(--text-faint)}.msg-head{display:flex;align-items:baseline;gap:.4rem}.msg.mine .msg-head{justify-content:flex-end}.msg-time{font-family:var(--font-mono);font-size:.6rem;color:var(--text-faint);white-space:nowrap}.msg.system .msg-time{margin-left:.35rem;opacity:.8}.chat-input{display:flex;gap:.5rem;padding:.75rem;border-top:1px solid var(--border)}.songs::-webkit-scrollbar,.messages::-webkit-scrollbar,.modal::-webkit-scrollbar{width:8px}.songs::-webkit-scrollbar-thumb,.messages::-webkit-scrollbar-thumb,.modal::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;padding:1rem;background:color-mix(in srgb,var(--bg) 55%,rgba(0,0,0,.6));-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);width:min(620px,100%);max-height:86dvh;overflow-y:auto;padding:clamp(1.2rem,4vw,1.8rem);box-shadow:var(--shadow)}.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.2rem}.modal-head h2{margin:0;font-size:1.4rem;font-weight:700;letter-spacing:-.02em}.diary-modal{display:flex;flex-direction:column;padding-bottom:.6rem}.diary-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.8rem;margin-bottom:1rem}.diary-head h2{margin:0 0 .15rem;font-size:1.4rem;font-weight:700;letter-spacing:-.02em}.diary-head-actions{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.modal-close{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:var(--surface-2);color:var(--text-dim);cursor:pointer;font-size:.85rem;display:grid;place-items:center;padding:0}.modal-close:hover{background:var(--surface-3);color:var(--text)}.diary-scroll{overflow-y:auto;display:grid;gap:1.2rem;padding-right:.2rem}.diary-empty{text-align:center;padding:clamp(2rem,8vw,4rem) 1rem;display:grid;gap:.4rem;place-items:center}.diary-empty i{font-size:2.2rem;color:var(--accent);opacity:.6;margin-bottom:.4rem}.diary-empty p{margin:0}.diary-day-label{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint);margin-bottom:.5rem}.diary-tracks{list-style:none;margin:0;padding:0;display:grid;gap:.3rem}.diary-track{display:flex;align-items:center;gap:.7rem;padding:.35rem;border-radius:var(--r-sm)}.diary-track:hover{background:var(--surface-2)}.dt-thumb{flex-shrink:0;line-height:0}.dt-thumb img{width:56px;height:38px;object-fit:cover;border-radius:6px;display:block}.dt-main{display:grid;gap:.1rem;flex:1;min-width:0}.dt-title{font-weight:600;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dt-sub{font-size:.74rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dt-time{font-family:var(--font-mono);font-size:.66rem;flex-shrink:0;white-space:nowrap}.diary-songs a:hover{color:var(--accent)}.toast{position:fixed;left:50%;bottom:max(1.4rem,env(safe-area-inset-bottom));transform:translate(-50%);z-index:60;background:var(--text);color:var(--bg);font-size:.88rem;font-weight:500;padding:.7rem 1.1rem;border-radius:999px;box-shadow:var(--shadow);max-width:calc(100vw - 2rem);text-align:center}@media(min-width:560px){.brand small{display:inline;font-family:var(--font-mono);font-size:.62rem;letter-spacing:.12em;color:var(--text-faint);margin-left:.1rem}}@media(max-width:900px){.room-grid{grid-template-columns:1fr}.side{height:clamp(440px,70vh,640px)}}@media(max-width:520px){.split{grid-template-columns:1fr;gap:.9rem}.divider{padding:.1rem 0}.divider:before{width:auto;left:0;right:0;top:50%;height:1px}.station-plate{width:100%;flex-wrap:nowrap;gap:.5rem}.station-plate h2{flex:0 1 auto;min-width:1.5rem;max-width:none}.station-plate .freq-readout{flex-shrink:0}.freq-readout small{display:none}.station-plate .share-btns{flex-shrink:0}.copy-link .cl-text{display:none}.copy-link{padding:.46rem .62rem}.room-head-right{width:100%;flex-wrap:nowrap;justify-content:space-between;gap:.5rem}.room-head-right .join-policy{order:1;min-width:0}.room-head-right .members-wrap{order:2;flex-shrink:0}.join-policy .jp-label{display:none}.jp-current{white-space:nowrap}.listeners-pop{max-width:calc(100vw - 1.6rem)}.seek-row{gap:.55rem}.control-row{flex-wrap:nowrap;gap:.28rem}.control-row button{width:38px;height:38px;font-size:.92rem}.play-btn{width:46px!important;height:46px!important;font-size:1.1rem!important}.talker-name{max-width:6rem}}@media(max-width:340px){.control-row{gap:.2rem}.control-row button{width:34px;height:34px}.play-btn{width:42px!important;height:42px!important}}.landing,:root[data-theme=light] .landing{--lp-ink: #34344f;--lp-ink-soft: #6b6b85;--lp-coral: #ff6f91;--lp-coral-d: #ff5680;--lp-surface: #ffffff;--lp-input: #fff7f9;--lp-border: #ffd9e2;--lp-chip: rgba(255,255,255,.72);--lp-frame: rgba(255,255,255,.9);--lp-glow: rgba(255,170,190,.5);--lp-modal-bg: rgba(120,80,95,.35);--lp-bg: radial-gradient(900px 600px at 12% 18%, #ffe3ec 0%, transparent 60%), radial-gradient(900px 700px at 92% 80%, #fff0df 0%, transparent 55%), linear-gradient(120deg, #ffe7ee 0%, #fff2e9 52%, #fdeede 100%)}:root[data-theme=dark] .landing{--lp-ink: #f2ebef;--lp-ink-soft: #b8a7b1;--lp-coral: #ff8aa8;--lp-coral-d: #ff7a9c;--lp-surface: #2c2433;--lp-input: #352b3a;--lp-border: #4a3a47;--lp-chip: rgba(255,255,255,.08);--lp-frame: rgba(255,255,255,.12);--lp-glow: rgba(255,130,160,.28);--lp-modal-bg: rgba(8,5,11,.6);--lp-bg: radial-gradient(900px 700px at 85% 92%, #322a47 0%, transparent 60%), radial-gradient(800px 600px at 12% 10%, #2a2238 0%, transparent 55%), linear-gradient(125deg, #1c1a2c 0%, #231d2f 55%, #2a1f30 100%)}.landing{position:relative;min-height:100dvh;overflow:hidden;font-family:Kanit,Hanken Grotesk,sans-serif;color:var(--lp-ink);background:var(--lp-bg);padding:clamp(1.1rem,3vw,2rem) clamp(1.1rem,5vw,4.5rem);display:flex;flex-direction:column}.landing .deco{position:absolute;pointer-events:none;z-index:0;opacity:.9}.landing .deco.note{color:#ff9db4}.landing .deco.heart{color:#ff8fb0}.landing .deco.cloud{color:#bfe0ff}.landing .n1{top:14%;left:44%;font-size:1.4rem;transform:rotate(-12deg)}.landing .n2{top:30%;left:52%;font-size:1rem;color:#8fb4ff;transform:rotate(10deg)}.landing .n3{top:8%;right:6%;font-size:1.6rem;color:#ffc24b}.landing .h1{top:9%;left:36%;font-size:.9rem}.landing .h2{top:40%;left:60%;font-size:1.2rem;color:#ffbf6e}.landing .h3{bottom:14%;right:4%;font-size:1rem}.landing .c1{top:20%;left:60%;font-size:1.8rem;opacity:.6}.landing .c2{bottom:18%;left:30%;font-size:1.5rem;opacity:.5}.lp-brand{position:relative;z-index:2;display:flex;align-items:center;gap:.7rem}.lp-logo{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,#ff8aa8,#ff6f91);color:#fff;font-size:1rem;box-shadow:0 6px 16px #ff6f9159}.lp-brand-text{font-weight:600;font-size:.92rem;line-height:1.1;color:var(--lp-ink)}.lp-brand-actions{margin-left:auto;display:flex;align-items:center;gap:.5rem}.lp-diary{background:var(--lp-chip);border:1px solid var(--lp-border);color:var(--lp-coral-d);border-radius:999px;padding:.45rem 1rem;font-family:inherit;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem}.lp-diary:hover,.lp-toggle:hover{filter:brightness(1.06)}.lp-toggle{width:38px;height:38px;padding:0;border-radius:50%;border:1px solid var(--lp-border);background:var(--lp-chip);color:var(--lp-coral-d);cursor:pointer;font-size:.88rem;display:grid;place-items:center;font-family:inherit}.lp-grid{position:relative;z-index:1;flex:1;display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(1.5rem,4vw,3rem);align-items:center}.lp-copy h1{font-size:clamp(2.4rem,6vw,4.2rem);font-weight:700;line-height:1.05;letter-spacing:-.01em;margin:0 0 1rem}.lp-copy h1 .hl{color:var(--lp-coral)}.lp-sub{font-size:clamp(.98rem,1.6vw,1.15rem);font-weight:300;color:var(--lp-ink-soft);max-width:30rem;margin:0 0 1.8rem;line-height:1.7}.lp-features{display:flex;gap:1.4rem;flex-wrap:wrap;margin-bottom:2rem}.lp-feature{display:flex;align-items:center;gap:.6rem}.lp-fic{width:46px;height:46px;border-radius:16px;display:grid;place-items:center;color:#fff;font-size:1.1rem;flex-shrink:0;box-shadow:0 8px 18px #00000014}.lp-fic.f-music{background:linear-gradient(135deg,#ff8aa8,#ff6f91)}.lp-fic.f-talk{background:linear-gradient(135deg,#6fd1cf,#46bdbd)}.lp-fic.f-diary{background:linear-gradient(135deg,#ffd76a,#ffc24b)}.lp-ftxt{display:grid;line-height:1.25}.lp-ftxt strong{font-weight:600;font-size:.95rem}.lp-ftxt span{font-weight:300;font-size:.78rem;color:var(--lp-ink-soft)}.lp-cta{border:none;cursor:pointer;font-family:inherit;font-weight:500;font-size:clamp(1rem,1.4vw,1.15rem);color:#fff;background:linear-gradient(135deg,#ff8aa8,#ff5680);border-radius:999px;padding:.95rem 2.1rem;display:inline-flex;align-items:center;gap:.6rem;box-shadow:0 12px 26px #ff568066;transition:transform .1s ease,box-shadow .2s ease}.lp-cta:hover{transform:translateY(-2px);box-shadow:0 16px 32px #ff568080}.lp-cta:active{transform:translateY(0)}.lp-cta i{font-size:.85em}.lp-art{position:relative;display:grid;place-items:center}.lp-photo{position:relative;z-index:1;width:min(100%,480px);aspect-ratio:3/2;border-radius:28px;overflow:hidden;box-shadow:0 30px 60px #78506447;border:6px solid var(--lp-frame)}.lp-photo img{width:100%;height:100%;object-fit:cover;display:block}.lp-art:before{content:"";position:absolute;width:78%;aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,var(--lp-glow),transparent 70%);filter:blur(10px);z-index:0;transform:translate(8%,-6%)}.lp-modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;padding:1rem;background:var(--lp-modal-bg);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.lp-modal{position:relative;width:min(560px,100%);background:var(--lp-surface);border-radius:24px;padding:clamp(1.4rem,4vw,2.2rem);box-shadow:0 30px 70px #28142859;font-family:Kanit,sans-serif;color:var(--lp-ink)}.lp-close{position:absolute;top:1rem;right:1rem;width:34px;height:34px;padding:0;border-radius:50%;border:none;background:var(--lp-chip);color:var(--lp-coral-d);cursor:pointer;font-size:.9rem;display:grid;place-items:center;line-height:1}.lp-close:hover{filter:brightness(1.06)}.lp-modal h2{margin:0 0 1.2rem;font-weight:600;font-size:1.5rem}.lp-field{display:grid;gap:.4rem;margin-bottom:1.2rem}.lp-field span,.lp-col h4{font-size:.85rem;font-weight:500;color:var(--lp-ink-soft);margin:0}.lp-modal input{font-family:inherit;font-size:.95rem;width:100%;background:var(--lp-input);border:1.5px solid var(--lp-border);border-radius:12px;padding:.7rem .9rem;color:var(--lp-ink);outline:none}.lp-modal input::placeholder{color:var(--lp-ink-soft);opacity:.7}.lp-modal input:focus{border-color:var(--lp-coral);box-shadow:0 0 0 3px #ff6f9126}.lp-split{display:grid;grid-template-columns:1fr auto 1fr;gap:1rem;align-items:stretch}.lp-col{display:grid;gap:.5rem;align-content:start}.lp-or{display:grid;place-items:center;position:relative;color:var(--lp-ink-soft);font-size:.8rem}.lp-or:before{content:"";position:absolute;top:0;bottom:0;width:1px;background:var(--lp-border)}.lp-btn{font-family:inherit;font-weight:500;font-size:.95rem;cursor:pointer;border-radius:12px;padding:.7rem;border:1.5px solid var(--lp-border);background:var(--lp-surface);color:var(--lp-coral-d)}.lp-btn:hover:not(:disabled){filter:brightness(1.04)}.lp-btn.primary{background:linear-gradient(135deg,#ff8aa8,#ff5680);color:#fff;border-color:transparent}.lp-btn:disabled{opacity:.5;cursor:default}.lp-error{color:var(--lp-coral-d);font-size:.88rem;margin:1rem 0 0;text-align:center}@media(max-width:860px){.lp-grid{grid-template-columns:1fr;text-align:center;gap:1.6rem}.lp-copy{order:2}.lp-art{order:1}.lp-sub{margin-left:auto;margin-right:auto}.lp-features{justify-content:center}.landing .deco{display:none}.lp-photo{width:min(100%,360px)}}@media(max-width:520px){.lp-split{grid-template-columns:1fr;gap:.8rem}.lp-or:before{width:auto;left:0;right:0;top:50%;height:1px}.lp-features{gap:1rem}.lp-feature{flex-direction:column;gap:.35rem;width:5.5rem}}.add-box,.add-song{position:relative}.add-search-icon{position:absolute;left:1.4rem;top:50%;transform:translateY(-50%);color:var(--text-faint);font-size:.82rem;pointer-events:none;z-index:1}.add-song input{padding-left:2rem}.search-results{position:absolute;left:.5rem;right:.5rem;top:calc(100% - .35rem);z-index:25;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);max-height:330px;overflow-y:auto;padding:.3rem}.search-status{padding:.7rem}.search-row{display:flex;align-items:center;gap:.6rem;width:100%;text-align:left;background:transparent;border:none;box-shadow:none;padding:.4rem;border-radius:var(--r-sm);cursor:pointer}.search-row:hover{background:var(--surface-2)}.search-row img{width:58px;height:40px;object-fit:cover;border-radius:5px;flex-shrink:0}.sr-main{display:grid;gap:.1rem;flex:1;overflow:hidden;min-width:0}.sr-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.88rem;font-weight:500}.sr-meta{font-family:var(--font-mono);font-size:.66rem;color:var(--text-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sr-add{color:var(--accent);font-size:.8rem;flex-shrink:0}.search-results::-webkit-scrollbar{width:8px}.search-results::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px}.player-error{background:#08080ad1;z-index:2}.join-policy{display:inline-flex;align-items:center;gap:.4rem;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);padding:.28rem .6rem;color:var(--text-dim);font-size:.82rem}.join-policy.editable{border-color:var(--accent);cursor:pointer}.join-policy i{color:var(--accent);font-size:.82rem}.jp-label{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint)}.jp-static{font-size:.82rem;font-weight:700;color:var(--text)}.jp-dropdown{position:relative;display:inline-flex}.jp-current{background:transparent;border:none;padding:.2rem 0;cursor:pointer;color:var(--accent);font-weight:700;font-size:.82rem;display:inline-flex;align-items:center;gap:.4rem}.jp-current i{font-size:.62rem;transition:transform .15s ease}.join-policy:has(.jp-menu) .jp-current i{transform:rotate(180deg)}.jp-menu{position:absolute;top:calc(100% + .45rem);right:0;z-index:30;min-width:190px;padding:.3rem;display:grid;gap:.12rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow)}.jp-opt{display:flex;align-items:center;justify-content:space-between;gap:.6rem;width:100%;text-align:left;background:transparent;border:none;border-radius:var(--r-sm);padding:.5rem .7rem;cursor:pointer;color:var(--text);font-weight:600;font-size:.85rem}.jp-opt:hover{background:var(--surface-2)}.jp-opt.active{color:var(--accent)}.jp-opt i{font-size:.72rem}.approval-bar{display:grid;gap:.5rem;margin-bottom:var(--gap);background:color-mix(in srgb,var(--accent) 8%,var(--surface));border:1px solid color-mix(in srgb,var(--accent) 35%,var(--border));border-radius:var(--r);padding:.7rem .8rem}.approval-req{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.approval-req .avatar{flex-shrink:0}.ar-name{flex:1;min-width:8rem;color:var(--text-dim);font-size:.92rem}.ar-name strong{color:var(--text);font-weight:700}.lobby{min-height:70dvh;display:grid;place-items:center;padding:var(--pad-page)}.lobby-card{display:grid;gap:.6rem;justify-items:center;text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:clamp(1.6rem,6vw,3rem);box-shadow:var(--shadow);max-width:24rem}.lobby-card h2{margin:0;font-size:1.4rem}.lobby-card p{margin:0}.lobby-card button{margin-top:.6rem}.lobby-spin{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;background:color-mix(in srgb,var(--accent) 14%,var(--surface));color:var(--accent);font-size:1.5rem;margin-bottom:.4rem}.lobby-spin i{animation:lobby-tick 1.4s ease-in-out infinite}@keyframes lobby-tick{0%,to{transform:rotate(0)}50%{transform:rotate(180deg)}}.vol-btn.ducking{color:var(--accent);border-color:var(--accent)}.vol-btn.ducking i{animation:duck-pulse 1s ease-in-out infinite}@keyframes duck-pulse{0%,to{opacity:1}50%{opacity:.4}}.tab-badge{display:inline-grid;place-items:center;min-width:16px;height:16px;padding:0 4px;margin-left:.35rem;border-radius:999px;background:var(--accent);color:var(--accent-ink);font-size:.6rem;font-weight:700;vertical-align:middle}.chat-empty{text-align:center;margin:auto;padding:1.5rem}.activity{display:flex;flex-direction:column;flex:1;min-height:0}.activity-list{flex:1;overflow-y:auto;padding:.75rem .85rem;display:flex;flex-direction:column;gap:.55rem}.activity-empty{text-align:center;margin:auto;padding:1.5rem}.act-row{display:flex;align-items:baseline;gap:.55rem;font-size:.85rem;color:var(--text-dim)}.act-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;align-self:center;opacity:.7}.act-text{flex:1;min-width:0}.act-text strong{color:var(--text);font-weight:700}.act-time{font-family:var(--font-mono);font-size:.62rem;color:var(--text-faint);flex-shrink:0;white-space:nowrap}.activity-list::-webkit-scrollbar{width:8px}.activity-list::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px}.diary-modal{overflow:hidden;max-height:86dvh}.diary-scroll{flex:1;min-height:0}.diary-tabs{display:flex;gap:.3rem;margin-bottom:.6rem}.diary-tabs button{background:transparent;border:1px solid transparent;border-radius:999px;color:var(--text-dim);font-weight:600;font-size:.85rem;padding:.35rem .95rem}.diary-tabs button:hover{background:var(--surface-2)}.diary-tabs button.active{background:var(--accent);color:var(--accent-ink)}.diary-subhead{margin-bottom:.8rem}.diary-foot{margin-top:.6rem;text-align:center;border-top:1px solid var(--border);padding-top:.5rem}.diary-room-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r);padding:.7rem .85rem;margin-bottom:.9rem;display:grid;gap:.55rem}.drc-name{font-weight:700;font-size:1.05rem;display:flex;align-items:center;gap:.5rem}.drc-name i{color:var(--accent);font-size:.9rem}.drc-members{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.drc-chip{display:inline-flex;align-items:center;gap:.4rem;background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:.15rem .6rem .15rem .15rem;font-size:.82rem;font-weight:600;color:var(--text)}.drc-chip .avatar{width:22px;height:22px;font-size:.62rem}.drc-chip-name{white-space:nowrap}.drc-count{margin-top:.1rem}.drc-chip.away{opacity:.5}.drc-chip.here .avatar{background:var(--live);color:#fff}.dt-fav{background:transparent;border:none;cursor:pointer;padding:.25rem;flex-shrink:0;color:var(--text-faint);font-size:.9rem;line-height:1}.dt-fav:hover,.dt-fav.on{color:var(--accent)}.now-playing .np-title{flex:1}.np-fav{flex-shrink:0;width:36px;height:36px;padding:0;border-radius:50%;display:grid;place-items:center;background:transparent;border:none;cursor:pointer;color:var(--text-faint);font-size:1rem}.np-fav:hover{background:var(--surface-2);color:var(--accent)}.np-fav.on{color:var(--accent)}.fav-list{list-style:none;margin:0;padding:0;display:grid;gap:.2rem}.fav-row{touch-action:none}.fav-row.dragging{opacity:.6;background:var(--surface-2)}.fav-handle{cursor:grab;color:var(--text-faint);padding:.35rem .2rem;flex-shrink:0;touch-action:none;display:grid;place-items:center}.fav-handle:active{cursor:grabbing}.msg{position:relative}.msg-reply-btn{background:transparent;border:none;padding:0 .15rem;margin-left:.1rem;color:var(--text-faint);cursor:pointer;font-size:.68rem;line-height:1;opacity:0;transition:opacity .12s ease}.msg:hover .msg-reply-btn{opacity:.9}.msg-reply-btn:hover{background:transparent;color:var(--accent)}.msg-quote{display:flex;align-items:center;gap:.4rem;width:100%;max-width:100%;text-align:left;background:var(--surface-2);border:none;border-left:3px solid var(--accent);border-radius:6px;padding:.3rem .55rem;margin-bottom:.18rem;cursor:pointer;font-size:.74rem;color:var(--text-dim);overflow:hidden}.msg-quote:hover{background:var(--surface-3)}.msg-quote i{font-size:.6rem;color:var(--accent);flex-shrink:0}.mq-name{font-weight:700;color:var(--accent);flex-shrink:0}.mq-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.reply-banner{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-top:1px solid var(--border);background:var(--surface-2)}.rb-info{flex:1;min-width:0;display:grid;gap:.05rem}.rb-label{font-size:.72rem;font-weight:700;color:var(--accent);display:inline-flex;align-items:center;gap:.3rem}.rb-text{font-size:.8rem;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rb-cancel{background:transparent;border:none;color:var(--text-dim);cursor:pointer;flex-shrink:0;font-size:.85rem;padding:.2rem .4rem}.rb-cancel:hover{background:transparent;color:var(--text)}.msg.flash{animation:msg-flash 1.2s ease;border-radius:8px}@keyframes msg-flash{0%,to{box-shadow:0 0 0 0 transparent}25%{box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 50%,transparent)}}.logo-img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}.lp-logo,.brand-logo{overflow:hidden}.id-edit-btn{background:transparent;border:none;padding:0 .1rem;margin-left:.15rem;color:var(--text-faint);cursor:pointer;font-size:.72rem}.id-edit-btn:hover{background:transparent;color:var(--accent)}.id-edit{display:inline-flex;align-items:center;gap:.25rem}.id-edit input{width:8.5rem;padding:.15rem .4rem;font-family:var(--font-mono);font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;border-radius:var(--r-sm);border:1px solid var(--accent);background:var(--surface)}.id-btn{width:26px;height:26px;padding:0;display:grid;place-items:center;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface-2);cursor:pointer;font-size:.72rem}.id-btn.ok{color:var(--live)}.id-btn.cancel{color:var(--text-dim)}.id-err{display:block;margin-top:.2rem}.lp-or span{position:relative;z-index:1;background:var(--lp-surface);padding:.35rem 0}.cohost-tag{font-family:var(--font-mono);font-size:.58rem;letter-spacing:.06em;text-transform:uppercase;background:color-mix(in srgb,var(--live) 18%,transparent);color:var(--live);border-radius:999px;padding:.05rem .4rem;white-space:nowrap;flex-shrink:0}.listener-actions{display:inline-flex;align-items:center;gap:.1rem;margin-left:auto}.cohost-btn{background:transparent;border:none;padding:.3rem;color:var(--text-faint);cursor:pointer;border-radius:var(--r-sm);font-size:.82rem}.cohost-btn:hover{background:var(--surface-2);color:var(--live)}.cohost-btn.on{color:var(--live)}.name-edit{display:inline-flex;align-items:center;gap:.3rem;min-width:0}.name-edit input{font:inherit;font-size:clamp(1.1rem,3vw,1.4rem);font-weight:700;padding:.1rem .5rem;border:1px solid var(--accent);border-radius:var(--r-sm);background:var(--surface);width:13rem;max-width:38vw;min-width:0}.h2-edit{font-size:.72rem;margin-left:.4rem;vertical-align:middle}.confirm-card{width:min(380px,100%);text-align:center;padding:1.7rem 1.5rem 1.4rem}.confirm-icon{width:52px;height:52px;border-radius:50%;display:grid;place-items:center;margin:0 auto .9rem;font-size:1.2rem;background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent)}.confirm-card h3{margin:0 0 .5rem;font-size:1.2rem;font-weight:700;letter-spacing:-.01em}.confirm-card p{margin:0 0 1.4rem;font-size:.9rem;line-height:1.5}.confirm-actions{display:flex;gap:.6rem}.confirm-actions button{flex:1}button.danger{background:var(--accent);color:var(--accent-ink);border-color:transparent}button.danger:hover:not(:disabled){background:var(--accent);filter:brightness(1.07)}.qr-btn{display:grid;place-items:center;padding:.46rem .62rem}.qr-card{width:min(360px,100%);max-height:94dvh;overflow:visible;display:flex;flex-direction:column;align-items:center;gap:.55rem;text-align:center;padding:1.3rem 1.3rem 1.2rem;position:relative}.qr-card .modal-close{position:absolute;top:.8rem;right:.8rem}.qr-title{margin:0;font-size:1.2rem;font-weight:700;letter-spacing:-.01em}.qr-room{margin:0;font-size:.88rem}.qr-frame{display:grid;place-items:center;margin:.15rem auto .05rem;padding:.6rem;border-radius:var(--r);background:#fff;border:1px solid var(--border);box-shadow:0 6px 18px #78505f1f}.qr-canvas{width:min(236px,58vw,34vh);height:auto;display:block}.qr-code{margin:0;font-size:1.02rem;letter-spacing:.18em;font-weight:500;color:var(--text)}.qr-copy{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.15rem}.qr-actions{display:flex;gap:.5rem;width:100%}.qr-actions button{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.55rem .6rem}.ds-toggle{position:absolute;top:.6rem;right:.6rem;z-index:4;width:36px;height:36px;padding:0;display:grid;place-items:center;border-radius:50%;border:1px solid rgba(255,255,255,.22);background:#0000006b;color:#fff;font-size:.82rem}.ds-toggle:hover{background:#0000009e;color:#fff}.video-wrap.remote-on{aspect-ratio:auto;min-height:260px;background:var(--surface)}.video-empty.remote-mode{background:radial-gradient(120% 120% at 50% 0%,var(--surface-3) 0%,var(--surface) 100%);color:var(--text);gap:.45rem;padding:1.2rem}.remote-mode .muted{color:var(--text-dim)}.rm-icon{font-size:1.9rem;color:var(--accent);margin-bottom:.2rem}.remote-mode .rm-on{margin-top:.7rem;display:inline-flex;align-items:center;gap:.45rem}.account{position:relative}.account-btn.in{color:var(--accent)}.account-pop{position:absolute;top:calc(100% + 8px);right:0;z-index:40;width:244px;padding:.9rem;border-radius:var(--r);background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);display:grid;gap:.55rem;text-align:left}.acc-head{font-weight:700;font-size:.92rem;display:flex;align-items:center;gap:.4rem}.acc-head i,.acc-head strong{color:var(--accent)}.acc-sub{font-size:.78rem;margin:0;line-height:1.45}.acc-btn{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.acc-back{justify-self:start;padding:.15rem 0;font-size:.82rem}.acc-err{margin:.1rem 0 0}.lp-codefield::placeholder{letter-spacing:normal;text-transform:none;font-size:.84rem}
