@keyframes flashbangShake{0%,to{transform:translate(0) rotate(0)}10%{transform:translate(-8px,-4px) rotate(-1deg)}20%{transform:translate(8px,3px) rotate(1deg)}30%{transform:translate(-6px,5px) rotate(-.8deg)}40%{transform:translate(6px,-3px) rotate(.8deg)}50%{transform:translate(-4px,4px) rotate(-.5deg)}60%{transform:translate(4px,-2px) rotate(.5deg)}70%{transform:translate(-2px,2px) rotate(-.2deg)}80%{transform:translate(2px,-1px) rotate(.2deg)}90%{transform:translate(-1px,1px) rotate(0)}}body.flashbang-shake{animation:flashbangShake .6s ease-out}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0d0d0d;--surface: #1e1e1e;--surface-hi: #202020;--border: #2a2a2a;--border-hi: #363636;--text: #f5f5f5;--text-dim: #888888;--accent: #d4d4d4;--danger: #e05252;--radius-sm: 6px;--radius: 12px;--radius-lg: 16px;font-family:system-ui,-apple-system,Segoe UI,sans-serif;font-size:15px;-webkit-font-smoothing:antialiased}:root[data-theme=light]{--bg: #f5f5f5;--surface: #ffffff;--surface-hi: #eeeeee;--border: #dcdcdc;--border-hi: #c0c0c0;--text: #111111;--text-dim: #777777;--accent: #333333}:root[data-theme=light] .user-tooltip{box-shadow:0 8px 24px #0000001a}:root[data-theme=light] .modal{background:#00000038}:root[data-theme=light] .modal-box{box-shadow:0 24px 60px #00000021}:root[data-theme=light] .clip-card:hover{box-shadow:0 4px 20px #00000017}:root[data-theme=light] .toast{box-shadow:0 8px 24px #0000001a}:root[data-theme=light] .emoji-picker-dropdown{box-shadow:0 8px 32px #0000001f}:root[data-theme=light] emoji-picker{--background: #ffffff;--border-color: #e0d8c8;--text-color: #1a1510;--category-font-color: #7a6a58;--input-border-color: #e0d8c8;--input-font-color: #1a1510;--input-placeholder-color: #7a6a58;--category-button-active-color: #e8a030}body{background:var(--bg);color:var(--text);height:100vh;overflow-x:hidden}#app{display:flex;flex-direction:column;height:100%;overflow-y:auto}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-hi);border-radius:99px}.hidden{display:none!important}header{display:flex;align-items:center;gap:.75rem;padding:0 1.25rem;height:56px;background:var(--surface);background-image:linear-gradient(to bottom,rgba(255,255,255,.015) 0%,transparent 100%);border-bottom:1px solid var(--border);flex-shrink:0;position:sticky;top:0;z-index:100}#controls-bar-slot{flex-shrink:0;position:sticky;top:56px;z-index:99}.controls-bar{display:flex;align-items:center;padding:0 1.5rem;height:44px;background:var(--bg);border-bottom:1px solid var(--border);position:relative;z-index:99;gap:0}.controls-bar-scroll{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0;overflow-x:auto;scrollbar-width:none}.controls-bar-scroll::-webkit-scrollbar{display:none}.audio-settings-group{display:contents}:root:not([data-audio-settings]) .audio-settings-group{display:none}.header-title{font-size:.9rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text);flex-shrink:0;display:flex;align-items:center;gap:.65rem}.header-logo-mark{width:34px;height:34px;background:color-mix(in srgb,var(--accent) 13%,var(--surface-hi));border:1px solid color-mix(in srgb,var(--accent) 28%,transparent);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0;box-shadow:0 0 12px color-mix(in srgb,var(--accent) 14%,transparent)}.user-count-wrapper{position:relative;flex-shrink:0;display:flex;align-items:center;gap:.5rem}.user-avatars{display:flex;align-items:center;flex-direction:row-reverse}.online-avatar{width:26px;height:26px;border-radius:50%;border:2px solid var(--bg);overflow:hidden;flex-shrink:0;margin-left:-8px;background:var(--surface-hi);transition:transform .12s}.online-avatar:first-child{margin-left:0}.user-avatars:hover .online-avatar{transform:translate(0);margin-left:-4px}.online-avatar img{width:100%;height:100%;object-fit:cover;display:block}.online-avatar-initials{display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:700;color:var(--text);background:var(--surface-hi);letter-spacing:.02em}.user-tooltip{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--surface);border:1px solid var(--border-hi);border-radius:var(--radius);padding:.4rem .6rem;min-width:110px;box-shadow:0 8px 24px #00000080;opacity:0;pointer-events:none;transition:opacity .15s;z-index:50;display:flex;flex-direction:column;gap:.25rem}.user-count-wrapper:hover .user-tooltip{opacity:1}.user-tooltip-name{font-size:.82rem;color:var(--text);white-space:nowrap}.user-count{font-size:.72rem;font-weight:500;color:var(--text-dim);background:var(--bg);border:1px solid var(--border);border-radius:99px;padding:.18rem .6rem .18rem .5rem;flex-shrink:0;letter-spacing:.02em;cursor:default;display:flex;align-items:center;gap:.35rem}.user-count:before{content:"";width:6px;height:6px;border-radius:50%;background:#4ade80;flex-shrink:0}.header-sep{width:1px;height:20px;background:var(--border);flex-shrink:0}.username-field{display:flex;align-items:center;gap:.35rem;background:var(--surface-hi);border:1px solid var(--border);border-radius:var(--radius-sm);padding:0 .5rem;height:28px;flex-shrink:0;color:var(--text-dim);transition:border-color .15s}.username-field:focus-within{border-color:var(--accent);color:var(--accent)}.username-icon{flex-shrink:0}.username-input{background:transparent;border:none;outline:none;color:var(--text);font-size:.8rem;width:110px;padding:0}.username-input::placeholder{color:var(--text-dim)}.header-spacer{flex:1}.toolbar-group{display:flex;align-items:center;gap:.1rem;background:var(--surface-hi);border:1px solid var(--border);border-radius:var(--radius);padding:.2rem .4rem;flex-shrink:0}.toolbar-sep{width:1px;height:16px;background:var(--border);margin:0 .2rem;flex-shrink:0}.toggle-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .45rem;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text-dim);font-size:.78rem;cursor:pointer;font-family:inherit;line-height:1;transition:background .12s,color .12s;white-space:nowrap;flex-shrink:0}.toggle-btn:hover{background:color-mix(in srgb,var(--border) 60%,transparent);color:var(--text)}.toggle-btn.active{background:color-mix(in srgb,var(--accent) 15%,transparent);color:var(--accent)}.discord-toggle-btn{color:#5865f2}.discord-toggle-btn:hover{background:#5865f21f;color:#5865f2}.grid-size-btns{display:flex;gap:0}.grid-size-btn{display:inline-flex;align-items:center;justify-content:center;padding:.2rem .4rem;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text-dim);font-size:.72rem;font-weight:600;letter-spacing:.04em;cursor:pointer;font-family:inherit;line-height:1;transition:background .12s,color .12s}.grid-size-btn:hover{background:color-mix(in srgb,var(--border) 60%,transparent);color:var(--text)}.grid-size-btn.active{background:color-mix(in srgb,var(--accent) 15%,transparent);color:var(--accent)}.vol-label{display:flex;align-items:center;gap:.4rem;color:var(--text-dim);font-size:.8rem}#master-volume{width:80px;accent-color:var(--accent);cursor:pointer}.settings-anchor{position:relative;flex-shrink:0}.settings-dropdown{position:absolute;top:calc(100% + 6px);right:0;background:var(--surface);border:1px solid var(--border-hi);border-radius:var(--radius);padding:.35rem;display:flex;flex-direction:column;gap:.1rem;min-width:200px;max-height:calc(100vh - 80px);overflow-y:auto;box-shadow:0 8px 32px #0006;z-index:200}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:.25rem .5rem;gap:.75rem}.settings-label{font-size:.78rem;color:var(--text-dim)}.settings-toggle{display:flex;align-items:center;gap:.5rem;width:100%;padding:.35rem .5rem;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text-dim);font-size:.82rem;font-family:inherit;cursor:pointer;text-align:left;transition:background .12s,color .12s}.settings-toggle:hover{background:color-mix(in srgb,var(--border) 60%,transparent);color:var(--text)}.settings-toggle.active{color:var(--text)}.settings-toggle-state{margin-left:auto;font-size:.72rem;color:var(--text-dim);background:var(--bg);border:1px solid var(--border);border-radius:99px;padding:.05rem .45rem}.settings-toggle.active .settings-toggle-state{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 40%,transparent);background:color-mix(in srgb,var(--accent) 10%,transparent)}.settings-divider{height:1px;background:var(--border);margin:.2rem 0}.overlay-shortcut-row{align-items:center}.shortcut-recorder{font-size:.72rem;font-weight:600;padding:.25rem .6rem;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--surface-hi);color:var(--text);cursor:pointer;min-width:110px;text-align:center;font-family:monospace;transition:border-color .15s,background .15s}.shortcut-recorder:hover{border-color:var(--accent)}.shortcut-recorder.recording{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,var(--surface-hi));animation:pulse-border .8s ease infinite alternate}@keyframes pulse-border{0%{border-color:var(--accent)}to{border-color:color-mix(in srgb,var(--accent) 40%,transparent)}}.shortcut-error{font-size:.7rem;color:#f87171;padding:.1rem .75rem .3rem}.overlay-layout-btns{display:flex;gap:.2rem}.overlay-layout-btn{padding:.15rem .5rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;color:var(--text-dim);font-size:.72rem;font-family:inherit;cursor:pointer;transition:background .12s,color .12s,border-color .12s}.overlay-layout-btn:hover{background:color-mix(in srgb,var(--border) 60%,transparent);color:var(--text)}.overlay-layout-btn.active{background:color-mix(in srgb,var(--accent) 15%,transparent);border-color:color-mix(in srgb,var(--accent) 40%,transparent);color:var(--accent)}.controls-bar.hidden{display:none!important}@media(max-width:600px){header{padding:0 .75rem;gap:.5rem}.header-title>:not(.header-logo-mark){display:none}.current-user .user-name,.user-count{display:none}.controls-bar{padding:0 .5rem 0 .75rem}}.electron-app header{-webkit-app-region:drag;padding-right:150px}.electron-app header button,.electron-app header a,.electron-app header input,.electron-app header select,.electron-app header [role=button]{-webkit-app-region:no-drag}button{font-family:inherit;font-size:.82rem;font-weight:500;border:none;border-radius:var(--radius-sm);padding:.4rem .85rem;cursor:pointer;transition:background .12s,opacity .12s,transform .1s;line-height:1.4}button:active{transform:scale(.96)}.btn-primary{background:var(--accent);color:#111;font-weight:600}.btn-primary:hover{background:color-mix(in srgb,var(--accent) 85%,white)}.btn-danger{background:transparent;color:var(--danger);border:1px solid color-mix(in srgb,var(--danger) 35%,transparent)}.btn-danger:hover{background:color-mix(in srgb,var(--danger) 15%,transparent)}.btn-ghost{background:transparent;color:var(--text-dim)}.btn-ghost:hover{background:var(--surface-hi);color:var(--text)}.btn-ghost.active{background:color-mix(in srgb,var(--accent) 14%,var(--surface-hi));color:var(--accent);border-color:color-mix(in srgb,var(--accent) 35%,transparent)}.btn-icon{padding:.38rem .5rem;font-size:.85rem}.btn-sm{font-size:.75rem;padding:.2rem .5rem;border-radius:var(--radius-sm)}main{flex:1;padding:1rem}.toolbar{display:none;align-items:center;justify-content:space-between;gap:.75rem;padding:0 0 .85rem;flex-wrap:wrap}.category-bar{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap;flex:1}.category-tab{background:transparent;border:1px solid var(--border);border-radius:99px;color:var(--text-dim);font-size:.75rem;font-weight:500;padding:.22rem .7rem;cursor:pointer;transition:background .12s,color .12s,border-color .12s;white-space:nowrap}.category-tab:hover{background:var(--surface-hi);color:var(--text)}.category-tab:active{transform:scale(.96)}.category-tab.active{background:color-mix(in srgb,var(--accent) 18%,transparent);border-color:var(--accent);color:var(--accent)}.search-wrapper{display:flex;align-items:center;gap:.25rem;flex-shrink:0}#search-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:.3rem .6rem;font-size:.82rem;font-family:inherit;width:170px;transition:border-color .12s}#search-input::placeholder{color:var(--text-dim)}#search-input:focus{outline:none;border-color:var(--accent)}.search-clear{color:var(--text-dim)}.search-clear.hidden{display:none}#sound-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.5rem}html[data-grid-size=sm] #sound-grid{grid-template-columns:repeat(auto-fill,minmax(85px,1fr));gap:.35rem}html[data-grid-size=md] #sound-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.65rem}html[data-grid-size=lg] #sound-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}html[data-grid-size=sm] .clip-play-btn{min-height:45px}html[data-grid-size=sm] .clip-name{font-size:.68rem;padding:.2rem .35rem .15rem}html[data-grid-size=sm] .add-sound-card-btn{min-height:45px}html[data-grid-size=sm] .add-sound-card-label{display:none}html[data-grid-size=sm] .add-sound-card-icon{font-size:1rem}html[data-grid-size=sm] .clip-play-btn .clip-icon-img{height:40px}html[data-grid-size=sm] .clip-play-btn .clip-icon-emoji{font-size:1.6rem;padding:.4rem .35rem .15rem}html[data-grid-size=md] .clip-play-btn{min-height:90px}html[data-grid-size=md] .clip-name{font-size:.88rem;padding:.5rem .75rem .25rem}html[data-grid-size=md] .clip-play-btn .clip-icon-img{height:80px}html[data-grid-size=md] .clip-play-btn .clip-icon-emoji{font-size:3.5rem;padding:1rem .5rem .35rem}html[data-grid-size=md] .add-sound-card-btn{min-height:90px}html[data-grid-size=lg] .clip-play-btn{min-height:120px}html[data-grid-size=lg] .clip-name{font-size:1rem}html[data-grid-size=lg] .add-sound-card-btn{min-height:120px}html[data-grid-size=lg] .clip-play-btn .clip-icon-img{height:120px}html[data-grid-size=lg] .clip-play-btn .clip-icon-emoji{font-size:4.5rem;padding:1.5rem .75rem .5rem}.clip-card{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:border-color .15s,box-shadow .15s,transform .12s}.clip-card:hover{border-color:var(--accent);box-shadow:0 4px 20px #00000073;transform:translateY(-1px)}@keyframes soundPulse{0%,to{box-shadow:0 0 0 2px var(--accent),0 4px 20px color-mix(in srgb,var(--accent) 35%,transparent)}50%{box-shadow:0 0 0 2px var(--accent),0 4px 32px color-mix(in srgb,var(--accent) 60%,transparent)}}.clip-card.is-playing{border-color:var(--accent);animation:soundPulse 1.4s ease-in-out infinite}.clip-card.is-playing .clip-play-btn{background:color-mix(in srgb,var(--accent) 7%,var(--surface))}.clip-play-btn{flex:1;background:transparent;border-radius:0;padding:0;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;min-height:65px;transition:background .12s;overflow:hidden}.clip-play-btn:hover{background:var(--surface-hi)}.clip-play-btn:active{transform:none}.clip-gif-wrap{position:relative;width:100%;flex-shrink:0;margin-bottom:auto}.clip-gif-watermark{position:absolute;bottom:4px;left:5px;height:14px;width:auto;opacity:.75;pointer-events:none;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4))}.clip-play-btn .clip-icon-img{width:100%;height:62px;object-fit:cover;border-radius:0;border-bottom:1px solid var(--border);flex-shrink:0;margin-bottom:auto}.clip-play-btn .clip-icon-emoji{font-size:2.5rem;line-height:1;display:block;padding:.6rem .5rem .25rem;margin-bottom:auto}.clip-name{font-size:.78rem;font-weight:600;color:var(--text);word-break:break-word;line-height:1.3;padding:.3rem .5rem .2rem;text-align:center}.clip-hotkey{position:absolute;bottom:.3rem;left:.3rem;font-size:.6rem;font-weight:700;letter-spacing:.05em;background:color-mix(in srgb,var(--accent) 20%,transparent);color:var(--accent);padding:.1rem .35rem;border-radius:4px;border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);pointer-events:none;z-index:1}:root:not([data-edit-mode]) .clip-menu-strip{display:none}.clip-menu-strip{width:100%;display:flex;align-items:center;justify-content:center;gap:.45rem;padding:.35rem .75rem;background:var(--surface-hi);border:none;border-top:1px solid var(--border);color:var(--text-dim);font-size:.78rem;cursor:pointer;font-family:inherit;transition:background .12s,color .12s;flex-shrink:0}.clip-menu-strip:hover,.clip-menu-strip.active{background:color-mix(in srgb,var(--accent) 12%,var(--surface-hi));color:var(--accent);border-top-color:color-mix(in srgb,var(--accent) 35%,var(--border))}.clip-pinned-badge{position:absolute;top:.4rem;left:.4rem;font-size:.7rem;color:#f4c430;pointer-events:none;z-index:2;line-height:1}.clip-dropdown{position:fixed;z-index:1000;background:var(--surface);border:1px solid var(--border-hi);border-radius:var(--radius);box-shadow:0 8px 32px #00000080;min-width:180px;overflow:hidden;display:flex;flex-direction:column}.clip-dropdown-volume{display:flex;align-items:center;gap:.55rem;padding:.55rem .9rem;color:var(--text-dim)}.clip-dropdown-vol-slider{flex:1;accent-color:var(--accent);cursor:pointer}.clip-dropdown-vol-label{font-size:.75rem;min-width:2.5em;text-align:right;color:var(--text-dim)}.clip-dropdown-item{display:flex;align-items:center;gap:.65rem;padding:.6rem .9rem;font-size:.85rem;color:var(--text);background:transparent;border:none;text-align:left;cursor:pointer;font-family:inherit;line-height:1;transition:background .1s;white-space:nowrap}.clip-dropdown-item:hover{background:var(--surface-hi)}.clip-dropdown-item svg{flex-shrink:0;color:var(--text-dim)}.clip-dropdown-danger{color:var(--danger)!important}.clip-dropdown-danger:hover{background:color-mix(in srgb,var(--danger) 12%,var(--surface))!important}.clip-dropdown-danger svg{color:var(--danger)!important}.clip-dropdown-sep{height:1px;background:var(--border);margin:.2rem 0}.clip-card.dragging{opacity:.35;cursor:grabbing}.clip-card.drag-over{box-shadow:0 0 0 2px var(--accent),0 4px 20px color-mix(in srgb,var(--accent) 25%,transparent);transform:translateY(-2px)}.grid-section-header{grid-column:1 / -1;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-dim);padding:.25rem 0;border-bottom:1px solid var(--border);margin-bottom:.1rem}.grid-section-header:not(:first-child){margin-top:.75rem}.add-sound-card{border:1px dashed var(--border);opacity:.55;transition:opacity .15s,border-color .15s,box-shadow .15s,transform .12s}.add-sound-card:hover{opacity:1;border-color:var(--accent);border-top-color:var(--accent);box-shadow:0 4px 20px #00000073;transform:translateY(-1px)}.add-sound-card-btn{flex:1;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;background:transparent;border-radius:0;padding:.9rem .85rem;min-height:65px;color:var(--text-dim);transition:background .12s,color .12s}.add-sound-card-btn:hover{background:var(--surface-hi);color:var(--text)}.add-sound-card-btn:active{transform:none}.add-sound-card-icon{font-size:1.6rem;font-weight:300;line-height:1}.add-sound-card-label{font-size:.8rem;font-weight:600}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:4rem 1.5rem;gap:1rem}.empty-state-icon{width:64px;height:64px;border-radius:50%;background:color-mix(in srgb,var(--accent) 10%,transparent);display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:.25rem}.empty-state-icon svg{width:32px;height:32px}.empty-state-title{font-size:1.2rem;font-weight:700;color:var(--text)}.empty-state-desc{font-size:.88rem;color:var(--text-dim);line-height:1.6;max-width:340px}.empty-state-actions{margin-top:.25rem}.empty-state-cta{display:inline-flex;align-items:center;gap:.5rem;background:var(--accent);color:#000;border:none;border-radius:var(--radius);padding:.65rem 1.4rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s}.empty-state-cta svg{width:16px;height:16px}.empty-state-cta:hover{opacity:.88}.empty-state-cta:active{transform:scale(.97)}.empty-state-tips{display:flex;flex-direction:column;gap:.6rem;margin-top:1rem;padding-top:1.25rem;border-top:1px solid var(--border);width:100%;max-width:340px}.empty-state-tip{display:flex;align-items:center;gap:.65rem;font-size:.8rem;color:var(--text-dim);text-align:left}.empty-state-tip svg{width:15px;height:15px;flex-shrink:0;color:var(--text-dim)}.empty-state-tip kbd{background:var(--surface-hi);border:1px solid var(--border-hi);border-radius:4px;padding:.05rem .4rem;font-size:.75rem;font-family:monospace;color:var(--text)}.clip-card.is-selected{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,var(--surface))}.clip-select-check{position:absolute;top:.4rem;right:.4rem;width:1.3rem;height:1.3rem;border-radius:50%;border:2px solid var(--border-hi);background:var(--surface-hi);display:flex;align-items:center;justify-content:center;font-size:.7rem;color:transparent;z-index:4;pointer-events:none;transition:background .12s,border-color .12s,color .12s}.clip-select-check.checked{background:var(--accent);border-color:var(--accent);color:#fff}#select-mode-btn.active{background:color-mix(in srgb,var(--accent) 18%,transparent);border-color:var(--accent);color:var(--accent)}.select-action-bar{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);background:var(--surface-hi);border:1px solid var(--border-hi);border-radius:var(--radius);box-shadow:0 8px 32px #00000080;display:flex;align-items:center;gap:1rem;padding:.6rem 1.1rem;z-index:200;white-space:nowrap}.select-action-bar.hidden{display:none}.select-count{font-size:.88rem;font-weight:600;color:var(--text)}.select-action-bar-btns{display:flex;gap:.5rem}.select-action-bar-btns button{font-size:.85rem;padding:.45rem 1rem}.copy-to-board-hint{font-size:.88rem;color:var(--text-dim);margin:0 0 .75rem}.copy-to-board-list{display:flex;flex-direction:column;gap:.4rem;max-height:320px;overflow-y:auto}.copy-to-board-room-btn{width:100%;text-align:left;background:var(--surface-hi);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.6rem .9rem;font-size:.9rem;font-weight:500;color:var(--text);cursor:pointer;transition:border-color .12s,background .12s}.copy-to-board-room-btn:hover{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--surface-hi))}.queue-status-bar{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);background:color-mix(in srgb,var(--accent) 15%,var(--surface-hi));border:1px solid var(--accent);border-radius:var(--radius);box-shadow:0 8px 32px #00000080;display:flex;align-items:center;gap:1rem;padding:.6rem 1.1rem;z-index:200;white-space:nowrap}.queue-status-bar.hidden{display:none}#queue-status-text{font-size:.88rem;font-weight:600;color:var(--accent)}.modal{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:1rem}.modal.hidden{display:none}.modal-box{background:var(--surface);border:1px solid var(--border-hi);border-radius:var(--radius-lg);padding:1.5rem;width:100%;max-width:420px;position:relative;box-shadow:0 24px 60px #0009}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.modal-header h2{font-size:.95rem;font-weight:600}.modal-close{background:transparent;padding:.25rem .45rem;font-size:.85rem;border-radius:var(--radius-sm);color:var(--text-dim);line-height:1}.modal-close:hover{background:var(--surface-hi);color:var(--text)}#clip-form{display:flex;flex-direction:column;gap:.85rem}#clip-form label{display:flex;flex-direction:column;gap:.35rem;font-size:.78rem;font-weight:500;color:var(--text-dim);letter-spacing:.02em;text-transform:uppercase}#clip-form input[type=text],#clip-form input[type=file],#clip-form select{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:.5rem .65rem;font-size:.88rem;font-family:inherit;width:100%;transition:border-color .12s}#clip-form input[type=text]:focus,#clip-form input[type=file]:focus{outline:none;border-color:var(--accent)}#clip-form input[type=range]{accent-color:var(--accent)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}#clip-form input[type=color]{height:38px;width:100%;padding:3px 4px;border-radius:var(--radius-sm);background:var(--bg);border:1px solid var(--border);cursor:pointer}.file-hint{font-size:.72rem;color:var(--text-dim);font-style:italic;text-transform:none;letter-spacing:0;font-weight:400}.icon-section{display:flex;flex-direction:column;gap:.5rem;padding:.65rem .75rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm)}.icon-section-header{display:flex;align-items:center;justify-content:space-between}.icon-row{display:flex;align-items:center;gap:.75rem}.icon-preview-box{width:44px;height:44px;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;overflow:hidden}.icon-preview-box img{width:100%;height:100%;object-fit:cover}.icon-inputs{display:flex;flex-direction:column;gap:.35rem;flex:1;min-width:0}.icon-btn-row{display:flex;align-items:center;gap:.4rem}.icon-btn-row .emoji-picker-wrapper{flex:0 auto}.icon-or{font-size:.7rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em}.emoji-picker-wrapper{position:relative}.emoji-trigger-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:.35rem .65rem;font-size:.88rem;display:flex;align-items:center;gap:.4rem;width:100%;text-align:left;cursor:pointer;transition:border-color .12s,background .12s}.emoji-trigger-btn:hover{background:var(--surface-hi);border-color:var(--border-hi)}.emoji-trigger-btn:active{transform:none}#emoji-trigger-display{font-size:1.1rem;line-height:1}.emoji-picker-dropdown{position:absolute;top:calc(100% + 4px);left:0;z-index:300;border-radius:var(--radius);overflow:hidden;box-shadow:0 8px 32px #0009}.emoji-picker-dropdown.hidden{display:none}emoji-picker{--background: #1a1510;--border-color: #2e261c;--text-color: #f0e8d8;--category-font-color: #8a7560;--input-border-color: #2e261c;--input-font-color: #f0e8d8;--input-placeholder-color: #8a7560;--emoji-padding: .35rem;--emoji-size: 1.35rem;--num-columns: 8;--category-button-active-color: #e8a030;height:300px;width:300px}.file-input-row{display:flex;align-items:center;gap:.45rem;min-width:0}.file-input-row input[type=file],.icon-inputs input[type=file]{display:none}.file-input-btn{display:flex;align-items:center;gap:.35rem;flex-shrink:0;background:var(--surface-hi);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-dim);padding:.38rem .65rem;font-size:.8rem;font-weight:500;white-space:nowrap;cursor:pointer;transition:background .12s,color .12s,border-color .12s}.file-input-btn:hover{border-color:var(--border-hi);color:var(--text);background:var(--border)}.file-input-btn:active{transform:scale(.96)}.file-input-name{font-size:.76rem;color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1;font-style:italic}.clip-icon-emoji{font-size:1.6rem;line-height:1;display:block}.clip-icon-img{width:36px;height:36px;object-fit:cover;border-radius:4px;display:block}.modal-tabs{display:flex;gap:0;margin-bottom:1rem;border-bottom:1px solid var(--border)}.modal-tabs.hidden{display:none}.modal-tab{background:transparent;border:none;border-bottom:2px solid transparent;border-radius:4px 4px 0 0;color:var(--text-dim);font-size:.82rem;font-weight:500;letter-spacing:.02em;padding:.45rem .85rem;cursor:pointer;margin-bottom:-1px;transition:color .12s,border-color .12s}.modal-tab:hover{color:var(--text)}.modal-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.create-room-box{max-width:380px;padding-top:2rem}.create-room-hero{text-align:center;padding:0 .5rem 1.5rem}.create-room-icon{font-size:2.4rem;line-height:1;margin-bottom:.75rem}.create-room-title{font-size:1.2rem;font-weight:600;margin:0 0 .5rem;color:var(--text)}.create-room-desc{font-size:.82rem;color:var(--text-dim);line-height:1.55;margin:0}.create-room-field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.25rem}.create-room-label{font-size:.75rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-dim)}.create-room-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:inherit;font-size:.95rem;padding:.6rem .8rem;width:100%;transition:border-color .12s,box-shadow .12s}.create-room-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 15%,transparent)}.create-room-input::placeholder{color:var(--text-dim);opacity:.6}.create-room-input--error{border-color:var(--danger)!important}.create-room-error{font-size:.78rem;color:var(--danger);margin-top:.3rem}.public-toggle-row{display:flex;align-items:center;gap:.75rem;padding:.65rem .75rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;-webkit-user-select:none;user-select:none;transition:border-color .15s,background .15s}.public-toggle-row:hover{border-color:var(--border-hi)}.public-toggle-row.active{border-color:color-mix(in srgb,var(--accent) 40%,transparent);background:color-mix(in srgb,var(--accent) 6%,var(--bg))}.public-toggle-icon{flex-shrink:0;color:var(--text-dim);display:flex;align-items:center;transition:color .15s}.public-toggle-row.active .public-toggle-icon{color:var(--accent)}.public-toggle-info{flex:1;display:flex;flex-direction:column;gap:.2rem;min-width:0}.public-toggle-title{font-size:.82rem;font-weight:600;color:var(--text);line-height:1.3}.public-toggle-desc{font-size:.74rem;color:var(--text-dim);line-height:1.4}.public-toggle-switch{flex-shrink:0;width:32px;height:18px;background:var(--border-hi);border-radius:9px;position:relative;transition:background .2s}.public-toggle-switch.on{background:var(--accent)}.public-toggle-thumb{position:absolute;top:2px;left:2px;width:14px;height:14px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px #0000004d}.public-toggle-switch.on .public-toggle-thumb{transform:translate(14px)}.library-search-bar{margin-bottom:.75rem}.library-search-bar input{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:.5rem .65rem;font-size:.88rem;font-family:inherit;transition:border-color .12s}.library-search-bar input:focus{outline:none;border-color:var(--accent)}.library-list{display:flex;flex-direction:column;gap:.4rem;max-height:420px;overflow-y:auto;padding-right:2px}.library-empty{color:var(--text-dim);font-size:.85rem;text-align:center;padding:1.5rem 0}.lib-entry{display:flex;align-items:center;gap:.65rem;padding:.55rem .65rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color .12s}.lib-entry:hover{border-color:var(--border-hi)}.lib-entry-icon{width:36px;height:36px;border-radius:4px;flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--surface)}.lib-entry-icon img{width:100%;height:100%;object-fit:cover}.lib-entry-emoji{font-size:1.4rem}.lib-entry-info{display:flex;flex-direction:column;gap:.2rem;flex:1;min-width:0}.lib-entry-name{font-size:.88rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lib-entry-meta{display:flex;align-items:center;gap:.45rem;font-size:.74rem;color:var(--text-dim)}.lib-entry-category{background:var(--surface-hi);border-radius:3px;padding:0 .35rem;font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.03em}.lib-entry-actions{display:flex;align-items:center;gap:.35rem;flex-shrink:0}.upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:.25rem 0 .5rem}.upload-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;width:100%;padding:2rem 1.5rem;background:var(--bg);border:1.5px dashed var(--border-hi);border-radius:var(--radius);color:var(--text-dim);cursor:pointer;transition:border-color .15s,background .15s,color .15s;text-align:center}.upload-dropzone:hover{border-color:var(--accent);background:var(--surface-hi);color:var(--text)}.upload-dropzone--error{border-color:#f87171}.field-error{font-size:.78rem;color:#f87171;margin:.25rem 0 0}.input-error{border-color:#f87171!important}.upload-dropzone-label{font-size:.92rem;font-weight:600;color:inherit}.upload-dropzone-hint{font-size:.75rem;color:var(--text-dim);opacity:.8}.upload-or{display:flex;align-items:center;gap:.65rem;width:100%;color:var(--text-dim);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.upload-or:before,.upload-or:after{content:"";flex:1;height:1px;background:var(--border)}.giphy-section{display:flex;flex-direction:column;gap:.5rem;padding:.65rem .75rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm)}.giphy-section-header{display:flex;align-items:center;justify-content:space-between;font-size:.78rem;font-weight:500;color:var(--text-dim);letter-spacing:.02em;text-transform:uppercase}.giphy-current{display:flex;justify-content:center}.giphy-current-img{height:80px;max-width:100%;border-radius:var(--radius-sm);object-fit:contain}.giphy-search-row{display:flex;gap:.4rem;align-items:center}.giphy-search-row input{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:.4rem .6rem;font-size:.84rem;font-family:inherit;transition:border-color .12s}.giphy-search-row input:focus{outline:none;border-color:var(--accent)}.giphy-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}.giphy-thumb{background:var(--surface);border:2px solid transparent;border-radius:var(--radius-sm);padding:0;overflow:hidden;cursor:pointer;aspect-ratio:1;transition:border-color .12s}.giphy-thumb:hover{border-color:var(--border-hi)}.giphy-thumb.selected{border-color:var(--accent)}.giphy-thumb img{width:100%;height:100%;object-fit:cover;display:block}.klipy-powered{flex-shrink:0;height:16px;width:auto;opacity:.8}.record-hint{color:var(--danger, #e05252)}.record-hint.hidden{display:none}.record-status{display:flex;align-items:center;gap:.45rem;padding:.3rem 0}.record-status.hidden{display:none}.record-dot{width:8px;height:8px;border-radius:50%;background:var(--danger, #e05252);flex-shrink:0;animation:recordPulse 1s ease-in-out infinite}@keyframes recordPulse{0%,to{opacity:1}50%{opacity:.25}}.record-timer{font-size:.8rem;font-variant-numeric:tabular-nums;color:var(--text-dim);min-width:2.8ch}.capture-gain-row{display:flex;align-items:center;gap:.6rem;padding:.5rem 0 0}.capture-gain-label{font-size:.78rem;color:var(--text-dim);white-space:nowrap}.capture-gain-slider{flex:1;accent-color:var(--accent, #5b8af5)}.capture-gain-value{font-size:.78rem;color:var(--text-dim);min-width:3ch;text-align:right;font-variant-numeric:tabular-nums}.waveform-container{height:72px;border-radius:var(--radius-sm);overflow:hidden;background:var(--surface);border:1px solid var(--border);position:relative;cursor:default}.waveform-container.hidden{display:none}.waveform-container [part=region]{border-left:2px solid var(--accent);border-right:2px solid var(--accent)}.trim-section{display:flex;flex-direction:column;gap:.5rem;padding:.65rem .75rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm)}.trim-header{display:flex;align-items:center;justify-content:space-between}.trim-label{font-size:.78rem;font-weight:500;color:var(--text-dim);letter-spacing:.02em;text-transform:uppercase}.trim-duration-hint{font-weight:400;text-transform:none;letter-spacing:0;color:var(--text-dim);opacity:.6}.trim-section input[type=number]{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:.4rem .5rem;font-size:.85rem;font-family:inherit;width:100%}.trim-section input[type=number]:focus{outline:none;border-color:var(--accent)}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.25rem;padding-top:.75rem;border-top:1px solid var(--border)}#username-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:.3rem .6rem;font-size:.8rem;font-family:inherit;width:130px;transition:border-color .15s,box-shadow .15s}#username-input::placeholder{color:var(--text-dim)}#username-input:focus{outline:none;border-color:var(--accent)}@keyframes namePulse{0%,to{box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 25%,transparent)}50%{box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 10%,transparent)}}#username-input.needs-name{border-color:var(--accent);animation:namePulse 2s ease-in-out infinite}#username-input.needs-name::placeholder{color:var(--accent);opacity:.75}#toast-container{position:fixed;bottom:1.25rem;right:1.25rem;transition:right .2s;display:flex;flex-direction:column-reverse;gap:.5rem;z-index:200;pointer-events:none}.toast{background:var(--surface);border:1px solid var(--border-hi);border-radius:var(--radius);padding:.55rem .85rem;font-size:.8rem;color:var(--text-dim);box-shadow:0 8px 24px #00000080;opacity:0;transform:translateY(6px);transition:opacity .2s,transform .2s;max-width:280px;line-height:1.45;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.toast--visible{opacity:1;transform:translateY(0)}body.chat-open #toast-container{right:calc(300px + 1.25rem)}.toast-who{font-weight:600;color:var(--text)}.toast-sound{font-weight:600;color:var(--accent)}.current-user{display:flex;align-items:center;gap:.5rem}.user-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover;border:1px solid var(--border-hi)}.user-name{font-size:.85rem;color:var(--text-dim);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.login-overlay{position:fixed;inset:0;z-index:9999;background:var(--bg);display:flex;align-items:center;justify-content:center}.login-box{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2.5rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:360px}.login-logo{color:var(--accent);display:flex}.login-title{font-size:1.5rem;font-weight:700;color:var(--text);letter-spacing:-.02em}.login-subtitle{font-size:.9rem;color:var(--text-dim);margin-top:-.25rem}.btn-google{display:inline-flex;align-items:center;gap:.6rem;margin-top:.5rem;padding:.65rem 1.25rem;background:#fff;color:#3c4043;border:1px solid #dadce0;border-radius:6px;font-size:.9rem;font-weight:500;text-decoration:none;cursor:pointer;transition:background .15s,box-shadow .15s}.btn-google:hover{background:#f8f9fa;box-shadow:0 1px 4px #0000002e}.login-divider{display:flex;align-items:center;gap:.75rem;width:100%;color:var(--text-dim);font-size:.78rem}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border)}.login-tabs{display:flex;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;width:100%}.login-tab{flex:1;padding:.45rem 0;font-size:.82rem;font-weight:500;background:transparent;color:var(--text-dim);border-radius:0;border:none}.login-tab+.login-tab{border-left:1px solid var(--border)}.login-tab.active{background:var(--surface-hi);color:var(--text)}.login-tab:active{transform:none}.login-error{font-size:.8rem;color:var(--danger);background:color-mix(in srgb,var(--danger) 10%,transparent);border:1px solid color-mix(in srgb,var(--danger) 30%,transparent);border-radius:var(--radius-sm);padding:.45rem .7rem;width:100%;text-align:left;line-height:1.45}#auth-form{display:flex;flex-direction:column;gap:.55rem;width:100%}.login-box form input,#auth-form input{width:100%;padding:.6rem .75rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.9rem;font-family:inherit;transition:border-color .12s;margin-bottom:.75rem}.login-box form input::placeholder,#auth-form input::placeholder{color:var(--text-dim)}.login-box form input:focus,#auth-form input:focus{outline:none;border-color:var(--accent)}.auth-submit-btn{width:100%;padding:.65rem;font-size:.9rem;margin-top:.1rem}.login-forgot-link,.login-back-link{display:block;background:none;border:none;color:var(--text-dim);font-size:.82rem;cursor:pointer;font-family:inherit;margin-top:.75rem;padding:0;text-align:center;width:100%;transition:color .12s}.login-forgot-link:hover,.login-back-link:hover{color:var(--accent)}.room-name-display{font-size:.88rem;font-weight:600;color:var(--text);padding:.18rem .55rem;background:var(--surface-hi);border:1px solid var(--border);border-radius:var(--radius-sm);white-space:nowrap;max-width:180px;overflow:hidden;text-overflow:ellipsis}.pending-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--danger);color:#fff;font-size:.65rem;font-weight:700;border-radius:99px;min-width:16px;height:16px;padding:0 4px;line-height:1;margin-left:4px}.screen-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.75rem}.screen-title{font-size:1.35rem;font-weight:700;color:var(--text);letter-spacing:-.02em}.screen-subtitle{font-size:.82rem;color:var(--text-dim);margin-top:.2rem}.room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.room-card{--room-color: var(--accent);background:var(--surface);border:1px solid var(--border);border-top:2px solid var(--room-color);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:border-color .15s,box-shadow .15s,transform .12s}.room-card:hover{border-color:var(--room-color);box-shadow:0 4px 24px #0006;transform:translateY(-2px)}.room-card-main{flex:1;display:flex;align-items:center;gap:.9rem;padding:1.1rem 1.25rem;background:transparent;border-radius:0;text-align:left;width:100%;transition:background .12s}.room-card-main:hover{background:var(--surface-hi)}.room-card-main:active{transform:none}.room-card-icon{width:44px;height:44px;border-radius:var(--radius-sm);background:color-mix(in srgb,var(--room-color) 16%,transparent);border:1px solid color-mix(in srgb,var(--room-color) 28%,transparent);color:var(--room-color);font-size:1.25rem;font-weight:700;font-family:Bebas Neue,system-ui,sans-serif;letter-spacing:.03em;display:flex;align-items:center;justify-content:center;flex-shrink:0}.room-card-info{flex:1;min-width:0}.room-card-name{font-size:1rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:.2rem}.room-card-meta{font-size:.78rem;color:var(--text-dim);display:flex;align-items:center;gap:.35rem}.room-card-arrow{color:var(--room-color);font-size:1.1rem;flex-shrink:0;opacity:0;transform:translate(-6px);transition:opacity .15s,transform .15s}.room-card:hover .room-card-arrow{opacity:1;transform:translate(0)}.room-card-footer{display:flex;align-items:center;justify-content:space-between;padding:.55rem 1.25rem;border-top:1px solid var(--border);background:color-mix(in srgb,var(--bg) 60%,var(--surface))}.room-card-actions{display:flex;align-items:center;gap:.4rem}.role-badge{display:inline-block;font-size:.65rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:.15rem .5rem;border-radius:99px;border:1px solid}.role-badge--owner{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 40%,transparent);background:color-mix(in srgb,var(--accent) 12%,transparent)}.role-badge--member{color:#60a5fa;border-color:color-mix(in srgb,#60a5fa 40%,transparent);background:color-mix(in srgb,#60a5fa 10%,transparent)}.role-badge--viewer{color:var(--text-dim);border-color:var(--border);background:transparent}.role-badge--listener{color:#a78bfa;border-color:color-mix(in srgb,#a78bfa 40%,transparent);background:color-mix(in srgb,#a78bfa 10%,transparent)}.listener-mode-msg{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:4rem 2rem;color:var(--text-dim);text-align:center}.listener-mode-icon{font-size:3rem;line-height:1}.listener-mode-msg p{font-size:.95rem}#join-screen{display:flex;align-items:center;justify-content:center;min-height:60vh}#join-screen.hidden{display:none}.join-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.5rem 3rem;display:flex;flex-direction:column;align-items:center;gap:1rem;max-width:400px;width:100%;text-align:center}.join-logo{color:var(--accent);display:flex}.join-room-name{font-size:1.35rem;font-weight:700;color:var(--text)}.join-status{font-size:.9rem;color:var(--text-dim);line-height:1.5}.join-back-link{font-size:.82rem;color:var(--text-dim);text-decoration:none;margin-top:.25rem;padding:.3rem .6rem;border-radius:var(--radius-sm);transition:background .12s,color .12s}.join-back-link:hover{background:var(--surface-hi);color:var(--text)}.members-overlay{position:fixed;inset:0;background:#00000073;z-index:150;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.members-overlay.hidden{display:none}.members-panel{position:fixed;top:0;right:0;bottom:0;width:360px;max-width:100vw;background:var(--surface);border-left:1px solid var(--border);z-index:151;display:flex;flex-direction:column;box-shadow:-8px 0 32px #00000059}.members-panel.hidden{display:none}.members-panel-inner{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.members-panel-header{display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.members-panel-title{font-size:1rem;font-weight:700;color:var(--text)}.members-section-title{font-size:.72rem;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.65rem}.members-list{display:flex;flex-direction:column;gap:.4rem}.member-row{display:flex;align-items:center;gap:.6rem;padding:.5rem .65rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm)}.member-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;flex-shrink:0;border:1px solid var(--border)}.member-name{flex:1;font-size:.85rem;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.member-actions{display:flex;align-items:center;gap:.3rem;flex-shrink:0}.role-select{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:.2rem .4rem;font-size:.76rem;font-family:inherit;cursor:pointer}.role-select:focus{outline:none;border-color:var(--accent)}.room-card--new{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;border:1.5px dashed var(--border-hi);background:transparent;cursor:pointer;color:var(--text-dim);font-family:inherit;transition:border-color .15s,color .15s,background .15s;min-height:100px}.room-card--new:hover{border-color:var(--accent);color:var(--text);background:var(--surface-hi)}.room-card-new-icon{font-size:1.6rem;line-height:1;font-weight:300}.room-card-new-label{font-size:.85rem;font-weight:500}.yt-float{position:fixed;bottom:5rem;right:1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 32px #00000080;z-index:500;overflow:hidden;min-width:280px}.yt-float-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;cursor:grab;background:var(--surface-hi);-webkit-user-select:none;user-select:none;font-size:.82rem;font-weight:600;color:var(--text);border-bottom:1px solid var(--border)}.yt-url-row{display:flex;gap:.5rem;padding:.5rem .75rem}.yt-url-row input{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:.3rem .6rem;font-size:.82rem;font-family:inherit;transition:border-color .12s}.yt-url-row input::placeholder{color:var(--text-dim)}.yt-url-row input:focus{outline:none;border-color:var(--accent)}.yt-float iframe{display:block;width:100%!important;height:100%!important}.yt-resize-handle{position:absolute;bottom:0;right:0;width:18px;height:18px;cursor:nwse-resize;background:linear-gradient(135deg,transparent 40%,var(--border-hi) 40%,var(--border-hi) 55%,transparent 55%,transparent 65%,var(--border-hi) 65%,var(--border-hi) 80%,transparent 80%)}.yt-controls{display:flex;gap:.5rem;padding:.5rem .75rem;border-top:1px solid var(--border)}.yt-controls.hidden{display:none}@keyframes landingFadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes waveBarPulse{0%,to{height:var(--h-rest);opacity:.4}50%{height:var(--h-peak);opacity:.9}}.landing-page{position:fixed;inset:0;overflow-y:auto;background:var(--bg);background-image:radial-gradient(ellipse at 50% 0%,rgba(232,160,48,.09) 0%,transparent 55%),radial-gradient(ellipse at 15% 85%,rgba(232,160,48,.04) 0%,transparent 40%),radial-gradient(ellipse at 85% 70%,rgba(232,160,48,.03) 0%,transparent 40%);z-index:200;display:flex;flex-direction:column}.landing-nav{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 2rem;position:sticky;top:0;background:#110e0ad1;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);z-index:20;flex-shrink:0}.landing-brand{display:flex;align-items:center;gap:.65rem;font-size:.9rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text)}.landing-brand-logo{width:34px;height:34px;background:color-mix(in srgb,var(--accent) 13%,var(--surface-hi));border:1px solid color-mix(in srgb,var(--accent) 28%,transparent);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.landing-nav-auth{display:flex;align-items:center;gap:.5rem}.landing-nav-signin{background:transparent;border:1px solid var(--border-hi);color:var(--text-dim);border-radius:var(--radius-sm);padding:.4rem 1.1rem;font-size:.85rem;font-weight:500;cursor:pointer;transition:border-color .15s,color .15s}.landing-nav-signin:hover{border-color:var(--accent);color:var(--accent)}.landing-nav-signup{background:var(--accent);border:1px solid var(--accent);color:#fff;border-radius:var(--radius-sm);padding:.4rem 1.1rem;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .15s}.landing-nav-signup:hover{opacity:.88}.landing-hero{display:flex;align-items:center;justify-content:center;padding:6rem 2rem 5rem;min-height:82vh;flex-shrink:0}.landing-hero-content{text-align:center;max-width:720px;width:100%}.landing-headline{font-family:Bebas Neue,system-ui,sans-serif;font-size:clamp(4.5rem,12vw,9rem);line-height:.9;letter-spacing:.015em;color:var(--text);margin-bottom:2.25rem;animation:landingFadeUp .65s ease-out both}.landing-headline-accent{color:var(--accent)}.landing-wave{display:flex;align-items:flex-end;justify-content:center;gap:3px;height:72px;margin-bottom:2.25rem;animation:landingFadeUp .65s ease-out .12s both}.landing-wave-bar{display:block;width:4px;background:var(--accent);border-radius:2px;animation:waveBarPulse 1s ease-in-out infinite}.landing-tagline{font-size:clamp(1rem,2.5vw,1.2rem);color:var(--text-dim);line-height:1.65;margin-bottom:.75rem;animation:landingFadeUp .65s ease-out .22s both}.landing-hero-sub{font-size:clamp(.8rem,1.8vw,.92rem);color:var(--text-dim);opacity:.7;line-height:1.7;max-width:480px;margin:0 auto 2.5rem;text-align:center;animation:landingFadeUp .65s ease-out .3s both}.landing-cta-btn{background:var(--accent);color:#110e0a;border:none;border-radius:var(--radius);padding:.9rem 2.75rem;font-size:1rem;font-weight:700;letter-spacing:.05em;cursor:pointer;transition:transform .15s,box-shadow .15s,background .15s;box-shadow:0 0 36px #e8a03047;animation:landingFadeUp .65s ease-out .32s both}.landing-cta-btn:hover{transform:translateY(-2px);box-shadow:0 0 48px #e8a03073;background:#f0aa38}.landing-cta-btn:active{transform:translateY(0)}.landing-cta-group{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}.landing-cta-secondary{background:transparent;border:2px solid var(--accent);color:var(--accent);padding:.85rem 2rem;border-radius:var(--radius);cursor:pointer;font-size:1rem;font-weight:600;letter-spacing:.04em;opacity:.75;transition:opacity .15s,box-shadow .15s;animation:landingFadeUp .65s ease-out .38s both}.landing-cta-secondary:hover{opacity:1;box-shadow:0 0 24px #e8a03033}.landing-features{padding:5rem 2rem;max-width:1080px;margin:0 auto;width:100%;flex-shrink:0}.landing-features-title{font-family:Bebas Neue,system-ui,sans-serif;font-size:clamp(1.6rem,4vw,2.6rem);letter-spacing:.04em;color:var(--text-dim);text-align:center;margin-bottom:3rem}.landing-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem}.landing-feature-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem;transition:border-color .2s,transform .2s,box-shadow .2s}.landing-feature-card:hover{border-color:var(--border-hi);transform:translateY(-3px);box-shadow:0 10px 36px #00000073}.landing-feature-icon{width:44px;height:44px;background:var(--surface-hi);border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;margin-bottom:1rem;color:var(--accent);flex-shrink:0}.landing-feature-card h3{font-size:.95rem;font-weight:600;color:var(--text);margin-bottom:.45rem}.landing-feature-card p{font-size:.855rem;color:var(--text-dim);line-height:1.65}.landing-cta-section{text-align:center;padding:5rem 2rem 6rem;border-top:1px solid var(--border);background:linear-gradient(to bottom,transparent,rgba(232,160,48,.04));flex-shrink:0}.landing-cta-section .landing-cta-btn,.landing-cta-section .landing-cta-secondary{animation:none}.landing-cta-headline{font-family:Bebas Neue,system-ui,sans-serif;font-size:clamp(2rem,5vw,3.5rem);letter-spacing:.02em;color:var(--text);margin-bottom:.75rem}.landing-cta-sub{color:var(--text-dim);font-size:.9rem;margin-bottom:2rem}.landing-faq{max-width:720px;margin:0 auto;padding:3rem 1.5rem;width:100%;box-sizing:border-box}.landing-faq-title{font-size:1.5rem;font-weight:700;color:var(--text);margin-bottom:1.5rem;text-align:center}.landing-faq-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--border)}.landing-faq-item{border-bottom:1px solid var(--border);padding:1.1rem 0}.landing-faq-q{font-size:.95rem;font-weight:600;color:var(--text);margin:0 0 .4rem}.landing-faq-a{font-size:.88rem;color:var(--text-dim);margin:0;line-height:1.65}.landing-footer{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.5rem;padding:1.25rem;font-size:.78rem;color:var(--text-dim);border-top:1px solid var(--border);flex-shrink:0}.landing-footer-sep{opacity:.35}.landing-footer-email{color:var(--accent);text-decoration:none}.landing-footer-email:hover{text-decoration:underline}.kofi-footer-btn{display:inline-flex;align-items:center;gap:.35rem;color:#ff5e5b;text-decoration:none;font-weight:600;transition:opacity .15s}.kofi-footer-btn:hover{opacity:.75;text-decoration:none}.chat-panel{position:fixed;top:56px;right:0;bottom:0;width:300px;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;z-index:100;box-shadow:-6px 0 24px #0000004d}.chat-panel.hidden{display:none}.chat-panel-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--border);flex-shrink:0}.chat-panel-title{font-size:.88rem;font-weight:700;color:var(--text);letter-spacing:.02em}.chat-messages{flex:1;overflow-y:auto;padding:.75rem;display:flex;flex-direction:column;gap:.65rem}.chat-msg{display:flex;align-items:flex-start;gap:.5rem}.chat-avatar{width:26px;height:26px;border-radius:50%;object-fit:cover;flex-shrink:0;border:1px solid var(--border);margin-top:2px}.chat-msg--continue{margin-top:-.3rem}.chat-msg--continue .chat-avatar{visibility:hidden}.chat-bubble{flex:1;min-width:0}.chat-meta{display:flex;align-items:baseline;gap:.4rem;margin-bottom:.2rem}.chat-name{font-size:.78rem;font-weight:600;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-name--self{color:var(--accent)}.chat-time{font-size:.68rem;color:var(--text-dim);opacity:.6;flex-shrink:0}.chat-text{font-size:.84rem;color:var(--text);line-height:1.45;word-break:break-word;background:var(--bg);border:1px solid var(--border);border-radius:0 var(--radius-sm) var(--radius-sm) var(--radius-sm);padding:.35rem .55rem}.chat-msg--self .chat-text{background:color-mix(in srgb,var(--accent) 10%,var(--surface));border-color:color-mix(in srgb,var(--accent) 25%,transparent);border-radius:var(--radius-sm) 0 var(--radius-sm) var(--radius-sm)}.chat-input-row{display:flex;gap:.4rem;padding:.65rem .75rem;border-top:1px solid var(--border);flex-shrink:0}#chat-input{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:.35rem .6rem;font-size:.84rem;font-family:inherit;transition:border-color .12s}#chat-input::placeholder{color:var(--text-dim)}#chat-input:focus{outline:none;border-color:var(--accent)}.chat-btn-wrapper{position:relative;flex-shrink:0}.chat-unread-badge{position:absolute;top:-4px;right:-4px;background:var(--accent);color:#110e0a;font-size:.6rem;font-weight:700;border-radius:99px;min-width:15px;height:15px;padding:0 3px;display:flex;align-items:center;justify-content:center;line-height:1;pointer-events:none}.admin-page{max-width:1100px;margin:0 auto;padding:2rem 1.5rem}.admin-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.75rem}.admin-title{font-size:1.4rem;font-weight:700;color:var(--text);letter-spacing:.02em}.admin-back-btn{background:transparent;border:1px solid var(--border);color:var(--text-dim);border-radius:var(--radius-sm);padding:.35rem .9rem;font-size:.82rem;cursor:pointer;transition:border-color .15s,color .15s}.admin-back-btn:hover{border-color:var(--accent);color:var(--accent)}.admin-tabs{display:flex;gap:.25rem;border-bottom:1px solid var(--border);margin-bottom:1.75rem}.admin-tab{background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-dim);padding:.55rem 1.1rem;font-size:.88rem;font-weight:500;cursor:pointer;margin-bottom:-1px;transition:color .15s,border-color .15s}.admin-tab:hover{color:var(--text)}.admin-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.admin-content{animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:2rem}.admin-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;text-align:center}.admin-stat-value{font-size:2rem;font-weight:700;color:var(--accent);line-height:1;margin-bottom:.4rem}.admin-stat-label{font-size:.78rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em}.admin-section-title{font-size:.88rem;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.75rem}.admin-empty{color:var(--text-dim);font-size:.88rem;padding:2rem 0;text-align:center}.admin-error{color:#f87171;font-size:.85rem;margin-bottom:1rem}.admin-online-list{display:flex;flex-direction:column;gap:.5rem}.admin-online-item{display:flex;align-items:center;gap:.75rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.6rem .9rem}.admin-online-info{display:flex;flex-direction:column;gap:.1rem}.admin-online-name{font-size:.88rem;font-weight:500;color:var(--text)}.admin-online-room{font-size:.78rem;color:var(--text-dim)}.admin-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover}.admin-avatar-sm{width:24px;height:24px;border-radius:50%;object-fit:cover}.admin-avatar-placeholder{width:32px;height:32px;border-radius:50%;background:var(--surface-hi);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;color:var(--text-dim);flex-shrink:0}.admin-table{width:100%;border-collapse:collapse;font-size:.85rem}.admin-table th{text-align:left;color:var(--text-dim);font-weight:500;font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;padding:.5rem .75rem;border-bottom:1px solid var(--border)}.admin-table td{padding:.65rem .75rem;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--surface)}.admin-table-user{display:flex;align-items:center;gap:.5rem}.admin-dim{color:var(--text-dim)}.admin-mono{font-family:monospace;font-size:.78rem}.admin-ref{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-preview-btn{background:transparent;border:1px solid var(--border);color:var(--text-dim);border-radius:var(--radius-sm);padding:.25rem .7rem;font-size:.78rem;cursor:pointer;transition:border-color .15s,color .15s}.admin-preview-btn:hover{border-color:var(--accent);color:var(--accent)}.admin-modal-backdrop{position:fixed;inset:0;background:#0009;z-index:500;display:flex;align-items:center;justify-content:center;padding:1.5rem}.admin-modal{background:var(--surface);border:1px solid var(--border-hi);border-radius:var(--radius-lg);width:100%;max-width:680px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.admin-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.25rem;border-bottom:1px solid var(--border);flex-shrink:0}.admin-modal-title{font-size:1rem;font-weight:600;color:var(--text)}.admin-modal-close{background:transparent;border:none;color:var(--text-dim);font-size:1rem;cursor:pointer;line-height:1;padding:.25rem}.admin-modal-close:hover{color:var(--text)}.admin-sound-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.6rem;padding:1.1rem;overflow-y:auto}.admin-sound-btn{display:flex;flex-direction:column;align-items:center;gap:.3rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem .5rem;cursor:pointer;transition:border-color .15s,background .15s;text-align:center;min-height:90px}.admin-sound-btn:hover{border-color:var(--accent);background:var(--surface-hi)}.admin-sound-btn.playing{border-color:var(--accent);background:#e8a03014}.admin-sound-icon{font-size:1.4rem;line-height:1}.admin-sound-name{font-size:.78rem;font-weight:500;color:var(--text);word-break:break-word;line-height:1.3}.admin-sound-meta{font-size:.68rem;color:var(--text-dim)}.admin-badge{background:var(--surface-hi);border:1px solid var(--border);border-radius:999px;padding:.15rem .55rem;font-size:.72rem;color:var(--text-dim);white-space:nowrap}.admin-badge--electron{background:color-mix(in srgb,#a78bfa 12%,var(--surface-hi));border-color:color-mix(in srgb,#a78bfa 35%,transparent);color:#a78bfa}.admin-badge--web{background:color-mix(in srgb,#60a5fa 12%,var(--surface-hi));border-color:color-mix(in srgb,#60a5fa 35%,transparent);color:#60a5fa}.admin-delete-btn{background:transparent;border:1px solid var(--border);color:var(--text-dim);border-radius:var(--radius-sm);padding:.25rem .7rem;font-size:.78rem;cursor:pointer;transition:border-color .15s,color .15s}.admin-delete-btn:hover{border-color:#f87171;color:#f87171}.admin-templates-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.admin-template-list{display:flex;flex-direction:column;gap:.6rem}.admin-template-card{display:flex;align-items:center;gap:1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.9rem 1.1rem}.admin-template-icon{font-size:2rem;line-height:1;flex-shrink:0}.admin-template-info{flex:1;min-width:0}.admin-template-name{font-size:.92rem;font-weight:600;color:var(--text);margin-bottom:.15rem}.admin-template-desc{font-size:.82rem;color:var(--text-dim);margin-bottom:.2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-template-meta{font-size:.75rem;color:var(--accent)}.admin-template-actions{display:flex;gap:.4rem;flex-shrink:0}.admin-template-editor{max-width:700px}.admin-template-form{padding:1.1rem 1.25rem;overflow-y:auto;display:flex;flex-direction:column;gap:.9rem;flex:1}.admin-form-row{display:flex;flex-direction:column;gap:.35rem}.admin-form-label{font-size:.78rem;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em}.admin-form-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:.5rem .75rem;font-size:.88rem;width:100%;box-sizing:border-box;outline:none}.admin-form-input:focus{border-color:var(--accent)}.admin-form-input--icon{max-width:80px;text-align:center;font-size:1.2rem}.admin-form-section{display:flex;flex-direction:column;gap:.35rem}.admin-sound-picker{border:1px solid var(--border);border-radius:var(--radius-sm);max-height:280px;overflow-y:auto;background:var(--bg)}.admin-sound-pick-item{display:flex;align-items:center;gap:.6rem;padding:.5rem .75rem;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s}.admin-sound-pick-item:last-child{border-bottom:none}.admin-sound-pick-item:hover{background:var(--surface)}.admin-sound-pick-item.selected{background:#e8a03012}.admin-sound-pick-item input[type=checkbox]{accent-color:var(--accent);flex-shrink:0}.admin-sound-pick-icon{font-size:1rem;flex-shrink:0}.admin-sound-pick-name{font-size:.85rem;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-sound-pick-cat{font-size:.72rem;color:var(--text-dim);flex-shrink:0}.admin-rooms-toolbar{margin-bottom:.75rem}.admin-toggle-btn{font-size:.8rem;padding:.3rem .75rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-hi);color:var(--text-dim);cursor:pointer;font-family:inherit;transition:background .12s,color .12s,border-color .12s}.admin-toggle-btn:hover{background:color-mix(in srgb,var(--border) 60%,transparent);color:var(--text)}.admin-toggle-btn.active{background:color-mix(in srgb,var(--accent) 12%,transparent);border-color:color-mix(in srgb,var(--accent) 35%,transparent);color:var(--accent)}.cookie-notice[data-v-c8e0bfa5]{position:fixed;bottom:16px;left:50%;transform:translate(-50%);z-index:999;display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--border-hi);border-radius:var(--radius);padding:12px 16px;font-size:13px;color:var(--text-dim);white-space:nowrap;box-shadow:0 4px 24px #0006}.cookie-link[data-v-c8e0bfa5]{color:var(--text);text-decoration:underline}.cookie-btn[data-v-c8e0bfa5]{flex-shrink:0;background:var(--border-hi);border:none;border-radius:var(--radius-sm);color:var(--text);font-size:13px;padding:5px 12px;cursor:pointer}.cookie-btn[data-v-c8e0bfa5]:hover{background:var(--accent);color:#000}.landing-screenshots[data-v-d6dd0ffb]{padding:4rem 2rem;max-width:1100px;margin:0 auto}.landing-screenshots-title[data-v-d6dd0ffb]{font-size:1.6rem;font-weight:700;text-align:center;margin-bottom:2rem;color:var(--text-primary, #fff)}.landing-screenshots-grid[data-v-d6dd0ffb]{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media(max-width:600px){.landing-screenshots-grid[data-v-d6dd0ffb]{grid-template-columns:1fr}}.landing-screenshot-item[data-v-d6dd0ffb]{margin:0;border-radius:10px;overflow:hidden;border:1px solid rgba(255,255,255,.08);background:var(--bg-card, #1a1a1a);cursor:zoom-in;transition:border-color .15s}.landing-screenshot-item[data-v-d6dd0ffb]:hover{border-color:#fff3}.landing-screenshot-item img[data-v-d6dd0ffb]{width:100%;height:260px;display:block;object-fit:cover;object-position:top}.landing-screenshot-item figcaption[data-v-d6dd0ffb]{padding:.65rem 1rem;font-size:.85rem;color:var(--text-muted, #888);text-align:center}.screenshot-lightbox[data-v-d6dd0ffb]{position:fixed;inset:0;z-index:1000;background:#000000d9;display:flex;align-items:center;justify-content:center;cursor:zoom-out;padding:2rem}.screenshot-lightbox img[data-v-d6dd0ffb]{max-width:100%;max-height:100%;border-radius:8px;box-shadow:0 8px 40px #0009}.update-banner[data-v-c51d78a6]{display:flex;align-items:center;gap:.5rem;padding:0 1rem;height:34px;font-size:.8rem;flex-shrink:0;z-index:110}.update-banner.downloading[data-v-c51d78a6]{background:color-mix(in srgb,#3b82f6 12%,var(--surface));border-bottom:1px solid color-mix(in srgb,#3b82f6 30%,transparent);color:#93c5fd}.update-banner.ready[data-v-c51d78a6]{background:color-mix(in srgb,#22c55e 12%,var(--surface));border-bottom:1px solid color-mix(in srgb,#22c55e 30%,transparent);color:#86efac}.update-banner-icon[data-v-c51d78a6]{flex-shrink:0;display:flex;align-items:center}.update-banner-text[data-v-c51d78a6]{flex:1;display:flex;align-items:center;gap:.4rem}.update-banner-progress[data-v-c51d78a6]{opacity:.7;font-variant-numeric:tabular-nums}.update-banner-btn[data-v-c51d78a6]{padding:.2rem .7rem;border-radius:99px;border:1px solid currentColor;background:transparent;color:inherit;font-size:.75rem;font-weight:600;cursor:pointer;font-family:inherit;flex-shrink:0;opacity:.9;transition:opacity .12s}.update-banner-btn[data-v-c51d78a6]:hover{opacity:1}.update-banner-dismiss[data-v-c51d78a6]{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border:none;background:transparent;color:inherit;opacity:.5;cursor:pointer;border-radius:4px;flex-shrink:0;transition:opacity .12s}.update-banner-dismiss[data-v-c51d78a6]:hover{opacity:1}.update-banner-enter-active[data-v-c51d78a6],.update-banner-leave-active[data-v-c51d78a6]{transition:height .2s ease,opacity .2s ease;overflow:hidden}.update-banner-enter-from[data-v-c51d78a6],.update-banner-leave-to[data-v-c51d78a6]{height:0;opacity:0}.create-room-templates[data-v-3af6c148]{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.25rem}.create-room-tpl[data-v-3af6c148]{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.65rem .85rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color .15s,background .15s;min-width:80px}.create-room-tpl[data-v-3af6c148]:hover{border-color:var(--accent)}.create-room-tpl.active[data-v-3af6c148]{border-color:var(--accent);background:#e8a03014}.create-room-tpl-icon[data-v-3af6c148]{font-size:1.4rem;line-height:1}.create-room-tpl-name[data-v-3af6c148]{font-size:.78rem;font-weight:600;color:var(--text)}.create-room-tpl-count[data-v-3af6c148]{font-size:.68rem;color:var(--text-dim)}.join-page[data-v-bd08255c]{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem;background:var(--bg)}.join-container[data-v-bd08255c]{width:100%;max-width:420px;display:flex;flex-direction:column;align-items:center;gap:2rem}.join-brand[data-v-bd08255c]{display:flex;align-items:center;gap:.6rem;color:var(--text-dim)}.join-brand-icon[data-v-bd08255c]{width:22px;height:14px;color:var(--accent)}.join-brand-name[data-v-bd08255c]{font-size:.9rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.join-card[data-v-bd08255c]{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center}.join-card--error[data-v-bd08255c]{border-color:#f871714d}.join-room-name[data-v-bd08255c]{font-size:1.6rem;font-weight:700;color:var(--text);line-height:1.2;word-break:break-word}.join-stats[data-v-bd08255c]{display:flex;gap:1.5rem;justify-content:center}.join-stat[data-v-bd08255c]{display:flex;align-items:center;gap:.4rem;font-size:.82rem;color:var(--text-dim)}.join-stat svg[data-v-bd08255c]{width:14px;height:14px;flex-shrink:0}.join-divider[data-v-bd08255c]{width:100%;height:1px;background:var(--border)}.join-hint[data-v-bd08255c]{font-size:.85rem;color:var(--text-dim);line-height:1.5;max-width:300px}.btn-google[data-v-bd08255c]{width:100%;display:flex;align-items:center;justify-content:center;gap:.6rem;background:#fff;color:#333;border:1px solid #ddd;border-radius:var(--radius);padding:.65rem 1rem;font-size:.9rem;font-weight:500;cursor:pointer;text-decoration:none;transition:background .15s}.btn-google[data-v-bd08255c]:hover{background:#f5f5f5}.join-or[data-v-bd08255c]{width:100%;display:flex;align-items:center;gap:.75rem;color:var(--text-dim);font-size:.78rem}.join-or[data-v-bd08255c]:before,.join-or[data-v-bd08255c]:after{content:"";flex:1;height:1px;background:var(--border)}.join-auth-tabs[data-v-bd08255c]{display:flex;gap:0;width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px}.join-auth-tabs button[data-v-bd08255c]{flex:1;background:transparent;border:none;border-radius:calc(var(--radius-sm) - 2px);color:var(--text-dim);font-size:.82rem;font-weight:500;padding:.35rem 0;cursor:pointer;transition:background .12s,color .12s}.join-auth-tabs button.active[data-v-bd08255c]{background:var(--surface);color:var(--text)}.join-auth-error[data-v-bd08255c]{font-size:.82rem;color:#f87171;width:100%;text-align:left}.join-auth-form[data-v-bd08255c]{width:100%;display:flex;flex-direction:column;gap:.5rem}.join-auth-form input[data-v-bd08255c]{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.88rem;padding:.55rem .75rem;outline:none;box-sizing:border-box;transition:border-color .15s}.join-auth-form input[data-v-bd08255c]:focus{border-color:var(--accent)}.join-cta[data-v-bd08255c]{display:flex;align-items:center;gap:.5rem;background:var(--accent);color:#000;border:none;border-radius:var(--radius);padding:.7rem 1.5rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s;width:100%;justify-content:center}.join-cta svg[data-v-bd08255c]{width:16px;height:16px;flex-shrink:0}.join-cta[data-v-bd08255c]:hover:not(:disabled){opacity:.9}.join-cta[data-v-bd08255c]:active:not(:disabled){transform:scale(.98)}.join-cta[data-v-bd08255c]:disabled{opacity:.5;cursor:not-allowed}.join-pending-icon[data-v-bd08255c]{width:48px;height:48px;background:color-mix(in srgb,var(--accent) 12%,transparent);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--accent)}.join-pending-icon svg[data-v-bd08255c]{width:24px;height:24px}.join-pending-title[data-v-bd08255c]{font-size:1.1rem;font-weight:600;color:var(--text)}.join-error-icon[data-v-bd08255c]{width:48px;height:48px;background:#f871711f;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#f87171}.join-error-icon svg[data-v-bd08255c]{width:24px;height:24px}.join-error-title[data-v-bd08255c]{font-size:1.1rem;font-weight:600;color:var(--text)}.join-back-btn[data-v-bd08255c]{display:inline-flex;align-items:center;padding:.45rem 1rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--text-dim);font-size:.82rem;text-decoration:none;transition:border-color .15s,color .15s}.join-back-btn[data-v-bd08255c]:hover{border-color:var(--accent);color:var(--accent)}.join-back-link[data-v-bd08255c]{font-size:.8rem;color:var(--text-dim);text-decoration:none;transition:color .15s}.join-back-link[data-v-bd08255c]:hover{color:var(--text)}.join-spinner[data-v-bd08255c]{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin-bd08255c .7s linear infinite}@keyframes spin-bd08255c{to{transform:rotate(360deg)}}.anon-banner[data-v-2f656f26]{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.4rem 1rem;background:var(--color-warning-bg, #fef3c7);color:var(--color-warning-text, #92400e);font-size:.85rem;border-bottom:1px solid var(--color-warning-border, #fde68a)}.anon-banner-signup[data-v-2f656f26]{background:var(--color-warning-text, #92400e);color:#fff;border:none;border-radius:6px;padding:.25rem .75rem;cursor:pointer;font-size:.8rem;white-space:nowrap}.discord-body[data-v-f16b41ad]{display:flex;flex-direction:column;gap:1.25rem}.discord-loading[data-v-f16b41ad]{color:var(--text-dim);font-size:.85rem}.discord-section[data-v-f16b41ad]{display:flex;flex-direction:column;gap:.85rem}.discord-status[data-v-f16b41ad]{display:flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:600}.discord-status-dot[data-v-f16b41ad]{width:8px;height:8px;border-radius:50%;flex-shrink:0}.discord-status--connected .discord-status-dot[data-v-f16b41ad]{background:#3ba55c}.discord-status--connected[data-v-f16b41ad]{color:#3ba55c}.discord-status--disconnected .discord-status-dot[data-v-f16b41ad]{background:var(--text-dim)}.discord-status--disconnected[data-v-f16b41ad]{color:var(--text-dim)}.discord-desc[data-v-f16b41ad],.discord-notice[data-v-f16b41ad]{font-size:.82rem;color:var(--text-dim);line-height:1.5}.discord-channel-id[data-v-f16b41ad]{font-size:.8rem;color:var(--text-dim)}.discord-channel-id code[data-v-f16b41ad],.discord-notice code[data-v-f16b41ad]{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.1rem .35rem;font-size:.78rem}.discord-disconnect-btn[data-v-f16b41ad]{align-self:flex-start}.discord-step[data-v-f16b41ad]{display:flex;gap:.85rem;align-items:flex-start}.discord-step-num[data-v-f16b41ad]{width:22px;height:22px;border-radius:50%;background:#5865f2;color:#fff;font-size:.72rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.discord-step-content[data-v-f16b41ad]{display:flex;flex-direction:column;gap:.5rem;flex:1}.discord-step-title[data-v-f16b41ad]{font-size:.85rem;font-weight:600;color:var(--text)}.discord-step-hint[data-v-f16b41ad]{font-size:.78rem;color:var(--text-dim);line-height:1.5}.discord-invite-btn[data-v-f16b41ad]{display:inline-flex;align-items:center;gap:.4rem;background:#5865f2;text-decoration:none;margin-top:.25rem;border-radius:var(--radius-sm);padding:.4rem .9rem;font-size:.82rem;font-weight:600;color:#fff}.discord-invite-btn[data-v-f16b41ad]:hover{background:#4752c4}.discord-input[data-v-f16b41ad]{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:.45rem .7rem;font-size:.85rem;box-sizing:border-box;outline:none;font-family:monospace}.discord-input[data-v-f16b41ad]:focus{border-color:#5865f2}.discord-error[data-v-f16b41ad]{font-size:.78rem;color:#f87171}.discord-select[data-v-f16b41ad]{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:.45rem .7rem;font-size:.85rem;outline:none;cursor:pointer}.discord-select[data-v-f16b41ad]:focus{border-color:#5865f2}.discord-guild-name[data-v-f16b41ad]{font-size:.85rem;font-weight:600;color:var(--text)}.modal-overlay[data-v-76c98009]{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-box[data-v-76c98009]{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;max-width:400px;width:90%;display:flex;flex-direction:column;gap:1rem}.modal-title[data-v-76c98009]{margin:0;font-size:1.2rem;color:var(--text)}.modal-body[data-v-76c98009]{margin:0;font-size:.88rem;color:var(--text-dim);line-height:1.55}.modal-actions[data-v-76c98009]{display:flex;gap:.75rem;justify-content:flex-end}.btn-primary[data-v-76c98009]{background:var(--accent);color:#110e0a;border:none;border-radius:var(--radius);padding:.5rem 1.25rem;font-size:.88rem;font-weight:600;cursor:pointer;transition:opacity .15s}.btn-primary[data-v-76c98009]:hover{opacity:.88}.btn-secondary[data-v-76c98009]{background:transparent;border:1px solid var(--border-hi);border-radius:var(--radius);padding:.5rem 1.25rem;font-size:.88rem;color:var(--text-dim);cursor:pointer;transition:border-color .15s,color .15s}.btn-secondary[data-v-76c98009]:hover{border-color:var(--accent);color:var(--accent)}#soundboard-loader[data-v-bad84b22]{display:flex;align-items:center;justify-content:center;height:calc(100vh - 100px)}.loader-spinner[data-v-bad84b22]{width:36px;height:36px;border:3px solid var(--color-border, #e5e7eb);border-top-color:var(--color-accent, #6366f1);border-radius:50%;animation:spin-bad84b22 .7s linear infinite}@keyframes spin-bad84b22{to{transform:rotate(360deg)}}.badge-online{display:inline-block;background:#d1fae5;color:#065f46;border-radius:4px;padding:.1rem .4rem;font-size:.75rem;font-weight:600}.badge-anon{display:inline-block;background:#fef3c7;color:#92400e;border-radius:4px;padding:.1rem .4rem;font-size:.75rem;margin-left:.5rem;vertical-align:middle}.step-number[data-v-b2e77744],.step-number[data-v-3449b8f9],.step-number[data-v-724b9cd2]{font-family:Bebas Neue,system-ui,sans-serif;font-size:2.2rem;color:var(--accent);line-height:1;margin-bottom:.6rem}.terms-page[data-v-9b3b6744]{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}.terms-content[data-v-9b3b6744]{max-width:720px;margin:0 auto;padding:3rem 1.5rem 4rem;flex:1;color:var(--text);line-height:1.75}.terms-title[data-v-9b3b6744]{font-size:2rem;font-weight:700;color:var(--text);margin-bottom:.35rem}.terms-updated[data-v-9b3b6744]{font-size:.82rem;color:var(--text-dim);margin-bottom:2rem}.terms-content h2[data-v-9b3b6744]{font-size:1.1rem;font-weight:700;color:var(--text);margin-top:2rem;margin-bottom:.5rem}.terms-content p[data-v-9b3b6744]{margin-bottom:.85rem;font-size:.93rem;color:var(--text)}.terms-content ul[data-v-9b3b6744]{margin:.5rem 0 .85rem 1.4rem;font-size:.93rem}.terms-content li[data-v-9b3b6744]{margin-bottom:.3rem}.terms-content a[data-v-9b3b6744]{color:var(--accent);text-decoration:none}.terms-content a[data-v-9b3b6744]:hover{text-decoration:underline}
