*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:#888;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#555}button,input{font-family:inherit}a{color:inherit;text-decoration:none}.search-bar{margin-bottom:20px;width:100%}.search-form{display:flex;gap:10px;width:100%}.search-input{border:2px solid #e0e0e0;border-radius:25px;flex:1 1;font-size:16px;outline:none;padding:12px 16px;transition:border-color .3s}.search-input:focus{border-color:#4a90e2}.search-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.search-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:25px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;padding:12px 24px;transition:opacity .3s,transform .2s;white-space:nowrap}.search-button:hover:not(:disabled){opacity:.9;transform:scale(1.02)}.search-button:active:not(:disabled){transform:scale(.98)}.search-button:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.search-form{flex-direction:column;gap:10px}.search-button{width:100%}.search-input{font-size:16px}}.website-selector{margin-bottom:20px}.website-label{color:#666;display:block;font-size:14px;font-weight:500;margin-bottom:10px}.website-buttons{-webkit-overflow-scrolling:touch;-ms-overflow-style:none;display:flex;flex-wrap:nowrap;gap:10px;overflow-x:auto;overflow-y:hidden;scroll-behavior:smooth;scrollbar-width:none}.website-buttons::-webkit-scrollbar{display:none;height:0;width:0}.website-button{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:20px;cursor:pointer;display:flex;flex-shrink:0;font-size:14px;gap:8px;padding:10px 16px;transition:all .3s;white-space:nowrap}.website-button:hover{background:#f0f4ff;border-color:#667eea}.website-button.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff}.website-icon{font-size:18px}.website-name{font-weight:500}.website-description{background:#f8f9fa;border-left:3px solid #667eea;border-radius:8px;margin-top:12px;padding:12px 16px}.website-description p{color:#666;font-size:13px;line-height:1.5;margin:0}@media (max-width:768px){.website-buttons{gap:8px}.website-button{font-size:13px;padding:8px 14px}}.source-selector{margin-bottom:20px;margin-top:20px}.source-label{color:#666;display:block;font-size:14px;font-weight:500;margin-bottom:10px}.source-buttons{-webkit-overflow-scrolling:touch;-ms-overflow-style:none;display:flex;flex-wrap:nowrap;gap:10px;overflow-x:auto;overflow-y:hidden;scroll-behavior:smooth;scrollbar-width:none}.source-buttons::-webkit-scrollbar{display:none;height:0;width:0}.source-button{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:20px;cursor:pointer;display:flex;flex-shrink:0;font-size:14px;gap:8px;padding:10px 16px;transition:all .3s;white-space:nowrap}.source-button:hover{background:#f0f4ff;border-color:#667eea}.source-button.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff}.source-icon{font-size:18px}.source-name{font-weight:500}.source-hint{font-size:11px;font-weight:400;margin-left:4px;opacity:.8}.source-button.active .source-hint{opacity:.9}.source-description{background:#f8f9fa;border-left:3px solid #667eea;border-radius:8px;margin-top:12px;padding:12px 16px}.source-description p{color:#666;font-size:13px;line-height:1.5;margin:0}@media (max-width:768px){.source-buttons{gap:8px}.source-button{font-size:13px;padding:8px 14px}}.music-list-item{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;box-sizing:border-box;cursor:pointer;display:flex;gap:16px;margin-bottom:12px;overflow:hidden;padding:16px;transition:all .3s;width:100%}.music-list-item:hover{box-shadow:0 4px 16px #0000001f;transform:translateY(-2px)}.music-item-number{color:#999;flex-shrink:0;font-size:16px;font-weight:600;text-align:center;width:32px}.music-item-cover{background:#f0f0f0;border-radius:8px;cursor:pointer;flex-shrink:0;height:64px;overflow:hidden;position:relative;width:64px}.music-item-cover img{height:100%;object-fit:cover;width:100%}.music-item-play-overlay{align-items:center;background:#0006;display:flex;height:100%;justify-content:center;left:0;opacity:0;position:absolute;top:0;transition:opacity .3s;width:100%}.music-item-cover:hover .music-item-play-overlay{opacity:1}.play-icon{color:#fff;font-size:24px}.music-item-info{flex:1 1;flex-direction:column;gap:4px;max-width:100%}.music-item-info,.music-item-title-row{display:flex;min-width:0;overflow:hidden}.music-item-title-row{align-items:center}.music-item-title{color:#333;flex:1 1;font-size:16px;font-weight:600;margin:0;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.music-item-quality{background:#f0f4ff;border-radius:12px;color:#667eea;font-size:12px;font-weight:500;padding:2px 8px;white-space:nowrap}.music-item-singer{color:#666;font-size:14px;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.music-item-meta{align-items:center;color:#999;display:flex;font-size:12px;gap:16px;min-width:0;overflow:hidden}.music-item-album{flex:1 1;max-width:100%;min-width:0;overflow:hidden;text-overflow:ellipsis}.music-item-album,.music-item-interval{white-space:nowrap}.music-item-actions{display:flex;flex-shrink:0}.music-item-button{background:#fff;border:1px solid #e0e0e0;border-radius:20px;color:#666;cursor:pointer;font-size:14px;padding:8px 24px;transition:all .3s;white-space:nowrap}.music-item-button:hover{transform:scale(1.05)}.play-button:hover{background:#667eea;border-color:#667eea;color:#fff}@media (max-width:768px){.music-list-item{gap:12px;padding:12px}.music-item-number{font-size:14px;width:24px}.music-item-cover{height:56px;width:56px}.music-item-title{font-size:15px}.music-item-singer{font-size:13px}.music-item-meta{font-size:11px;gap:12px}.music-item-actions{flex-direction:column;gap:6px}.music-item-button{font-size:13px;padding:6px 16px;width:70px}.music-item-quality{font-size:11px;padding:2px 6px}}@media (max-width:480px){.music-list-item{gap:10px;padding:10px}.music-item-number{display:none}.music-item-cover{height:48px;width:48px}.music-item-title-row{gap:8px}.music-item-meta{align-items:flex-start;flex-direction:column;gap:4px}}.music-list{width:100%}.music-list-container{display:flex;flex-direction:column;width:100%}.music-list-empty{color:#999;padding:60px 20px}.music-list-empty,.music-list-loading-overlay{align-items:center;display:flex;flex-direction:column;justify-content:center}.music-list-loading-overlay{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#fffffff2;border-radius:8px;margin-bottom:20px;min-height:80px;padding:20px;position:-webkit-sticky;position:sticky;text-align:center;top:0;z-index:10}.music-list-loading-overlay p{color:#666;font-size:14px;margin:0}.music-list-container.loading{opacity:.7;pointer-events:none;transition:opacity .2s}.music-list-skeleton{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:12px;padding:12px}.skeleton-item{animation:skeleton-loading 1.5s ease-in-out infinite;background:linear-gradient(90deg,#f0f0f0,#e0e0e0 50%,#f0f0f0);background-size:200% 100%;border-radius:8px;height:80px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f0f0f0;border-radius:50%;border-top-color:#667eea;display:block;flex-shrink:0;height:40px;margin:0 0 12px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.empty-hint{color:#ccc;font-size:14px;margin-top:8px}@media (max-width:768px){.music-list-grid{gap:16px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.music-list-empty,.music-list-loading{padding:40px 20px}}@media (max-width:480px){.music-list-grid{gap:12px;grid-template-columns:repeat(2,1fr)}}.pagination{flex-wrap:wrap;gap:8px;margin-bottom:24px;margin-top:24px}.pagination,.pagination-button{align-items:center;display:flex;justify-content:center}.pagination-button{background:#fff;border:1px solid #e0e0e0;border-radius:10px;color:#666;cursor:pointer;font-size:16px;font-weight:500;height:48px;min-width:48px;padding:0 16px;transition:all .3s}.pagination-nav{font-size:20px;font-weight:600;min-width:48px}.pagination-button.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff}.pagination-button:disabled{cursor:not-allowed;opacity:.5;pointer-events:none}.pagination-button:not(:disabled){cursor:pointer}.pagination-button:not(:disabled):hover{background:#f0f4ff;border-color:#667eea;box-shadow:0 2px 8px #667eea33;color:#667eea;transform:translateY(-2px)}.pagination-current-page{align-items:center;color:#666;display:flex;font-size:16px;font-weight:500;height:48px;justify-content:center;min-width:80px;padding:0 16px}@media (max-width:768px){.pagination{gap:8px;margin-bottom:20px;margin-top:20px}.pagination-button{font-size:15px;height:44px;min-width:44px;padding:0 14px}.pagination-nav{font-size:18px;min-width:44px}.pagination-current-page{font-size:15px;height:44px;min-width:70px;padding:0 12px}}@media (max-width:480px){.pagination-button{font-size:14px;height:40px;min-width:40px;padding:0 12px}.pagination-nav{font-size:16px;min-width:40px}.pagination-current-page{font-size:14px;height:40px;min-width:60px;padding:0 10px}}.quality-selector{margin-bottom:20px}.quality-label{color:#666;display:block;font-size:14px;font-weight:500;margin-bottom:10px}.quality-buttons{display:flex;flex-wrap:wrap;gap:8px}.quality-button{background:#fff;border:2px solid #e0e0e0;border-radius:20px;cursor:pointer;font-size:13px;padding:8px 16px;transition:all .3s;white-space:nowrap}.quality-button:hover{background:#f0f4ff;border-color:#667eea}.quality-button.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff}@media (max-width:768px){.quality-buttons{gap:6px}.quality-button{font-size:12px;padding:6px 12px}}.player-overlay{align-items:center;animation:fadeIn .3s;background:#000000b3;display:flex;height:100%;justify-content:center;left:0;padding:20px;position:fixed;top:0;width:100%;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.player-container{animation:slideUp .3s;background:#fff;border-radius:20px;box-shadow:0 10px 40px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;padding:24px;position:relative;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.player-close{align-items:center;background:#f0f0f0;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;line-height:1;position:absolute;right:16px;top:16px;transition:background .3s;width:32px}.player-close:hover{background:#e0e0e0}.player-content{display:flex;flex-direction:column;gap:20px}.player-cover{aspect-ratio:1;border-radius:12px;box-shadow:0 4px 16px #0003;margin:0 auto;max-width:300px;overflow:hidden;width:100%}.player-cover img{height:100%;object-fit:cover;width:100%}.player-info{text-align:center}.player-title{color:#333;font-size:20px;font-weight:600;margin:0 0 8px}.player-singer{color:#666;font-size:16px;margin:0 0 4px}.player-album{color:#999;font-size:14px;margin:0}.player-error{background:#fff2f0;border-radius:8px;color:#ff4d4f;font-size:14px;padding:12px;text-align:center}.player-controls{display:flex;flex-direction:column;gap:16px}.player-progress-container{display:flex;flex-direction:column;gap:8px}.player-progress{background:#e0e0e0;border-radius:4px;cursor:pointer;height:8px;margin:-6px 0;overflow:hidden;padding:6px 0;position:relative;touch-action:none;user-select:none;-webkit-user-select:none;width:100%}.player-progress.dragging,.player-progress:hover{border-radius:5px;height:10px}.player-progress-bar{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px;height:100%;left:0;pointer-events:none;position:absolute;top:0;transition:width .1s;z-index:0}.player-progress.dragging .player-progress-bar{transition:none}.player-progress-thumb{background:#fff;border:2px solid #667eea;border-radius:50%;box-shadow:0 2px 5px #0000004d;height:16px;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);width:16px;z-index:1}@media (max-width:768px){.player-progress{border-radius:5px;height:10px;margin:-8px 0;padding:8px 0}.player-progress.dragging,.player-progress:hover{border-radius:6px;height:12px}.player-progress-thumb{border-width:2px;height:18px;width:18px}}.player-time{color:#999;display:flex;font-size:12px;justify-content:space-between}.player-buttons{display:flex;gap:12px}.player-button{align-items:center;border:none;border-radius:25px;cursor:pointer;display:flex;flex:1 1;font-size:16px;font-weight:500;justify-content:center;padding:12px 24px;transition:all .3s}.player-icon-play{border-bottom:8px solid #0000;border-left:12px solid #fff;border-top:8px solid #0000;display:inline-block;height:0;margin-left:4px;width:0}.player-icon-pause{align-items:center;display:inline-flex;gap:4px;height:20px;justify-content:center;width:20px}.pause-bar{background:#fff;border-radius:2px;height:16px;width:4px}.play-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.play-button:hover:not(:disabled){opacity:.9;transform:scale(1.02)}.download-button{background:#fff;border:2px solid #667eea;color:#667eea}.download-button:hover:not(:disabled){background:#667eea;color:#fff}.player-button:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.player-overlay{padding:10px}.player-container{max-height:95vh;padding:20px}.player-cover{max-width:250px}.player-title{font-size:18px}.player-singer{font-size:14px}.player-buttons{flex-direction:column}.player-button{width:100%}}.App{min-height:100vh;padding:20px}.app-main{background:#fff;border-radius:20px;box-shadow:0 10px 40px #0003;margin:0 auto;max-width:1200px;padding:30px}.project-docs-link{border-top:1px solid #e0e0e0;margin-top:30px;padding-top:20px;text-align:center}.docs-link{align-items:center;border-radius:6px;color:#667eea;display:inline-flex;font-size:14px;font-weight:500;gap:6px;padding:6px 12px;text-decoration:none;transition:all .3s}.docs-link:hover{background:#f0f4ff;color:#764ba2;text-decoration:none}.error-message{background:#fff2f0;border-left:4px solid #ff4d4f;border-radius:8px;color:#ff4d4f;font-size:14px;margin-bottom:20px;padding:12px 16px;text-align:center}@media (max-width:768px){.App{padding:10px}.app-main{border-radius:15px;padding:20px}}@media (max-width:480px){.app-main{padding:15px}}
/*# sourceMappingURL=main.6de2d943.css.map*/