:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#242424;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}*{box-sizing:border-box;margin:0;padding:0}body{flex-direction:column;min-height:100vh;display:flex}#root{flex-direction:column;flex:1;display:flex}a{color:#1db954;text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;border:1px solid #0000;border-radius:8px;padding:.6em 1.2em;font-family:inherit;font-size:1em;font-weight:500;transition:border-color .25s,background-color .25s}button:hover{border-color:#1db954}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}button.primary{color:#fff;background-color:#1db954;min-width:120px}button.primary:hover{background-color:#1ed760}button.danger{color:#fff;background-color:#e74c3c;min-width:100px}button.danger:hover{background-color:#c0392b}button.secondary{color:#fff;background-color:#0000;border:1px solid #666;min-width:100px}button.secondary:hover{background-color:#444;border-color:#1db954}.container{width:100%;max-width:800px;margin:0 auto;padding:2rem}.card{background-color:#333;border-radius:12px;margin-bottom:1rem;padding:1.5rem}.card h2{min-height:1.8rem;margin-bottom:1rem;font-size:1.2rem}.card-row{justify-content:space-between;align-items:center;padding:.5rem 0;display:flex}.status-badge{text-align:center;border-radius:20px;min-width:90px;padding:.25rem .75rem;font-size:.85rem;font-weight:500;display:inline-block}.status-badge.connected{color:#1db954;background-color:#1db95433}.status-badge.disconnected{color:#e74c3c;background-color:#e74c3c33}.input-group{gap:.5rem;margin-top:.5rem;display:flex}.input-group input{color:#fff;background-color:#2a2a2a;border:1px solid #555;border-radius:8px;flex:1;padding:.6rem;font-size:1rem}.input-group input:focus{border-color:#1db954;outline:none}.code-block{word-break:break-all;background-color:#1a1a1a;border-radius:8px;margin-top:.5rem;padding:1rem;font-family:monospace}.copy-button{color:#1db954;cursor:pointer;background:0 0;border:none;padding:.25rem .5rem;font-size:.85rem}.copy-button:hover{text-decoration:underline}.flex-center{flex:1;justify-content:center;align-items:center;display:flex}.login-container{text-align:center}.login-container h1{margin-bottom:.5rem;font-size:2.5rem}.login-container p{color:#888;margin-bottom:2rem}.spotify-logo{color:#1db954}.alert{border-radius:8px;margin-bottom:1rem;padding:1rem}.alert.success{color:#1db954;background-color:#1db95433;border:1px solid #1db954}.alert.error{color:#e74c3c;background-color:#e74c3c33;border:1px solid #e74c3c}.token-display{background-color:#1a1a1a;border:2px solid #1db954;border-radius:8px;margin-top:1rem;padding:1rem}.token-display p{color:#f39c12;margin-bottom:.5rem;font-size:.9rem}.token-display code{word-break:break-all;background-color:#000;border-radius:4px;padding:.75rem;font-family:monospace;display:block}.loading{justify-content:center;align-items:center;padding:2rem;display:flex}.spinner{border:4px solid #333;border-top-color:#1db954;border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}header{background-color:#1a1a1a;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex}header h1{align-items:center;gap:.5rem;font-size:1.2rem;display:flex}header nav{align-items:center;gap:1rem;display:flex}.lang-switcher{background-color:#333;border-radius:6px;display:flex;overflow:hidden}.lang-switcher button{color:#888;cursor:pointer;background-color:#0000;border:none;border-radius:0;padding:.4rem .8rem;font-size:.85rem;transition:all .2s}.lang-switcher button:hover{color:#fff;border-color:#0000}.lang-switcher button.active{color:#fff;background-color:#1db954}
