.playlists-page{padding-bottom:2rem}.playlists-header{margin:1.5rem 0 .75rem}.playlists-header-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.playlists-header h2{font-size:1.125rem;font-weight:700;flex-shrink:0}.search-filter{flex:1;min-width:0;max-width:200px;padding:.3rem .5rem;font-size:.8125rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);outline:none;transition:border-color .15s ease}.search-filter:focus{border-color:var(--color-primary)}.search-filter::placeholder{color:var(--color-text-secondary)}.header-search-group{display:flex;gap:.375rem;width:100%}.header-search-group .search-filter{flex:1;max-width:none}.song-search-wrap{margin-bottom:.5rem}.song-search-wrap .search-filter{max-width:none;width:100%}.playlist-card{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:background .15s ease}.playlist-card:hover{background:var(--color-surface-hover)}.playlist-card+.playlist-card{margin-top:.5rem}.playlist-info{flex:1}.playlist-name{font-weight:600;font-size:1rem}.playlist-meta{font-size:.75rem;color:var(--color-text-secondary);margin-top:.25rem}.item-actions{display:flex;gap:.25rem;flex-shrink:0}.song-list{margin-top:1rem}.song-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:background .15s ease}.song-item:hover{background:var(--color-surface-hover)}.song-item+.song-item{margin-top:.5rem}.song-icon{width:2.5rem;height:2.5rem;border-radius:var(--radius-sm);background:var(--color-region-bg);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.song-info{flex:1;min-width:0}.song-title{font-weight:600;font-size:.9375rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-meta{font-size:.75rem;color:var(--color-text-secondary);margin-top:.125rem}.song-status{font-size:.625rem;padding:.125rem .5rem;border-radius:999px;font-weight:600}.song-status.ready{background:#22c55e26;color:var(--color-success)}.song-status.pending{background:#f59e0b26;color:var(--color-warning)}.song-status.no-audio{background:#ef444426;color:var(--color-danger)}.song-region-badges{display:flex;gap:.2rem;margin-top:.25rem;overflow:hidden;max-width:100%}.song-region-badge{display:inline-flex;align-items:center;gap:.2rem;font-size:.6rem;padding:.05rem .35rem;background:var(--color-region-bg, rgba(99, 102, 241, .12));border:1px solid var(--color-region-border, rgba(99, 102, 241, .25));border-radius:var(--radius-sm, 4px);white-space:nowrap;color:var(--color-text-secondary);font-weight:500;flex-shrink:0}.badge-time{color:var(--color-text-secondary);font-weight:400}.badge-ts{opacity:.75;font-weight:400}.badge-bpm{font-weight:700;color:var(--color-text)}.song-region-badge-more{background:var(--color-surface-hover, rgba(100,100,100,.1));border-color:var(--color-border);color:var(--color-text-secondary);font-style:italic}.song-region-badges:after{content:"";position:absolute;right:0;top:0;bottom:0;width:20px;background:linear-gradient(to right,transparent,var(--color-surface));pointer-events:none;display:none}.song-region-badges{position:relative}.add-song-area{margin-top:1rem;padding:1.5rem;border:2px dashed var(--color-border);border-radius:var(--radius-md);text-align:center;cursor:pointer;transition:border-color .15s ease}.add-song-area:hover{border-color:var(--color-primary)}.add-song-area p{font-size:.875rem;color:var(--color-text-secondary);margin-top:.5rem}.playlist-card.expanded{border-radius:var(--radius-md) var(--radius-md) 0 0;border-bottom-color:var(--color-primary);background:var(--color-surface-hover)}.playlist-songs{border:1px solid var(--color-border);border-top:none;border-radius:0 0 var(--radius-md) var(--radius-md);padding:.75rem;background:var(--color-bg)}.playlist-songs+.playlist-card{margin-top:.5rem}.song-checkbox{flex-shrink:0;width:1rem;height:1rem;accent-color:var(--color-primary);cursor:pointer}.song-list-toolbar{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;margin-top:.5rem}.song-select-all{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--color-text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.song-bulk-actions{display:flex;gap:.375rem;margin-left:auto}.move-playlist-item{padding:.75rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:background .15s ease;margin-top:.375rem;font-size:.875rem}.move-playlist-item:hover{background:var(--color-surface-hover)}.playlist-card.dragging{opacity:.25;border-style:dashed}.playlist-ghost{opacity:.92;box-shadow:0 8px 24px #00000059;transform:scale(1.02);transition:none!important}.drop-indicator{height:3px;background:var(--color-primary);border-radius:2px;margin:2px 0}.add-song-tabs{display:flex;gap:0;margin-bottom:1rem;border-bottom:1px solid var(--color-border)}.add-song-tab{flex:1;padding:.75rem;text-align:center;font-size:.875rem;font-weight:600;color:var(--color-text-secondary);border-bottom:2px solid transparent;transition:all .15s ease}.add-song-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.file-drop-zone{padding:2rem;border:2px dashed var(--color-border);border-radius:var(--radius-md);text-align:center;transition:border-color .15s ease}.file-drop-zone.dragover{border-color:var(--color-primary);background:var(--color-region-bg)}.youtube-input-group{display:flex;gap:.5rem}.youtube-input-group input{flex:1}.song-icon{position:relative;overflow:hidden;cursor:pointer}.song-icon img.song-thumb{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-sm)}.song-icon-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s ease;border-radius:var(--radius-sm);font-size:.8rem;color:#fff}.song-icon:hover .song-icon-overlay{opacity:1}.song-source-badge{display:inline-flex;align-items:center;gap:.2rem;font-size:.6rem;font-weight:700;padding:.1rem .35rem;border-radius:var(--radius-sm);cursor:pointer;-webkit-user-select:none;user-select:none;vertical-align:middle;margin-left:0;margin-right:.3rem;flex-shrink:0;transition:opacity .15s}.song-source-badge:hover{opacity:.75}.song-source-badge.yt{background:#ff00001f;color:#f44;border:1px solid rgba(255,0,0,.25)}.song-source-badge.ext{background:#6366f11f;color:var(--color-primary);border:1px solid rgba(99,102,241,.25);text-transform:uppercase}.source-badge-popup{position:absolute;z-index:200;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 4px 16px #00000059;overflow:hidden;min-width:130px}.source-badge-popup-item{display:flex;align-items:center;gap:.5rem;padding:.65rem 1rem;font-size:.875rem;cursor:pointer;transition:background .1s ease}.source-badge-popup-item:hover{background:var(--color-surface-hover)}.extract-cost-info{font-size:.75rem;color:var(--color-text-secondary);margin-top:.375rem;line-height:1.4}.recover-options{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.song-item.no-audio{opacity:.7}.song-item.no-audio .song-icon{background:#ef44441a}
