@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700;900&family=Lora:ital,wght@0,400;0,600;1,400&family=IBM+Plex+Mono:wght@400;500&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{color-scheme:light dark;--accent: #e8a030;--accent-dim: #c4852a;--accent-glow: rgba(232, 160, 48, .2);--accent-contrast: #1a0e00;--bg: #faf5ec;--text: #1c1208;--text-muted: #8a7060;--border: #ddc9a8;--surface: #f0e8d8;--surface-own: #fde8c0;--surface-hover: #f5ecdc;--textbox-color: #faf0e0}@media(prefers-color-scheme:dark){:root{--bg: #140e06;--text: #f0e4c8;--text-muted: #7a6248;--border: #2e1e0e;--surface: #1e160a;--surface-own: #2a1c08;--surface-hover: #241a0c;--textbox-color: #1a1206}}html,body,#root{height:100%;margin:0}body{font-family:Lora,Georgia,Times New Roman,serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg);color:var(--text)}code{font-family:IBM Plex Mono,Courier New,monospace}button{padding:.45rem .8rem;border:none;border-radius:.375rem;background-color:var(--accent);color:var(--accent-contrast);cursor:pointer;font-weight:500;font-family:IBM Plex Mono,Courier New,monospace;font-size:.82rem;letter-spacing:.2px;transition:background-color .15s ease,opacity .15s ease}button:hover:not(:disabled){background-color:var(--accent-dim)}button:disabled{opacity:.45;cursor:not-allowed}input,textarea{border:1px solid var(--border);border-radius:.375rem;caret-color:var(--accent);font-family:Lora,Georgia,serif;font-weight:400;font-size:.9rem;letter-spacing:.1px;padding:.45rem .75rem;background:var(--textbox-color);color:var(--text);transition:border-color .15s ease,box-shadow .15s ease}input:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}input::placeholder,textarea::placeholder{color:var(--text-muted);font-style:italic}.chat-panel{display:flex;flex-direction:column;height:100%;overflow:hidden}.chat-users{padding:.6rem .75rem;border-bottom:1px solid var(--border);flex-shrink:0}.chat-users-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.chat-users-count{font-size:.67rem;font-family:IBM Plex Mono,monospace;color:var(--accent);text-transform:uppercase;letter-spacing:.8px;font-weight:500}.chat-name-btn{background:none;border:none;padding:.2rem .4rem;font-size:.74rem;font-family:IBM Plex Mono,monospace;cursor:pointer;color:var(--text-muted);border-radius:4px;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:background .15s,color .15s}.chat-name-btn:hover{background:var(--surface-hover);color:var(--accent)}.chat-name-form{display:flex;gap:.25rem;flex:1}.chat-name-input{flex:1;font-size:.75rem;padding:.2rem .4rem;min-width:0}.chat-name-save{padding:.2rem .5rem;font-size:.75rem;min-width:auto}.chat-users-list{list-style:none;display:flex;flex-wrap:wrap;gap:.25rem .75rem;margin-top:.4rem}.chat-user-item{display:flex;align-items:center;gap:.3rem;font-size:.74rem;font-family:IBM Plex Mono,monospace;color:var(--text-muted)}.chat-user-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;animation:dot-pulse 3s ease-in-out infinite}.chat-user-name{color:var(--text)}.chat-user-you{color:var(--text-muted)}.chat-messages-container{flex:1 1 0;display:flex;flex-direction:column;min-height:0;overflow:hidden}.chat-messages-header{display:flex;align-items:center;justify-content:space-between;padding:.35rem .75rem;border-bottom:1px solid var(--border);flex-shrink:0}.chat-messages-label{font-family:IBM Plex Mono,monospace;font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);opacity:.7}.chat-clear-btn{font-family:IBM Plex Mono,monospace;font-size:.62rem;color:var(--text-muted);background:none;border:none;cursor:pointer;padding:.1rem .35rem;border-radius:3px;opacity:.6;transition:opacity .15s,color .15s}.chat-clear-btn:hover{opacity:1;color:var(--accent)}.chat-clear-confirm{display:flex;align-items:center;gap:.35rem;font-family:IBM Plex Mono,monospace;font-size:.62rem;color:var(--text-muted)}.chat-clear-yes,.chat-clear-no{font-family:IBM Plex Mono,monospace;font-size:.62rem;padding:.1rem .4rem;border-radius:3px;border:1px solid var(--border);cursor:pointer;background:var(--surface);color:var(--text);transition:background .15s}.chat-clear-yes:hover{background:var(--accent);color:var(--accent-contrast);border-color:var(--accent)}.chat-clear-no:hover{background:var(--surface-own)}.chat-messages{flex:1 1 0;overflow-y:auto;padding:.75rem;display:flex;flex-direction:column;gap:.35rem;min-height:0}.chat-messages::-webkit-scrollbar{width:4px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.chat-empty{font-family:Lora,serif;font-size:.82rem;font-style:italic;color:var(--text-muted);text-align:center;margin-top:1.5rem;opacity:.7}.chat-message--system{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.25rem .5rem;font-style:italic;font-family:IBM Plex Mono,monospace;font-size:.68rem;color:var(--text-muted);opacity:.65}.chat-message--user{background:var(--surface);padding:.4rem .65rem;border-radius:8px;border-left:2px solid var(--border);font-size:.82rem}.chat-message--own{background:var(--surface-own);border-left:2px solid var(--accent)}.chat-message-header{display:flex;align-items:baseline;gap:.4rem;margin-bottom:.15rem}.chat-message-sender{font-weight:600;font-size:.7rem;font-family:IBM Plex Mono,monospace;color:var(--accent)}.chat-message-time{font-size:.6rem;color:var(--text-muted);font-family:IBM Plex Mono,monospace;margin-left:auto;opacity:.7}.chat-message-text{color:var(--text);line-height:1.5;word-break:break-word;font-family:Lora,serif}.chat-input-form{display:flex;gap:.4rem;padding:.6rem .75rem;border-top:1px solid var(--border);flex-shrink:0}.chat-input{flex:1;font-size:.85rem;min-width:0}.chat-send-btn{padding:.4rem .7rem;font-size:.78rem}.chat-typing-indicator{display:flex;align-items:center;gap:.5rem;padding:.3rem .75rem .2rem;font-family:Lora,serif;font-style:italic;font-size:.72rem;color:var(--text-muted);flex-shrink:0;min-height:1.4rem}.typing-dots{display:inline-flex;gap:3px;align-items:center}.typing-dots span{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:.6;animation:typing-bounce 1.2s ease-in-out infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}.player-panel{display:flex;flex-direction:column;height:100%;overflow:hidden}.player-embed-wrapper{position:relative;flex:1 1 0;background:#0a0804;min-height:0}.player-embed{position:absolute;inset:0;width:100%;height:100%}@keyframes eq-dance{0%,to{transform:scaleY(.2)}50%{transform:scaleY(1)}}.player-embed-wrapper--audio-only{flex:none;height:96px;background:var(--surface);display:flex;align-items:center;justify-content:center;gap:1.5rem}.player-embed-wrapper--audio-only .player-embed{position:absolute;width:1px;height:1px;opacity:.01;left:0;top:0;pointer-events:none}.audio-viz{display:flex;align-items:flex-end;gap:4px;height:36px}.eq-bar{width:5px;height:36px;background:var(--accent);transform-origin:bottom center;transform:scaleY(.2);border-radius:2px 2px 0 0;opacity:.65;transition:transform .1s}.eq-bar--playing{animation:eq-dance .75s ease-in-out infinite}.audio-viz-meta{display:flex;flex-direction:column;gap:.2rem;min-width:0;max-width:180px}.audio-viz-title{font-family:Playfair Display,Georgia,serif;font-size:.9rem;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.audio-viz-label{font-family:IBM Plex Mono,monospace;font-size:.65rem;color:var(--text-muted);letter-spacing:.04em}@media(max-width:768px){.player-embed-wrapper{flex:none;height:min(56.25vw,40dvh)}.player-embed-wrapper--audio-only{height:80px}}.player-idle{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;color:var(--text-muted)}.player-idle p{font-family:Lora,serif;font-size:.95rem;font-style:italic}.player-idle-hint{font-size:.8rem!important;opacity:.6}.vinyl-record{width:76px;height:76px;border-radius:50%;background:radial-gradient(circle at 50% 50%,var(--bg) 0,var(--bg) 5px,transparent 5px),radial-gradient(circle at 50% 50%,var(--accent) 0,var(--accent) 14px,transparent 14px),radial-gradient(circle at 50% 50%,#1a1208 0 100%);border:2px solid var(--border);box-shadow:inset 0 0 0 10px #ffffff05,inset 0 0 0 22px #ffffff03,inset 0 0 0 34px #ffffff02,0 4px 24px #00000073;margin-bottom:.25rem;opacity:.75}.player-progress{position:relative;height:18px;background:var(--surface);border-top:1px solid var(--border);flex-shrink:0;cursor:default;display:flex;align-items:center}.player-progress-fill{position:absolute;left:0;top:0;bottom:0;background:var(--accent);opacity:.7;transition:width .5s linear;pointer-events:none}.player-progress-time{position:relative;z-index:1;font-family:IBM Plex Mono,monospace;font-size:.64rem;color:var(--text-muted);padding:0 .6rem;pointer-events:none;white-space:nowrap;text-shadow:0 0 4px var(--surface)}.player-controls{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.6rem 1rem;border-top:1px solid var(--border);flex-shrink:0;background:var(--surface)}.player-actions{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.playpause-btn{padding:.28rem .55rem;font-size:.85rem;background:var(--accent);color:var(--accent-contrast);border:none;border-radius:4px;cursor:pointer;flex-shrink:0;line-height:1;transition:opacity .15s}.playpause-btn:hover{opacity:.85}.video-toggle-btn{padding:.2rem .45rem;font-size:.65rem;font-family:IBM Plex Mono,monospace;background:transparent;color:var(--text-muted);border:1px solid var(--border);border-radius:4px;cursor:pointer;flex-shrink:0;white-space:nowrap;transition:background .15s,color .15s,border-color .15s}.video-toggle-btn:hover,.video-toggle-btn--active{color:var(--accent);border-color:var(--accent)}@media(max-width:768px){.player-controls{padding:.5rem .75rem;gap:.5rem}.playpause-btn,.skip-btn{padding:.5rem .65rem;font-size:1rem;min-width:40px;min-height:40px;display:flex;align-items:center;justify-content:center}.volume-slider{width:55px}.volume-value{display:none}.now-playing-thumb{width:40px;height:30px}.now-playing-title{font-size:.82rem}.player-progress-time{display:none}}.now-playing-info{display:flex;align-items:center;gap:.75rem;flex:1;overflow:hidden;min-width:0}.now-playing-empty{flex:1}.now-playing-thumb{width:54px;height:40px;object-fit:cover;border-radius:4px;flex-shrink:0;box-shadow:0 2px 8px #0000004d}.now-playing-meta{overflow:hidden;min-width:0}.now-playing-title{font-family:Playfair Display,Georgia,serif;font-size:.9rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text);line-height:1.3}.now-playing-by{font-family:IBM Plex Mono,monospace;font-size:.7rem;color:var(--text-muted);margin-top:.1rem}.now-playing-username{color:var(--accent)}.skip-btn{padding:.28rem .6rem;font-size:.72rem;font-family:IBM Plex Mono,monospace;background:transparent;color:var(--text-muted);border:1px solid var(--border);border-radius:4px;cursor:pointer;flex-shrink:0;white-space:nowrap;transition:background .15s,color .15s,border-color .15s}.skip-btn:hover{background:var(--surface-hover);color:var(--text);border-color:var(--accent)}.volume-control{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.volume-mute-btn{background:none;border:none;padding:.1rem .25rem;cursor:pointer;line-height:1;font-size:1rem;border-radius:4px;color:var(--text-muted);transition:background .15s}.volume-mute-btn:hover{background:var(--surface-hover)}.volume-icon{pointer-events:none}.volume-slider{-webkit-appearance:none;appearance:none;width:80px;height:3px;border-radius:2px;background:var(--border);outline:none;cursor:pointer;padding:0;border:none;box-shadow:none}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:13px;height:13px;border-radius:50%;background:var(--accent);cursor:pointer;transition:transform .1s}.volume-slider::-webkit-slider-thumb:hover{transform:scale(1.3)}.volume-slider::-moz-range-thumb{width:13px;height:13px;border-radius:50%;background:var(--accent);cursor:pointer;border:none}.volume-slider:focus{box-shadow:none;outline:none}.volume-value{font-family:IBM Plex Mono,monospace;font-size:.68rem;color:var(--text-muted);min-width:2ch;text-align:right}.player-reactions-bar{display:flex;justify-content:center;gap:.5rem;padding:.35rem .75rem;border-bottom:1px solid var(--border);flex-shrink:0}.reaction-btn{background:none;border:1px solid transparent;border-radius:8px;font-size:1.25rem;line-height:1;padding:.25rem .35rem;cursor:pointer;transition:transform .1s,border-color .15s,background .15s;-webkit-tap-highlight-color:transparent}.reaction-btn:hover{transform:scale(1.2);border-color:var(--border);background:var(--surface)}.reaction-btn:active{transform:scale(.9)}.reactions-overlay{position:absolute;inset:0;pointer-events:none;z-index:10;overflow:hidden}.floating-reaction{position:absolute;bottom:10%;font-size:2rem;line-height:1;pointer-events:none;will-change:transform,opacity}@media(max-width:768px){.reaction-btn{font-size:1.5rem;padding:.3rem .4rem}}.queue-panel{display:flex;flex-direction:column;padding:.6rem 1rem;gap:.6rem}.queue-header{display:flex;align-items:center;gap:.75rem}.queue-title{font-family:IBM Plex Mono,monospace;font-size:.67rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);font-weight:500}.queue-count{font-family:IBM Plex Mono,monospace;font-size:.7rem;color:var(--text-muted)}.queue-my-position{font-family:IBM Plex Mono,monospace;font-size:.7rem;color:var(--accent);background:var(--surface-own);padding:.15rem .55rem;border-radius:20px;border:1px solid var(--border)}.queue-list{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.25rem;align-items:flex-start}.queue-list::-webkit-scrollbar{height:3px}.queue-list::-webkit-scrollbar-track{background:transparent}.queue-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.queue-empty{font-family:Lora,serif;font-size:.82rem;font-style:italic;color:var(--text-muted);opacity:.7}.queue-item{display:flex;align-items:center;gap:.5rem;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:.45rem .65rem;flex-shrink:0;max-width:230px;position:relative;transition:background .15s,box-shadow .15s;box-shadow:0 1px 4px #00000014}.queue-item:hover{background:var(--surface-hover);box-shadow:0 3px 10px #0000001f}.queue-item-position{font-family:IBM Plex Mono,monospace;font-size:.65rem;font-weight:500;color:var(--accent-contrast);background:var(--accent);border-radius:4px;padding:.1rem .35rem;flex-shrink:0;line-height:1.4}.queue-item-thumb{width:38px;height:28px;object-fit:cover;border-radius:4px;flex-shrink:0;box-shadow:0 1px 4px #0003}.queue-item-meta{overflow:hidden;flex:1;min-width:0}.queue-item-title{font-family:Lora,serif;font-size:.75rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text);line-height:1.3}.queue-item-by{font-family:IBM Plex Mono,monospace;font-size:.62rem;color:var(--text-muted);margin-top:.1rem}.queue-item-remove{background:none;border:none;padding:.15rem .3rem;font-size:.68rem;cursor:pointer;color:var(--text-muted);flex-shrink:0;border-radius:3px;transition:background .15s,color .15s}.queue-item-remove:hover{background:#dc50501f;color:#e05050}.add-to-queue-form{display:flex;align-items:center;gap:.4rem;flex-shrink:0;flex-wrap:wrap}.add-to-queue-input{font-size:.82rem;width:260px}.add-to-queue-btn{font-size:.78rem;padding:.4rem .8rem;white-space:nowrap}.add-to-queue-error{width:100%;font-family:IBM Plex Mono,monospace;font-size:.72rem;color:#e05050;margin-top:.1rem}.add-to-queue{display:flex;flex-direction:column;gap:.5rem;flex-shrink:0}.add-to-queue-mode{display:flex;gap:.25rem}.add-to-queue-mode-btn{font-family:IBM Plex Mono,monospace;font-size:.7rem;padding:.25rem .5rem;background:transparent;border:1px solid var(--border);border-radius:4px;color:var(--text-muted);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.add-to-queue-mode-btn:hover{background:var(--surface-hover);color:var(--text)}.add-to-queue-mode-btn--active{background:var(--accent);color:var(--accent-contrast);border-color:var(--accent)}.add-to-queue-search{display:flex;flex-direction:column;gap:.35rem}.add-to-queue-search-input{width:100%;max-width:280px}.add-to-queue-search-status{font-family:IBM Plex Mono,monospace;font-size:.7rem;color:var(--text-muted);font-style:italic;margin:0}.add-to-queue-results{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.35rem;max-height:220px;overflow-y:auto}.add-to-queue-results::-webkit-scrollbar{width:4px}.add-to-queue-results::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.add-to-queue-result-item{display:flex;align-items:center;gap:.5rem;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:.35rem .5rem;transition:background .15s}.add-to-queue-result-item:hover{background:var(--surface-hover)}.add-to-queue-result-thumb{width:56px;height:32px;object-fit:cover;border-radius:4px;flex-shrink:0}.add-to-queue-result-title{flex:1;min-width:0;font-family:Lora,serif;font-size:.78rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}.add-to-queue-result-add{font-size:.72rem;padding:.2rem .5rem;flex-shrink:0;white-space:nowrap}@keyframes dot-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.7)}}.app:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23g)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:200px 200px}.join-splash{position:fixed;inset:0;background-color:var(--bg);display:flex;align-items:center;justify-content:center;z-index:1000}.join-splash-content{display:flex;flex-direction:column;align-items:center;gap:1.25rem;text-align:center}.join-vinyl{width:96px;height:96px;border-radius:50%;background:radial-gradient(circle at center,var(--surface) 28%,var(--border) 30%,var(--surface) 32%,var(--bg) 48%,var(--surface) 50%,var(--text) 52%,var(--surface) 54%);box-shadow:0 0 0 2px var(--border),0 8px 32px #0000002e;margin-bottom:.25rem}.join-logo{margin:0}.join-logo img{height:3rem;width:auto;display:block}.join-tagline{font-family:IBM Plex Mono,monospace;font-size:.82rem;color:var(--text-muted);font-style:italic;margin:0}.join-btn{margin-top:.5rem;padding:.75rem 2rem;font-family:Lora,serif;font-size:1rem;font-weight:600;background-color:var(--accent);color:var(--accent-contrast);border:none;border-radius:4px;cursor:pointer;letter-spacing:.02em;transition:box-shadow .15s ease}.join-btn:hover{box-shadow:0 4px 16px #e8a03059}.connecting{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:1rem;background-color:var(--bg)}.connecting-logo{display:block;height:2.75rem;width:auto}.connecting-text{font-family:IBM Plex Mono,monospace;font-size:.82rem;color:var(--text-muted);font-style:italic}.app-header{display:flex;align-items:center;justify-content:space-between;padding:.65rem 1.25rem;border-bottom:1px solid var(--border);flex-shrink:0}.app-logo{height:1.75rem;width:auto;display:block}.app-online-count{display:flex;align-items:center;gap:.45rem;font-family:IBM Plex Mono,monospace;font-size:.76rem;color:var(--text-muted)}.app-online-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);flex-shrink:0;animation:dot-pulse 2.8s ease-in-out infinite}.app{display:grid;grid-template-areas:"header header" "player chat" "queue  chat";grid-template-columns:1fr 320px;grid-template-rows:auto 1fr auto;height:100vh;overflow:hidden;background-color:var(--bg);color:var(--text);position:relative}.app-header{grid-area:header}.app-player{grid-area:player;overflow:hidden;border-right:1px solid var(--border)}.app-chat{grid-area:chat;overflow:hidden}.app-queue{grid-area:queue;border-top:1px solid var(--border)}.app-mobile-tabs{display:none}@media(max-width:768px){.app{display:flex;flex-direction:column;height:100dvh;overflow:hidden}.app-header{flex-shrink:0}.app-player{flex-shrink:0;border-right:none;border-bottom:1px solid var(--border)}.app-mobile-tabs{display:flex;flex-shrink:0;background:var(--surface);border-bottom:1px solid var(--border)}.app-tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.75rem 1rem;font-family:IBM Plex Mono,monospace;font-size:.8rem;background:none;border:none;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.app-tab-btn--active{color:var(--accent);border-bottom-color:var(--accent)}.app-tab-badge{background:var(--accent);color:var(--accent-contrast);font-size:.65rem;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;padding:0 4px}.app-chat,.app-queue{flex:1;overflow:hidden;min-height:0;border-top:none}.app-chat[data-mobile-active=false],.app-queue[data-mobile-active=false]{display:none}}
