.controls-container{display:flex;justify-content:center;align-items:center;gap:1rem;margin:2rem 0;flex-wrap:wrap}.controls-container button{background:#fff;border:1px solid #dee2e6;color:#495057;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .2s ease;min-width:50px;display:flex;align-items:center;justify-content:center;gap:.5rem}.controls-container button:hover:not(:disabled){background:#f8f9fa;border-color:#adb5bd;transform:translateY(-1px)}.controls-container button:active:not(:disabled){transform:translateY(0)}.controls-container button:disabled{opacity:.5;cursor:not-allowed;transform:none}.controls-container button.play-pause{background:#007bff;border-color:#007bff;color:#fff;padding:1rem 2rem;font-size:1.2rem;min-width:80px}.controls-container button.play-pause:hover:not(:disabled){background:#0056b3;border-color:#0056b3;transform:scale(1.05)}.controls-container button.shuffle,.controls-container button.repeat{background:#f8f9fa;font-size:.9rem;padding:.6rem 1.2rem}.controls-container button.shuffle.active,.controls-container button.repeat.active{background:#e9ecef;border-color:#adb5bd}.controls-container button.prev,.controls-container button.next{background:#fff;font-size:1.1rem;padding:.8rem 1rem}.progress-container{margin:2rem 0;padding:0 1rem}.progress-bar{width:100%;height:6px;background:#e9ecef;border-radius:3px;outline:none;cursor:pointer;transition:all .2s ease;appearance:none}.progress-bar::-webkit-slider-thumb{appearance:none;width:18px;height:18px;border-radius:50%;background:#007bff;cursor:pointer;border:2px solid #fff;box-shadow:0 2px 4px #0003;transition:all .2s ease}.progress-bar::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 4px 8px #0000004d}.progress-bar::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#007bff;cursor:pointer;border:2px solid #fff;box-shadow:0 2px 4px #0003;transition:all .2s ease}.progress-bar::-moz-range-thumb:hover{transform:scale(1.1);box-shadow:0 4px 8px #0000004d}.progress-bar::-webkit-slider-track{background:#e9ecef;border-radius:3px;height:6px}.progress-bar::-moz-range-track{background:#e9ecef;border-radius:3px;height:6px;border:none}.time-info{display:flex;justify-content:space-between;font-size:.9rem;color:#6c757d;margin-top:.5rem;font-weight:500}.time-info span{background:#f8f9fa;padding:.25rem .75rem;border-radius:4px;border:1px solid #e9ecef}.volume-container{display:flex;align-items:center;justify-content:center;gap:1rem;margin:1.5rem 0;padding:0 1rem}.volume-container button{background:#fff;border:1px solid #dee2e6;color:#495057;padding:.5rem;border-radius:50%;cursor:pointer;font-size:1.2rem;transition:all .2s ease;width:40px;height:40px;display:flex;align-items:center;justify-content:center}.volume-container button:hover{background:#f8f9fa;border-color:#adb5bd;transform:scale(1.05)}.volume-container button.muted{background:#f8d7da;border-color:#f5c6cb;color:#721c24}.volume-slider{flex:1;max-width:200px;height:6px;background:#e9ecef;border-radius:3px;outline:none;cursor:pointer;transition:all .2s ease;appearance:none}.volume-slider::-webkit-slider-thumb{appearance:none;width:16px;height:16px;border-radius:50%;background:#007bff;cursor:pointer;border:2px solid #fff;box-shadow:0 2px 4px #0003;transition:all .2s ease}.volume-slider::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 4px 8px #0000004d}.volume-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#007bff;cursor:pointer;border:2px solid #fff;box-shadow:0 2px 4px #0003;transition:all .2s ease}.volume-slider::-moz-range-thumb:hover{transform:scale(1.1);box-shadow:0 4px 8px #0000004d}.volume-slider::-webkit-slider-track{background:#e9ecef;border-radius:3px;height:6px}.volume-slider::-moz-range-track{background:#e9ecef;border-radius:3px;height:6px;border:none}.volume-label{color:#6c757d;font-size:.9rem;font-weight:500;min-width:60px;text-align:center}.player-container{background:#fff;border:1px solid #e1e5e9;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a;transition:box-shadow .2s ease}.player-container:hover{box-shadow:0 4px 12px #00000026}.player-container h2{color:#2c3e50;font-size:1.5rem;font-weight:600;margin-bottom:1.5rem;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-container h2:empty:before{content:"Selecciona una canción";color:#6c757d;font-style:italic}.playlist-container{background:#fff;border:1px solid #e1e5e9;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a;transition:box-shadow .2s ease}.playlist-container:hover{box-shadow:0 4px 12px #00000026}.playlist-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.playlist-header h3{color:#2c3e50;font-size:1.5rem;font-weight:600;margin:0}.playlist-controls{display:flex;gap:.5rem;align-items:center}.sort-btn,.clear-all-btn{background:#6c757d;border:none;color:#fff;padding:.5rem 1rem;border-radius:6px;font-size:.85rem;cursor:pointer;transition:all .2s ease;white-space:nowrap}.sort-btn:hover,.clear-all-btn:hover{background:#5a6268;transform:translateY(-1px)}.sort-btn.active{background:#007bff}.sort-btn.active:hover{background:#0056b3}.clear-all-btn{background:#dc3545}.clear-all-btn:hover{background:#c82333}.playlist-container ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.playlist-container li{margin:0;transition:transform .2s ease}.playlist-container li:hover{transform:translate(4px)}.playlist-container li.active{transform:translate(8px)}.track-button{width:100%;background:#f8f9fa;border:1px solid #e9ecef;color:#495057;padding:1rem 1.5rem;border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:left;position:relative;display:flex;justify-content:space-between;align-items:center}.track-button:hover{background:#e9ecef;border-color:#dee2e6;transform:translateY(-1px)}.playlist-container li.active .track-button{background:#e3f2fd;border-color:#90caf9;color:#1976d2}.track-button:hover .remove-track-btn{opacity:1}.track-info{position:relative;z-index:1}.track-title{font-size:1rem;font-weight:600;margin-bottom:.25rem;color:#2c3e50;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-artist{font-size:.85rem;color:#6c757d;margin-bottom:.25rem}.track-meta{display:flex;gap:.5rem;margin-top:.25rem}.track-type{font-size:.75rem;color:#6c757d;background:#e9ecef;padding:.25rem .5rem;border-radius:4px;display:inline-block;font-weight:500}.remove-track-btn{background:#dc3545;border:none;color:#fff;width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.8rem;transition:all .2s ease;flex-shrink:0;opacity:0;margin-left:1rem}.remove-track-btn:hover{background:#c82333;transform:scale(1.1);opacity:1}.playlist-container .empty-state{text-align:center;color:#6c757d;font-style:italic;padding:2rem;background:#f8f9fa;border-radius:8px;border:1px dashed #dee2e6}@media (max-width: 768px){.playlist-header{flex-direction:column;align-items:stretch;gap:.75rem}.playlist-controls{justify-content:center;flex-wrap:wrap}.sort-btn,.clear-all-btn{flex:1;min-width:120px}.track-button{padding:.75rem 1rem}.remove-track-btn{opacity:1;margin-left:.5rem}}.addtrack-container{background:#fff;border:1px solid #e1e5e9;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a;transition:box-shadow .2s ease}.addtrack-container:hover{box-shadow:0 4px 12px #00000026}.addtrack-container h3{color:#2c3e50;font-size:1.5rem;font-weight:600;margin-bottom:2rem;text-align:center}.addtrack-section{margin-bottom:2rem}.addtrack-section:last-child{margin-bottom:0}.file-upload-label{display:block;cursor:pointer;transition:all .2s ease;border-radius:8px;overflow:hidden;position:relative}.file-upload-label:hover{transform:translateY(-1px)}.file-upload-content{background:#f8f9fa;border:2px dashed #dee2e6;border-radius:8px;padding:2rem;text-align:center;transition:all .2s ease;position:relative;overflow:hidden}.file-upload-label:hover .file-upload-content{border-color:#adb5bd;background:#e9ecef}.file-upload-icon{font-size:3rem;margin-bottom:1rem;position:relative;z-index:1;color:#6c757d}.file-upload-text{position:relative;z-index:1}.file-upload-title{color:#2c3e50;font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.file-upload-subtitle{color:#6c757d;font-size:.9rem}.file-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.url-adder{display:flex;gap:1rem;align-items:center}.url-input{flex:1;background:#fff;border:1px solid #dee2e6;color:#495057;padding:1rem 1.5rem;border-radius:8px;font-size:1rem;transition:all .2s ease}.url-input::placeholder{color:#6c757d}.url-input:focus{outline:none;border-color:#007bff;background:#fff;box-shadow:0 0 0 3px #007bff1a}.add-url-button{background:#007bff;border:none;color:#fff;padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.add-url-button:hover{background:#0056b3;transform:translateY(-1px)}.add-url-button:active{transform:translateY(0)}.help-text{display:block;color:#6c757d;font-size:.85rem;margin-top:.75rem;font-style:italic;text-align:center}.validation-errors{background:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;padding:1rem;margin-top:1rem}.validation-errors h4{color:#721c24;font-size:1rem;margin:0 0 .5rem}.validation-errors ul{margin:0;padding-left:1.5rem}.error-item{color:#721c24;font-size:.9rem;margin-bottom:.25rem}.selected-files{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:1rem;margin-top:1rem}.selected-files-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.selected-files-header h4{color:#2c3e50;font-size:1rem;margin:0}.clear-all-btn{background:#dc3545;border:none;color:#fff;padding:.5rem 1rem;border-radius:6px;font-size:.85rem;cursor:pointer;transition:all .2s ease}.clear-all-btn:hover{background:#c82333;transform:translateY(-1px)}.files-list{display:flex;flex-direction:column;gap:.5rem}.file-item{display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid #dee2e6;border-radius:6px;padding:.75rem;transition:all .2s ease}.file-item:hover{border-color:#adb5bd;box-shadow:0 2px 4px #0000001a}.file-details{flex:1;min-width:0}.file-name{font-weight:600;color:#2c3e50;margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-meta{display:flex;gap:1rem;font-size:.8rem;color:#6c757d}.file-size{font-weight:500}.file-type{background:#e9ecef;padding:.2rem .4rem;border-radius:4px;font-size:.75rem}.remove-file-btn{background:#dc3545;border:none;color:#fff;width:24px;height:24px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.8rem;transition:all .2s ease;flex-shrink:0}.remove-file-btn:hover{background:#c82333;transform:scale(1.1)}@media (max-width: 768px){.url-adder{flex-direction:column;gap:.75rem}.add-url-button{width:100%}.addtrack-container,.file-upload-content{padding:1.5rem}.selected-files-header{flex-direction:column;gap:.5rem;align-items:stretch}.clear-all-btn{width:100%}.file-meta{flex-direction:column;gap:.25rem}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f8f9fa;min-height:100vh;color:#333;line-height:1.6}.app-container{max-width:800px;margin:0 auto;padding:2rem 1rem;min-height:100vh;display:flex;flex-direction:column;gap:2rem}.app-container h1{text-align:center;font-size:2rem;font-weight:600;color:#2c3e50;margin-bottom:1rem}.error-message{background:#fee;border:1px solid #fcc;color:#c33;padding:1rem;border-radius:8px;margin-bottom:1rem;font-weight:500}
