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