body{margin:0;padding:0;font-family:Helvetica Neue,Helvetica,Arial,sans-serif}#root{width:100vw;height:100vh;overflow:hidden}*{margin:0;padding:0;box-sizing:border-box}:root{--tv-green: #1DB954;--tv-black: #000000;--tv-dark-grey: #0a0a0a;--tv-grey: #1a1a1a;--tv-light-grey: #b3b3b3;--tv-white: #FFFFFF}body{font-family:Helvetica Neue,Helvetica,Arial,sans-serif;background-color:var(--tv-black);color:var(--tv-white);overflow:hidden}.tv-container{width:100vw;height:100vh;display:flex;flex-direction:column;background:var(--tv-black)}.tv-header{display:flex;justify-content:space-between;align-items:center;padding:30px 40px;background:var(--tv-dark-grey);border-bottom:2px solid var(--tv-grey)}.tv-logo{font-size:36px;font-weight:900;color:var(--tv-green);letter-spacing:-1px}.tv-session-info{display:flex;align-items:center;gap:30px}.tv-qr-code{width:120px;height:120px;padding:8px;background:#fff;border-radius:8px}.tv-url{text-align:center}.tv-url-label{font-size:16px;color:var(--tv-light-grey);margin-bottom:8px}.tv-url-text{font-size:32px;font-weight:700;color:var(--tv-green);letter-spacing:1px}.tv-main{flex:1;display:flex;overflow:hidden}.tv-now-playing{width:40%;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:40px;background:linear-gradient(135deg,var(--tv-black) 0%,var(--tv-dark-grey) 100%);border-right:2px solid var(--tv-grey)}.tv-album-art{width:400px;height:400px;border-radius:8px;box-shadow:0 20px 60px #000c;margin-bottom:40px;object-fit:cover}.tv-track-info{text-align:center;width:100%;max-width:500px}.tv-track-title{font-size:42px;font-weight:700;margin-bottom:12px;line-height:1.2}.tv-track-artist{font-size:28px;color:var(--tv-light-grey);margin-bottom:30px}.tv-progress-bar{width:100%;height:6px;background:var(--tv-grey);border-radius:3px;overflow:hidden;margin-bottom:12px}.tv-progress-fill{height:100%;background:var(--tv-green);transition:width .3s linear}.tv-time{display:flex;justify-content:space-between;font-size:16px;color:var(--tv-light-grey)}.tv-queue{width:60%;display:flex;flex-direction:column;background:var(--tv-black)}.tv-queue-header{padding:30px 40px;border-bottom:2px solid var(--tv-grey)}.tv-queue-title{font-size:32px;font-weight:700;color:var(--tv-white)}.tv-queue-count{font-size:18px;color:var(--tv-light-grey);margin-top:8px}.tv-queue-list{flex:1;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.tv-queue-list::-webkit-scrollbar{display:none}.tv-queue-item{display:flex;align-items:center;padding:20px 40px;gap:24px;border-bottom:1px solid var(--tv-grey);transition:background .3s}.tv-queue-item:hover{background:var(--tv-dark-grey)}.tv-queue-position{font-size:28px;font-weight:700;color:var(--tv-light-grey);min-width:50px;text-align:center}.tv-queue-artwork{width:80px;height:80px;border-radius:4px;object-fit:cover;flex-shrink:0}.tv-queue-info{flex:1;min-width:0}.tv-queue-song-title{font-size:24px;font-weight:600;margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tv-queue-song-artist{font-size:18px;color:var(--tv-light-grey);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tv-queue-votes{display:flex;flex-direction:column;align-items:center;gap:8px;min-width:100px}.tv-vote-count{font-size:36px;font-weight:700;color:var(--tv-green)}.tv-vote-breakdown{font-size:16px;color:var(--tv-light-grey)}.tv-song-duration{font-size:18px;color:var(--tv-light-grey);min-width:70px;text-align:right}.tv-loading{width:100vw;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--tv-black)}.tv-spinner{border:4px solid rgba(255,255,255,.1);border-top:4px solid var(--tv-green);border-radius:50%;width:60px;height:60px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tv-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--tv-light-grey)}.tv-empty-icon{font-size:120px;margin-bottom:30px}.tv-empty-text{font-size:32px;text-align:center}@keyframes scroll-queue{0%{transform:translateY(0)}to{transform:translateY(-50%)}}.tv-queue-list.auto-scroll{animation:scroll-queue 30s linear infinite}
