*{margin:0;padding:0;box-sizing:border-box}body{font-family:Times New Roman,Times,serif;background:#f8f8f6;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#1a1a1a;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.container{text-align:center;width:1000px;height:auto;padding:1rem;box-sizing:border-box;position:relative;overflow:visible}h1{font-family:Times New Roman,Times,serif;font-size:2rem;margin-bottom:.3rem;color:#000;text-shadow:none;font-weight:700;letter-spacing:-.02em;transform:scaleX(.7);transform-origin:center}.subtitle{font-size:1.2rem;margin-bottom:2rem;opacity:.9}.player-container{background:transparent;border:none;border-radius:0;padding:0;margin:1rem 0;position:relative;height:auto;display:block}.auth-container,.upload-container{background:#0000000d;-webkit-backdrop-filter:none;backdrop-filter:none;border-radius:10px;padding:2rem;margin:2rem 0;border:1px solid rgba(0,0,0,.1)}.track-info{margin-bottom:1.5rem}.radio-table{width:100%;height:auto;display:table;border-collapse:collapse;border:3px solid #000;background:#f8f8f6;margin-bottom:0}.radio-row{display:table-row}.radio-cell{display:table-cell;border:1px solid #000;vertical-align:middle;font-family:Times New Roman,Times,serif;height:100%;text-align:center;position:relative}.radio-cell.status{text-align:center;vertical-align:middle;display:flex;align-items:center;justify-content:center;height:50%}.controls-info-cell{width:70%;text-align:left;padding:1rem;background:#f8f8f6}.controls-info-cell.full-width{width:100%}.controls-section{display:flex;gap:1rem;align-items:center;margin-bottom:1rem}.track-info-section{width:100%}.track-labels{display:grid;grid-template-columns:140px 1fr 120px;gap:2rem;margin-bottom:.8rem}.label{font-size:.75rem;font-weight:700;color:#666;font-family:Times New Roman,Times,serif;letter-spacing:.5px;text-transform:uppercase}.label:first-child{text-align:left}.label:nth-child(2){text-align:center}.label:last-child{text-align:center}.track-content{display:grid;grid-template-columns:140px 1fr 120px;gap:2rem;align-items:baseline}.artist-name{font-size:1.1rem;font-weight:400;color:#000;font-family:Times New Roman,Times,serif}.song-title-container{overflow:hidden;position:relative;min-height:1.5rem;text-align:center;width:100%;display:flex;justify-content:center;align-items:center}.song-title{font-size:1.1rem;font-weight:700;color:#000;font-family:Times New Roman,Times,serif;white-space:nowrap;width:100%}.song-title.marquee{animation:marquee 15s linear infinite;display:inline-block;width:auto;white-space:nowrap;padding-left:100%;animation-fill-mode:forwards;will-change:transform}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-100%)}}.time-display{font-size:1rem;font-weight:400;color:#666;font-family:Times New Roman,Times,serif;text-align:center;white-space:nowrap}.spectrogram-cell{width:100%;padding:0!important;background:#f8f8f6;height:375px;position:relative;vertical-align:top}.spectrogram-container{position:relative!important;top:0!important;left:0!important;width:100%!important;height:375px!important;background:transparent!important;border:none!important;margin:0!important;padding:0!important;z-index:1!important}.visualizer-toggle-btn{position:absolute;top:10px;right:10px;z-index:10;background:#000000b3;border:2px solid #fff;color:#fff;padding:8px 12px;border-radius:4px;font-size:1rem;cursor:pointer;transition:all .2s ease;font-family:Times New Roman,Times,serif;min-width:40px;text-align:center}.visualizer-toggle-btn:hover{background:#000000e6;transform:translateY(-1px);border-color:#f8f8f6}.spectrogram-container canvas{position:relative!important;top:0!important;left:0!important;width:100%!important;height:375px!important;max-height:375px!important;display:block!important;background:transparent!important;object-fit:contain!important}.controls-row{text-align:center;padding:1rem}.control-button{background:transparent;color:#000;border:1px solid #000;padding:.4rem .8rem;font-size:.8rem;cursor:pointer;font-family:Times New Roman,Times,serif;border-radius:0}.control-button:hover:not(:disabled){background:#000;color:#f8f8f6}.control-button:disabled{opacity:.5;cursor:not-allowed}.next-up-cell{text-align:left;padding:.8rem;background:#f8f8f6}.next-up-title{font-weight:700;font-size:.8rem;margin-bottom:.6rem;color:#666;font-family:Times New Roman,Times,serif;letter-spacing:.5px;text-transform:uppercase}.next-up-track{font-size:1rem;color:#000;margin-bottom:0;font-family:Times New Roman,Times,serif;font-weight:500}.ad-cell{text-align:center;padding:.8rem;background:#00000008}.ad-space{font-size:.75rem;color:#666;font-style:italic;font-family:Times New Roman,Times,serif;border:1px dashed rgba(0,0,0,.3);padding:.8rem;letter-spacing:.3px}.status-cell{text-align:center;padding:.8rem;font-size:.85rem;color:#666;font-family:Times New Roman,Times,serif;background:#f8f8f6;display:flex;align-items:center;justify-content:center;min-height:60px}.control-btn{background:#f8f8f6;border:2px solid #000;color:#000;padding:0;font-size:1.2rem;cursor:pointer;font-family:Times New Roman,Times,serif;border-radius:0;transition:all .2s ease;width:50px;height:50px;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}.control-btn:hover:not(:disabled){background:#e8e8e6;transform:translateY(-1px)}.control-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.play-btn{font-size:1.3rem}.crossfade-btn,.skip-btn{font-size:1.2rem}.current-track{font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.next-track{font-size:1rem;opacity:.8}.controls{display:flex;gap:1rem;justify-content:center;align-items:center;margin:2rem 0;flex-wrap:wrap}button{background:#f8f8f6;border:2px solid #000;color:#000;padding:.6rem 1.2rem;border-radius:0;cursor:pointer;font-size:.9rem;font-family:Times New Roman,Times,serif;transition:all .15s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}button:hover:not(:disabled){background:#e8e8e6;transform:translateY(-1px)}button:active:not(:disabled){transform:scale(.98);background:#dcdcda}button:focus{outline:2px solid #666;outline-offset:2px}button:disabled{opacity:.4;cursor:not-allowed;transform:none}button.active,button.btn-primary{background:#000;color:#f8f8f6}button.active:hover:not(:disabled),button.btn-primary:hover:not(:disabled){background:#1a1a1a}.upload-buttons{display:flex;gap:1rem;margin-top:1rem;align-items:center;flex-wrap:wrap}.upload-button{background:#000;border:2px solid #000;color:#f8f8f6;flex:1;min-width:200px;padding:.8rem 1.5rem;font-weight:700}.upload-button:hover:not(:disabled){background:#1a1a1a;transform:translateY(-1px)}.cancel-button{background:#f8f8f6;border:2px solid #000;color:#000;padding:.8rem 1.5rem;font-size:.9rem}.cancel-button:hover:not(:disabled){background:#e8e8e6;transform:translateY(-1px)}.test-convert-button{background:#f8f8f6;border:2px solid #000;color:#000;padding:.8rem 1.5rem;font-size:.9rem}.test-convert-button:hover:not(:disabled){background:#e8e8e6;transform:translateY(-1px)}.test-convert-button:disabled{opacity:.4;cursor:not-allowed;transform:none}.header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.upload-nav{display:flex;justify-content:center;margin-bottom:1rem}.nav-link{background:transparent;border:1px solid #000;color:#000;padding:.5rem 1rem;text-decoration:none;font-family:Times New Roman,Times,serif;font-size:.9rem;transition:all .2s ease}.nav-link:hover{background:#000;color:#f8f8f6}.logout-button{background:#f8f8f6;border:2px solid #000;color:#000;padding:.5rem 1rem;font-size:.85rem;font-family:Times New Roman,Times,serif}.logout-button:hover:not(:disabled){background:#e8e8e6;transform:translateY(-1px)}.status{margin:0;font-size:.9rem;opacity:.8}.upload-link,.back-link{position:fixed;top:20px;right:20px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:.5rem 1rem;border-radius:15px;text-decoration:none;font-size:.9rem;transition:all .3s ease;z-index:1000}.back-link{right:auto;left:20px}.upload-link:hover,.back-link:hover{background:#fff3;transform:translateY(-1px)}.loading{display:flex;flex-direction:column;align-items:center;gap:1rem}.spinner{border:3px solid rgba(255,255,255,.3);border-top:3px solid white;border-radius:50%;width:30px;height:30px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error{color:#ff6b6b;margin-top:1rem;padding:1rem;background:#ff6b6b1a;border-radius:10px;border:1px solid rgba(255,107,107,.3)}.success{color:#4caf50;margin-top:1rem;padding:1rem;background:#4caf501a;border-radius:10px;border:1px solid rgba(76,175,80,.3)}.form-group{margin-bottom:1.5rem;text-align:left}label{display:block;margin-bottom:.5rem;font-weight:700}input[type=password],input[type=text],input[type=file]{width:100%;padding:.8rem;border:2px solid rgba(255,255,255,.3);border-radius:10px;background:#ffffff1a;color:#fff;font-size:1rem}input[type=file]{padding:.5rem;cursor:pointer}input::placeholder{color:#ffffffb3}.file-list{margin-top:1rem;text-align:left}.file-item{background:#ffffff1a;padding:1rem;margin:.5rem 0;border-radius:10px;border:1px solid rgba(255,255,255,.2);transition:all .3s ease}.file-item--pending{border-color:#ffffff4d}.file-item--converting{border-color:#ff9800;background:#ff98001a}.file-item--uploading{border-color:#2196f3;background:#2196f31a}.file-item--completed{border-color:#4caf50;background:#4caf501a}.file-item--error{border-color:#f44336;background:#f443361a}.file-name{font-weight:700;margin-bottom:.5rem}.file-title{width:100%;padding:.5rem;border:1px solid rgba(255,255,255,.3);border-radius:5px;background:#ffffff1a;color:#fff;margin-top:.5rem}.conversion-badge{display:inline-block;background:linear-gradient(45deg,#ff9800,#f57c00);color:#fff;padding:.2rem .5rem;border-radius:12px;font-size:.75rem;margin-left:.5rem;font-weight:700}.conversion-progress{margin:.5rem 0}.conversion-status{font-size:.8rem;color:#ff9800;margin-top:.25rem}.file-info{display:flex;gap:1rem;margin-top:.5rem;font-size:.8rem;opacity:.8}.file-info span{background:#ffffff1a;padding:.2rem .5rem;border-radius:8px}.file-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.status-badge{display:inline-block;padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:700;margin-left:.5rem}.status-badge--pending{background:#fff3;color:#fffc}.status-badge--converting{background:#ff9800;color:#fff}.status-badge--uploading{background:#2196f3;color:#fff}.status-badge--completed{background:#4caf50;color:#fff}.status-badge--error{background:#f44336;color:#fff}.file-error{background:#f4433633;border:1px solid #f44336;color:#ffcdd2;padding:.5rem;border-radius:5px;margin:.5rem 0;font-size:.9rem}.file-title:disabled{opacity:.6;cursor:not-allowed}.tracks-section{margin:2rem 0}.tracks-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.tracks-section h2{font-size:1.5rem;margin:0;color:#fff}.title-buttons{display:flex;gap:.5rem;align-items:center}.regenerate-titles-button,.ensure-unique-button{background:#f8f8f6;color:#000;padding:.5rem 1rem;font-size:.85rem;font-family:Times New Roman,Times,serif;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;gap:.5rem;border:2px solid #000}.regenerate-titles-button:hover:not(:disabled),.ensure-unique-button:hover:not(:disabled){background:#e8e8e6;transform:translateY(-1px)}.regenerate-titles-button:disabled,.ensure-unique-button:disabled{opacity:.4;cursor:not-allowed;transform:none}.tracks-table{background:#ffffff1a;border-radius:10px;overflow:hidden;border:1px solid rgba(255,255,255,.2)}.tracks-header{display:grid;grid-template-columns:2fr 1fr 1fr 120px;gap:1rem;padding:1rem;background:#fff3;font-weight:700;border-bottom:1px solid rgba(255,255,255,.2)}.track-row{display:grid;grid-template-columns:2fr 1fr 1fr 120px;gap:1rem;padding:1rem;border-bottom:1px solid rgba(255,255,255,.1);transition:background-color .2s ease}.track-row:hover{background:#ffffff0d}.track-row:last-child{border-bottom:none}.track-title{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.track-artist{opacity:.8}.track-date{opacity:.7;font-size:.9rem}.track-actions{display:flex;justify-content:flex-end}.delete-button{background:#f8f8f6;border:2px solid #000;color:#000;padding:.5rem 1rem;font-size:.8rem;font-family:Times New Roman,Times,serif;cursor:pointer;transition:all .15s ease}.delete-button:hover:not(:disabled){background:#000;color:#f8f8f6;transform:translateY(-1px)}.delete-button:disabled{opacity:.4;cursor:not-allowed;transform:none}.no-tracks{text-align:center;padding:2rem;opacity:.7;font-style:italic}@media (max-width: 768px){.tracks-section{margin:1rem 0}.tracks-section h2{font-size:1.2rem}.tracks-table{border-radius:8px}.tracks-header{display:none}.track-row{display:flex;flex-direction:column;gap:.4rem;padding:.8rem;align-items:flex-start}.track-title{font-size:.95rem;width:100%;white-space:normal;line-height:1.3}.track-artist{font-size:.8rem;opacity:.7}.track-date{font-size:.75rem;opacity:.6}.track-actions{width:100%;justify-content:flex-start;margin-top:.3rem}.delete-button{padding:.6rem 1rem;font-size:.85rem}}@media (max-width: 480px){.tracks-section h2{font-size:1.1rem}.track-row{padding:.6rem}.track-title{font-size:.9rem}.track-artist,.track-date{display:none}}.progress-container{margin-top:1rem}.progress-bar{width:100%;height:20px;background:#fff3;border-radius:10px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:linear-gradient(45deg,#4caf50,#45a049);width:0%;transition:width .3s ease}@media (max-width: 1024px){.container{width:100%;max-width:100vw;padding:.75rem}}@media (max-width: 768px){body{padding:0;justify-content:flex-start;padding-top:.5rem}.container{width:100%;max-width:100vw;min-height:auto;height:auto;padding:.5rem;box-sizing:border-box;overflow-x:hidden}h1{font-size:1.6rem;margin-bottom:.3rem;transform:scaleX(.8)}.subtitle{font-size:1rem;margin-bottom:1rem}.upload-link,.back-link{position:fixed;top:10px;padding:.5rem .8rem;font-size:.75rem;background:#000c;color:#f8f8f6;border:1px solid #000;z-index:1000}.upload-link{right:10px}.back-link{left:10px;right:auto}.radio-table{border:2px solid #000;display:flex;flex-direction:column}.radio-row{display:block;width:100%}.radio-cell{display:block;width:100%;border:none;border-bottom:1px solid #000}.radio-cell:last-child{border-bottom:none}.controls-info-cell{padding:1rem;display:flex;flex-direction:column;align-items:center;width:100%!important}.controls-section{justify-content:center;margin-bottom:1rem;gap:1rem;width:100%}.control-btn{width:56px;height:56px;font-size:1.3rem;border-width:2px}.control-btn:active{transform:scale(.95);background:#e0e0de}.play-btn{font-size:1.5rem;width:64px;height:64px}.track-info-section{text-align:center;width:100%}.track-labels{display:none}.track-content{display:flex;flex-direction:column;gap:.5rem;text-align:center;align-items:center}.artist-name{font-size:.9rem;color:#666;order:2}.song-title-container{order:1;width:100%;max-width:100%}.song-title{font-size:1.1rem;font-weight:700}.time-display{font-size:.85rem;order:3;margin-top:.3rem;font-family:Courier New,monospace;letter-spacing:.05em}.spectrogram-cell{height:280px;padding:0!important}.spectrogram-container{height:280px!important;min-height:280px!important}.spectrogram-container canvas{height:280px!important;max-height:280px!important}.visualizer-toggle-btn{top:8px;right:8px;padding:10px 14px;font-size:1.1rem;min-width:44px;min-height:44px}.next-up-cell{padding:.8rem 1rem;text-align:center}.next-up-title{font-size:.7rem;margin-bottom:.4rem}.next-up-track{font-size:.85rem;line-height:1.3}.ad-cell{padding:.6rem}.ad-space{font-size:.65rem;padding:.5rem;letter-spacing:0}.status-cell{padding:.6rem;min-height:40px}.status{font-size:.8rem}.voting-section{justify-content:center;margin-top:.8rem}.vote-btn{min-width:50px;padding:.5rem .6rem}.vote-icon{font-size:1rem}.vote-count{font-size:.8rem}.auth-container,.upload-container{padding:1.5rem;margin:1rem 0;border-radius:8px}.form-group{margin-bottom:1.2rem}label{font-size:.9rem}input[type=password],input[type=text],input[type=file]{padding:.7rem;font-size:16px}.upload-buttons{flex-direction:column;gap:.8rem}.upload-button,.cancel-button,.test-convert-button{width:100%;min-width:auto;padding:.9rem 1.5rem}.header-row{flex-direction:column;gap:.5rem;align-items:center;margin-top:2.5rem}.upload-nav{margin-bottom:.8rem}.nav-link{font-size:.8rem;padding:.4rem .8rem}.tracks-header-row{flex-direction:column;gap:.8rem;align-items:stretch}.title-buttons{flex-direction:column;gap:.5rem}.regenerate-titles-button,.ensure-unique-button{width:100%;justify-content:center}.logout-button{font-size:.8rem;padding:.4rem .8rem}.file-list{margin-top:.8rem}.file-item{padding:.8rem}.file-header{flex-direction:column;align-items:flex-start;gap:.5rem}.file-info{flex-wrap:wrap;gap:.5rem}.progress-bar{height:24px}}@media (max-width: 480px){body{padding-top:.25rem}.container{padding:.25rem}h1{font-size:1.4rem;transform:scaleX(.75)}.control-btn{width:52px;height:52px;font-size:1.2rem}.play-btn{width:60px;height:60px;font-size:1.4rem}.controls-section{gap:.8rem}.controls-info-cell{padding:.75rem}.spectrogram-cell{height:220px}.spectrogram-container{height:220px!important;min-height:220px!important}.spectrogram-container canvas{height:220px!important;max-height:220px!important}.visualizer-toggle-btn{top:5px;right:5px;padding:8px 10px;font-size:1rem;min-width:40px;min-height:40px}.song-title{font-size:1rem}.artist-name{font-size:.85rem}.time-display{font-size:.75rem}.next-up-cell{padding:.6rem .8rem}.next-up-title{font-size:.65rem}.next-up-track{font-size:.8rem}.ad-space{font-size:.6rem;padding:.4rem}.status{font-size:.75rem}.auth-container,.upload-container{padding:1rem;margin:.5rem 0}.upload-link,.back-link{padding:.4rem .6rem;font-size:.7rem}}@media (max-width: 900px) and (orientation: landscape){body{padding-top:0}.container{padding:.5rem}h1{font-size:1.3rem;margin-bottom:.2rem}.controls-info-cell{flex-direction:row;justify-content:space-between;align-items:center;padding:.6rem 1rem}.controls-section{margin-bottom:0;gap:.6rem}.control-btn{width:44px;height:44px;font-size:1rem}.play-btn{width:50px;height:50px;font-size:1.2rem}.track-info-section{flex:1;margin-left:1rem}.track-content{flex-direction:row;justify-content:space-between;align-items:center}.artist-name{order:1;font-size:.85rem;min-width:100px;text-align:left}.song-title-container{order:2;flex:1;margin:0 1rem}.song-title{font-size:.95rem}.time-display{order:3;font-size:.8rem;min-width:80px;text-align:right;margin-top:0}.spectrogram-cell{height:180px}.spectrogram-container{height:180px!important;min-height:180px!important}.spectrogram-container canvas{height:180px!important;max-height:180px!important}.waveform-cell,.waveform-widget,.waveform-canvas{height:35px!important}.next-up-cell,.ad-cell,.status-cell{padding:.4rem .8rem}.chatroom{display:none}}.chatroom{margin-top:1rem;border:2px solid #000;background:#f8f8f6;width:100%;height:350px;box-sizing:border-box}.chatroom-header{display:flex;justify-content:space-between;align-items:center;padding:.6rem .8rem;border-bottom:1px solid #000;background:#00000008;height:50px;box-sizing:border-box}.chatroom-header-desktop{display:flex}.chatroom-header h3{font-family:Times New Roman,Times,serif;font-size:1rem;font-weight:700;color:#000;margin:0;letter-spacing:.5px}.chatroom-tabs-mobile{display:none;justify-content:space-between;align-items:center;padding:0;border-bottom:1px solid #000;background:#00000008;height:44px;box-sizing:border-box}.chatroom-tab{flex:1;background:transparent;border:none;border-right:1px solid #000;padding:.6rem .5rem;font-family:Times New Roman,Times,serif;font-size:.85rem;font-weight:700;color:#666;cursor:pointer;transition:all .2s ease;height:100%;text-transform:uppercase;letter-spacing:.3px}.chatroom-tab:last-of-type{border-right:none}.chatroom-tab.active{background:#000;color:#f8f8f6}.chatroom-tab:active{transform:scale(.98)}.chatroom-tabs-mobile .connection-status{padding:0 .8rem;border-left:1px solid #000;height:100%;display:flex;align-items:center;gap:.4rem;font-size:.7rem;min-width:60px;justify-content:center}.connection-status{display:flex;align-items:center;gap:.5rem;font-family:Times New Roman,Times,serif;font-size:.8rem;font-weight:700;color:#666}.status-indicator{width:8px;height:8px;border-radius:50%;display:inline-block}.status-indicator.connected{background:#4caf50;animation:pulse 2s infinite}.status-indicator.disconnected{background:#f44336}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.users-table{width:100%;height:100%;overflow-y:auto;padding:0;font-family:Times New Roman,Times,serif}.no-users{padding:2rem;text-align:center;color:#666;font-style:italic;font-family:Courier New,Monaco,monospace}.listener-user-row{display:grid;grid-template-columns:1fr 1fr 60px;gap:.5rem;padding:.4rem .6rem;border-bottom:1px solid #000;transition:background-color .2s ease;align-items:center}@media (max-width: 768px){.listener-user-row{grid-template-columns:1fr 50px;gap:.3rem;padding:.3rem .5rem}.listener-track-info{display:none}.listener-username{font-size:.8rem;transform:none}.listener-remaining-time{font-size:.65rem;transform:none}}.listener-user-row:hover{background:#00000005}.listener-user-row:last-child{border-bottom:1px solid #000}.listener-username{font-family:Times New Roman,Times,serif;font-weight:400;font-size:.85rem;color:#000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transform:scaleX(.85);transform-origin:left;text-align:left}.you-indicator{color:#666;font-weight:400;font-size:.75rem}.listener-track-info{font-family:Times New Roman,Times,serif;font-size:.75rem;color:#666;overflow:hidden;position:relative;height:1rem;transform:scaleX(.85);transform-origin:left;text-align:left}.listener-current-track{white-space:nowrap;width:100%}.listener-current-track.marquee{animation:listenerTrackMarquee 18s linear infinite;display:inline-block;width:auto;padding-left:100%;animation-fill-mode:forwards;will-change:transform}.listener-not-listening{font-style:italic;opacity:.7}.listener-remaining-time{font-family:Times New Roman,Times,serif;font-size:.7rem;color:#999;transform:scaleX(.85);transform-origin:left;text-align:right;white-space:nowrap}@keyframes listenerTrackMarquee{0%{transform:translate(0)}to{transform:translate(-100%)}}@keyframes userTrackMarquee{0%{transform:translate(0)}to{transform:translate(-100%)}}.chatroom-content{display:grid;grid-template-columns:1fr 2fr;gap:0;height:calc(100% - 50px);margin:0;padding:0}.users-section{border-right:1px solid #000;padding:0;margin:0}.chat-section{display:flex;flex-direction:column;padding:0;margin:0}.chat-messages{flex:1 1 0;width:100%;min-height:0;min-width:0;overflow-y:auto;overflow-x:hidden;padding:0;background:#f8f8f6;border:none;margin:0;font-family:Times New Roman,Times,serif;box-sizing:border-box;display:flex;scroll-behavior:smooth;flex-direction:column;justify-content:flex-end}.chat-message-row{display:grid;grid-template-columns:60px 120px 150px 1fr;border-bottom:1px solid #000;border-collapse:collapse}.chat-timestamp-cell{padding:.4rem .6rem;border-right:1px solid #000;font-size:.8rem;color:#666;background:#f8f8f6;font-family:Times New Roman,Times,serif}.chat-username-cell{padding:.4rem .6rem;font-size:.85rem;color:#000;background:#f8f8f6;font-family:Times New Roman,Times,serif;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-track-cell{padding:.4rem .6rem;font-size:.75rem;color:#666;background:#f8f8f6;font-family:Times New Roman,Times,serif;overflow:hidden;position:relative}.chat-user-track{white-space:nowrap;width:100%}.chat-user-track.marquee{animation:chatTrackMarquee 16s linear infinite;display:inline-block;width:auto;padding-left:100%;animation-fill-mode:forwards;will-change:transform}.chat-no-track{font-style:italic;opacity:.5}.chat-message-cell{padding:.4rem .6rem;font-size:.85rem;color:#000;background:#f8f8f6;font-family:Times New Roman,Times,serif;font-weight:400;word-wrap:break-word;line-height:1.3;text-align:left;vertical-align:top}@keyframes chatTrackMarquee{0%{transform:translate(0)}to{transform:translate(-100%)}}.chat-input-container{display:flex;gap:.5rem;align-items:center}.chat-input-container{display:flex;width:100%;height:45px;border-top:1px solid #000;box-sizing:border-box}.chat-input-wrapper{position:relative;flex:1}.chat-input{width:100%;padding:.4rem .6rem;border:none;background:#f8f8f6;font-family:Times New Roman,Times,serif;font-size:.85rem;color:#000;border-radius:0;transform:scaleX(.85);transform-origin:left;font-weight:400}.chat-input:focus{outline:none;background:#f8f8f6;color:#000;box-shadow:none;border:none}.chat-input:disabled{opacity:.6;cursor:not-allowed;background:#f8f8f6}.chat-input::placeholder{color:#999;font-style:italic}.chat-send-btn{background:#f8f8f6;border:1px solid #000;border-left:1px solid #000;border-right:none;color:#000;padding:.4rem 1.4rem;font-family:Times New Roman,Times,serif;font-size:.85rem;font-weight:400;cursor:pointer;border-radius:0;transition:background .2s ease,background-color .2s ease,color .2s ease;white-space:nowrap;transform:scaleX(.85);transform-origin:left;margin-right:2px;height:100%;text-align:center;display:flex;align-items:center;justify-content:center;box-shadow:none}.chat-send-btn:hover:not(:disabled),.chat-send-btn:active:not(:disabled),.chat-send-btn:focus:not(:disabled){background:#e8e8e6;color:#000;box-shadow:none}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed;background:#f8f8f6;color:#000;box-shadow:none}.toxicity-warning{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#000;color:#f8f8f6;padding:.8rem 1rem;border:2px solid #000;font-family:Times New Roman,Times,serif;font-size:.8rem;white-space:nowrap;z-index:1000;margin-bottom:.5rem;box-shadow:0 4px 8px #0003;animation:tooltipFadeIn .3s ease-out}.toxicity-warning:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:8px solid transparent;border-top-color:#000}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media (max-width: 768px){.chatroom{margin-top:.8rem;height:320px;min-height:280px;max-height:380px;display:flex;flex-direction:column}.chatroom-header-desktop{display:none}.chatroom-tabs-mobile{display:flex;flex-shrink:0}.chatroom-content{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.users-section{display:none;flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;border-right:none}.users-section.mobile-visible{display:block}.chat-section{display:none;flex:1;min-height:0;flex-direction:column;overflow:hidden}.chat-section.mobile-visible{display:flex}.users-section.mobile-visible .users-table{padding:0;height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch}.users-section.mobile-visible .listener-user-row{grid-template-columns:1fr 1fr 50px;padding:.6rem .8rem}.users-section.mobile-visible .listener-username{font-size:.9rem;transform:none}.users-section.mobile-visible .listener-track-info{display:block!important;font-size:.8rem;transform:none;height:auto;overflow:hidden}.users-section.mobile-visible .listener-current-track{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.users-section.mobile-visible .listener-current-track.marquee{animation:listenerTrackMarquee 12s linear infinite;text-overflow:clip;overflow:visible}.users-section.mobile-visible .listener-remaining-time{font-size:.75rem;transform:none}.chat-messages{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.chat-message-row{grid-template-columns:50px 90px 1fr}.chat-track-cell{display:none}.chat-timestamp-cell{padding:.3rem .4rem;font-size:.7rem}.chat-username-cell{padding:.3rem .4rem;font-size:.75rem;border-right:1px solid #000}.chat-message-cell{padding:.3rem .5rem;font-size:.8rem}.chat-input-container{height:50px;border-top:2px solid #000;flex-shrink:0}.chat-input{padding:.5rem .8rem;font-size:16px;transform:none}.chat-send-btn{padding:.5rem 1rem;font-size:.85rem;transform:none;min-width:60px}.toxicity-warning{font-size:.75rem;padding:.6rem .8rem;max-width:280px;white-space:normal}}@media (max-width: 480px){.chatroom{height:280px;min-height:250px;max-height:320px}.chatroom-tabs-mobile{height:40px}.chatroom-tab{font-size:.75rem;padding:.5rem .3rem}.chatroom-tabs-mobile .connection-status{font-size:.65rem;padding:0 .5rem;min-width:50px}.chat-message-row{grid-template-columns:45px 80px 1fr}.chat-timestamp-cell{font-size:.65rem;padding:.25rem .35rem}.chat-username-cell{font-size:.7rem;padding:.25rem .35rem}.chat-message-cell{font-size:.75rem;padding:.25rem .4rem}.chat-input-container{height:46px;flex-shrink:0}.chat-input{padding:.4rem .6rem}.chat-send-btn{padding:.4rem .8rem;min-width:50px}.users-section.mobile-visible .listener-user-row{display:flex;flex-direction:column;gap:.2rem;padding:.5rem .6rem;border-bottom:1px solid #000}.users-section.mobile-visible .listener-username{font-size:.85rem;order:1}.users-section.mobile-visible .listener-track-info{display:block!important;font-size:.75rem;order:2;opacity:.7}.users-section.mobile-visible .listener-remaining-time{display:none}}.waveform-cell{display:table-cell;background:transparent;border:1px solid #000;border-top:none;padding:0;margin:0;height:40px;vertical-align:middle;width:100%;box-sizing:border-box}.waveform-widget{width:100%;height:40px;position:relative;box-sizing:border-box;overflow:hidden}.waveform-canvas{display:block;width:100%!important;height:40px!important;background:transparent;overflow:hidden;position:relative;box-sizing:border-box}.waveform-canvas>div{height:40px!important;max-height:40px!important;overflow:hidden!important}.waveform-canvas canvas{max-height:40px!important;height:40px!important}@media (max-width: 768px){.waveform-cell{display:block!important;width:100%!important;height:50px;border:none;border-top:1px solid #000;border-bottom:1px solid #000}.waveform-widget{width:100%!important;height:50px}.waveform-canvas{width:100%!important;height:50px!important}}@media (max-width: 480px){.waveform-cell,.waveform-widget{height:40px}.waveform-canvas{height:40px!important}}.voting-section{margin-top:.5rem;display:flex;justify-content:flex-end;align-items:center}.track-voting{display:flex;gap:.75rem;align-items:center;margin-top:.5rem}.vote-btn{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:.4rem;background:transparent;border:2px solid #333;border-radius:4px;padding:.5rem .75rem;cursor:pointer;font-family:Times New Roman,Times,serif;font-size:.85rem;min-width:60px;min-height:36px;transition:all .15s ease;color:#333}.vote-btn:hover:not(:disabled){background:#00000014;border-color:#000}.vote-btn:active:not(:disabled){transform:scale(.97)}.vote-btn:focus{outline:2px solid #666;outline-offset:2px}.upvote-btn.active{background:#2e7d32;border-color:#2e7d32;color:#fff}.downvote-btn.active{background:#c62828;border-color:#c62828;color:#fff}.vote-btn.voting{opacity:.6;cursor:wait}.vote-btn:disabled{cursor:not-allowed;opacity:.5}.vote-icon{font-size:.9rem;line-height:1}.vote-count{font-size:.85rem;font-weight:700;transition:all .3s ease;min-width:1.2em;text-align:center}.vote-count.animate{animation:voteCountPulse .6s ease-out}@keyframes voteCountPulse{0%{transform:scale(1)}50%{transform:scale(1.3);color:#ff6b35}to{transform:scale(1)}}.upvote-btn.active .vote-count.animate{animation:voteCountPulseGreen .6s ease-out}.downvote-btn.active .vote-count.animate{animation:voteCountPulseRed .6s ease-out}@keyframes voteCountPulseGreen{0%{transform:scale(1)}50%{transform:scale(1.3);color:#4caf50}to{transform:scale(1)}}@keyframes voteCountPulseRed{0%{transform:scale(1)}50%{transform:scale(1.3);color:#f44336}to{transform:scale(1)}}@supports (padding: max(0px)){body{padding-left:max(.5rem,env(safe-area-inset-left));padding-right:max(.5rem,env(safe-area-inset-right));padding-bottom:max(.5rem,env(safe-area-inset-bottom))}@media (max-width: 768px){.container{padding-left:max(.5rem,env(safe-area-inset-left));padding-right:max(.5rem,env(safe-area-inset-right))}.chat-input-container{padding-bottom:max(0px,env(safe-area-inset-bottom))}}}.chat-messages,.users-table,.file-list,.tracks-table{-webkit-overflow-scrolling:touch;scroll-behavior:smooth}body{overscroll-behavior-y:contain}button,.control-btn,.vote-btn,.chat-send-btn{-webkit-tap-highlight-color:rgba(0,0,0,.1)}.control-btn,.vote-btn,.chat-send-btn,.visualizer-toggle-btn{-webkit-user-select:none;user-select:none}@media (max-width: 768px){.loading{padding:2rem}.spinner{width:40px;height:40px;border-width:4px}.error,.success{padding:1rem;font-size:.9rem;margin:1rem}}@media (max-width: 768px){.video-upload-container{padding:1rem}.video-preview{max-height:200px}.video-info{flex-direction:column;gap:.5rem}}@media (max-width: 768px){.video-overlay-label{font-size:10px!important;padding:5px 8px!important;bottom:6px!important;left:6px!important}}@media (max-width: 480px){.video-overlay-label{font-size:9px!important;padding:4px 6px!important;letter-spacing:.2px!important}}@media (max-width: 768px){.voting-section{justify-content:center;width:100%;margin-top:1rem;padding-top:.5rem;border-top:1px solid rgba(0,0,0,.1)}.track-voting{gap:1rem;justify-content:center;width:100%}.vote-btn{min-width:70px;min-height:44px;padding:.6rem 1rem;font-size:.9rem;gap:.5rem}.vote-icon{font-size:1.1rem}.vote-count{font-size:.9rem;min-width:1.5em}}@media (max-width: 480px){.vote-btn{min-width:65px;min-height:42px;padding:.5rem .8rem}.vote-icon{font-size:1rem}.vote-count{font-size:.85rem}}@media print{.control-btn,.vote-btn,.chat-send-btn,.upload-link,.back-link,.visualizer-toggle-btn,.chatroom,.spectrogram-container{display:none!important}}
