*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#7366ea,#a24b8c);color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.app,body{min-height:100vh}.app{display:flex;flex-direction:column}.app-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-bottom:1px solid #fff3;box-shadow:0 2px 20px #0000001a;padding:1rem 2rem}.app-header h1{color:#4a5568;font-size:2rem;font-weight:700;margin-bottom:1rem;text-align:center}.nav-tabs{display:flex;gap:.5rem;justify-content:center}.app-header button,.nav-tabs button{background:#0000;border:none;border-radius:.5rem;color:#718096;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.nav-tabs button:hover{background:#667eea1a;color:#667eea}.nav-tabs button.active{background:#667eea;box-shadow:0 2px 8px #667eea4d;color:#fff}.app-main{flex:1 1;margin:0 auto;max-width:1200px;padding:2rem;width:100%}.loading{color:#fff;font-size:1.1rem;padding:2rem;text-align:center}.error-message{align-items:center;background:#fed7d7;border:1px solid #feb2b2;color:#c53030;display:flex;justify-content:space-between;padding:1rem}.error-message button{background:none;border:none;color:#c53030;cursor:pointer;font-size:1.5rem}.music-status{color:#fff}.status-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.status-header h2{font-size:1.8rem;font-weight:600}.refresh-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:.5rem;color:#fff;cursor:pointer;padding:.5rem 1rem;transition:all .2s ease}.refresh-btn:hover:not(:disabled){background:#ffffff4d}.refresh-btn:disabled{cursor:not-allowed;opacity:.6}.status-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.status-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:1rem;box-shadow:0 8px 32px #0000001a;padding:1.5rem}.status-card h3{color:#e2e8f0;font-size:1.2rem;margin-bottom:1rem}.song-info{color:#fff}.song-title{font-size:1.1rem;margin-bottom:.5rem}.song-details{color:#e2e8f0;display:flex;flex-direction:column;font-size:.9rem;gap:.25rem}.no-song{color:#a0aec0;font-style:italic}.playlist-details{display:flex;flex-direction:column;gap:.5rem}.info-item{align-items:center;display:flex;justify-content:space-between}.info-item .label{color:#e2e8f0}.info-item .value{color:#fff;font-weight:600}.info-item .value.streaming{color:#68d391}.info-item .value.stopped{color:#fc8181}.file-upload{color:#fff}.file-upload h2{font-size:1.8rem}.dropzone,.file-upload h2{margin-bottom:2rem;text-align:center}.dropzone{background:#ffffff0d;border:2px dashed #ffffff4d;border-radius:1rem;cursor:pointer;padding:3rem;transition:all .3s ease}.dropzone:hover{background:#ffffff1a;border-color:#ffffff80}.dropzone.active{background:#68d3911a;border-color:#68d391}.dropzone.disabled{cursor:not-allowed;opacity:.6}.dropzone-content{color:#fff}.upload-icon{font-size:3rem;margin-bottom:1rem}.dropzone-content p{margin-bottom:.5rem}.file-types{color:#e2e8f0;font-size:.9rem}.upload-status{border-radius:.5rem;font-weight:500;margin-bottom:1rem;padding:1rem;text-align:center}.upload-status.success{background:#68d39133;border:1px solid #68d3914d;color:#68d391}.upload-status.error{background:#fc818133;border:1px solid #fc81814d;color:#fc8181}.upload-info{background:#ffffff1a;border:1px solid #fff3;border-radius:1rem;padding:1.5rem}.upload-info h3{color:#fff;margin-bottom:1rem}.upload-info ul{color:#e2e8f0;list-style:none}.upload-info li{margin-bottom:.5rem;padding-left:1rem;position:relative}.upload-info li:before{color:#667eea;content:"•";left:0;position:absolute}.song-list{color:#fff}.song-list-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.song-list-header h2{font-size:1.8rem;font-weight:600}.song-list-controls{align-items:center;display:flex;gap:1rem}.filter-controls,.sort-controls{align-items:center;display:flex;gap:.5rem}.filter-controls label,.sort-controls label{color:#e2e8f0;font-weight:500}.filter-controls select,.sort-controls select,.sort-order-btn{background:#ffffff1a;border:1px solid #ffffff4d;border-radius:.5rem;color:#fff;cursor:pointer;padding:.5rem}.sort-order-btn{font-size:1rem}.songs-table{background:#ffffff1a;border:1px solid #fff3;border-radius:1rem;overflow:hidden}.table-header{background:#fff3;color:#fff;display:grid;font-weight:600;grid-template-columns:2fr 1fr 1fr 1.5fr 1fr;padding:1rem}.table-body{max-height:400px;overflow-y:auto}.table-row{align-items:center;border-bottom:1px solid #ffffff1a;display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr 1fr;padding:1rem;transition:background .2s ease}.table-row:hover{background:#ffffff0d}.table-row:last-child{border-bottom:none}.song-title{color:#fff;font-weight:600;margin-bottom:.25rem}.song-filename{color:#a0aec0;font-size:.8rem}.play-count{border-radius:.25rem;font-weight:600;padding:.25rem .5rem;text-align:center}.play-count.played{background:#68d39133;color:#68d391}.play-count.unplayed{background:#a0aec033;color:#a0aec0}.delete-btn{background:#fc818133;border:1px solid #fc81814d;border-radius:.5rem;color:#fc8181;cursor:pointer;padding:.5rem;transition:all .2s ease}.delete-btn:hover:not(:disabled){background:#fc81814d}.delete-btn:disabled{cursor:not-allowed;opacity:.6}.no-songs{color:#a0aec0;padding:2rem;text-align:center}.stats{color:#fff}.stats h2{font-size:1.8rem;margin-bottom:2rem;text-align:center}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.stats-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:1rem;padding:1.5rem;text-align:center;transition:transform .2s ease}.stats-card:hover{transform:translateY(-2px)}.stats-card.primary{background:#667eea33;border-color:#667eea4d}.stats-card.secondary{background:#764ba233;border-color:#764ba24d}.stats-icon{font-size:2rem;margin-bottom:1rem}.stats-number{color:#fff;font-size:2rem;font-weight:700;margin-bottom:.5rem}.stats-label{color:#e2e8f0;font-size:.9rem}.most-played-card{background:#ffffff1a;border:1px solid #fff3;border-radius:1rem;margin-bottom:2rem;padding:1.5rem}.most-played-card h3{color:#fff;margin-bottom:1rem}.most-played-content{color:#fff}.most-played-content .song-title{font-size:1.2rem;font-weight:600;margin-bottom:.5rem}.play-count{color:#68d391;font-weight:500;margin-bottom:.25rem}.play-percentage{color:#e2e8f0;font-size:.9rem}.stats-info{background:#ffffff1a;border:1px solid #fff3;border-radius:1rem;padding:1.5rem}.stats-info h3{color:#fff;margin-bottom:1rem}.stats-info ul{color:#e2e8f0;list-style:none}.stats-info li{margin-bottom:.5rem;padding-left:1rem;position:relative}.stats-info li:before{color:#667eea;content:"•";left:0;position:absolute}@media (max-width:768px){.app-header,.app-main{padding:1rem}.nav-tabs{flex-wrap:wrap}.status-grid{grid-template-columns:1fr}.song-list-controls,.song-list-header{align-items:stretch;flex-direction:column}.table-header,.table-row{gap:.5rem;grid-template-columns:1fr}.table-header>div,.table-row>div{padding:.25rem 0}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}}.login-container{align-items:center;background:linear-gradient(#0003,#000000b3),url(/static/media/background.328c0c3bd0b66f6f12a0.png) no-repeat 50% fixed;background-size:cover;display:flex;justify-content:center;min-height:100vh}.login-box{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#fff3;border-radius:12px;box-shadow:0 8px 24px #0000004d;color:#fff;max-width:400px;padding:2rem;text-align:center;width:100%}.login-box h2{margin-bottom:1.5rem}.login-box .input-group{margin-bottom:1rem}.login-box input{border:none;border-radius:8px;margin:.5rem 0;outline:none;padding:.75rem;width:100%}.login-box input:focus{background:#fff;box-shadow:0 0 0 2px #4e8df5;outline:none}.login-box input::placeholder{color:#666}.login-box button{background-color:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;margin-top:1rem;padding:.75rem;transition:background .3s ease;width:100%}.login-box button:hover{background-color:#0056b3}.login-box button:active{transform:translateY(0)}.error-message{background:#ff6b6b1a;border:1px solid #ff6b6b4d;border-radius:8px;color:#ff6b6b;margin-top:1rem}.success-message{align-items:center;background-color:#22c55e1a;border:1px solid #22c55e33;border-radius:6px;color:#22c55e;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;margin-top:1rem;padding:.75rem 1rem}.success-message:before{color:#22c55e;content:"✓";font-size:1rem;font-weight:700}.success-message-vibrant{background-color:#10b98114;border:1px solid #10b98140;border-radius:6px;color:#10b981;font-size:.875rem;font-weight:500;margin-top:1rem;padding:.75rem 1rem}@media (max-width:480px){.login-container{padding:.5rem}.login-box{margin:0 auto;max-width:100%;padding:1.5rem}.login-box h2{font-size:1.5rem;margin-bottom:1.25rem}.login-box button,.login-box input{font-size:.9rem;padding:.75rem}}@media (min-width:481px) and (max-width:768px){.login-box{max-width:350px;padding:1.75rem}}@media (min-width:769px){.login-box{max-width:400px;padding:2.5rem}.login-box h2{font-size:2rem}}.multiple-files{color:#2b44b6;font-weight:500;margin-top:8px}.upload-status.info{background-color:#dbeafe;border:1px solid #93c5fd;color:#1e40af}.status-content{align-items:center;display:flex;gap:10px;justify-content:space-between}.clear-status-btn{align-items:center;background:none;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:18px;font-weight:700;height:20px;justify-content:center;padding:0;transition:background-color .2s;width:20px}.clear-status-btn:hover{background-color:#0000001a}.upload-status.success .clear-status-btn:hover{background-color:#10b98133}.upload-status.error .clear-status-btn:hover{background-color:#ef444433}.upload-progress{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-top:20px;padding:15px}.upload-progress h4{color:#374151;font-size:14px;font-weight:600;margin:0 0 10px}.progress-list{display:flex;flex-direction:column;gap:8px}.progress-item{align-items:center;background-color:#fff;border:1px solid #e5e7eb;border-radius:6px;display:flex;font-size:13px;justify-content:space-between;padding:8px 12px}.progress-item.success{background-color:#f0fdf4;border-color:#10b981}.progress-item.failed{background-color:#fef2f2;border-color:#ef4444}.progress-item.pending{background-color:#fffbeb;border-color:#f59e0b}.filename{color:#374151;flex:1 1;font-weight:500;margin-right:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status{font-size:16px}.error-message{color:#dc2626;font-size:11px;font-style:italic;margin-top:4px}.youtube-upload{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff14;border-radius:1rem;box-shadow:0 8px 20px #0000004d;margin:2rem auto;max-width:600px;padding:2rem}.youtube-upload h2{color:#fff;font-size:1.5rem;font-weight:600;margin-bottom:1rem;text-align:center}.youtube-upload .youtube-input{background:#ffffff1a;border:1px solid #fff3;border-radius:.75rem;color:#fff;font-size:1rem;margin-bottom:1rem;padding:.8rem 1rem;transition:border-color .2s ease;width:100%}.youtube-upload .youtube-input:focus{border-color:#667eea;outline:none}.metadata-fields{display:flex;flex:1 1;flex-direction:column;gap:.75rem}.metadata-fields label{color:#cbd5e0;display:flex;flex-direction:column;font-size:.9rem}select{-webkit-appearance:none;appearance:none;background:#ffffff1a;border:1px solid #fff3;color:#fff;cursor:pointer;margin-top:.25rem;padding:.5rem .75rem;transition:border-color .2s ease}select:focus{border-color:#667eea;outline:none}option{background:#1a202c;color:#fff;padding:.5rem}.metadata-fields input{background:#ffffff1a;border:1px solid #fff3;border-radius:.5rem;color:#fff;margin-top:.25rem;padding:.5rem .75rem;transition:border-color .2s ease}.metadata-fields input:focus{border-color:#667eea;outline:none}.youtube-upload .submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:.75rem;color:#fff;cursor:pointer;font-weight:600;margin-top:1rem;padding:.75rem 1.25rem;transition:transform .2s ease,box-shadow .2s ease}.youtube-upload .submit-btn:hover{box-shadow:0 6px 15px #00000059;transform:translateY(-2px)}.error-message{color:#fc8181;font-size:.9rem;margin-top:.5rem}.metadata-preview{background:#ffffff0d;border-radius:.75rem;display:flex;flex-direction:column;gap:1rem;margin-top:1rem;padding:1rem}.thumbnail-section{text-align:center}.thumbnail-section h4{color:#e2e8f0;font-size:1rem;font-weight:500;margin-bottom:.5rem}.thumbnail-section .thumbnail{border-radius:.75rem;box-shadow:0 4px 12px #00000059;display:block;margin:0 auto;max-height:320px;max-width:350px;object-fit:cover;width:100%}.submit-btn{margin-top:.5rem;width:100%}.error-message{background:#fdecea;border:1px solid #f5c2c0;border-radius:.5rem;color:#b00020}.error-message,.success-message{margin-bottom:1rem;padding:.75rem}.success-message{background:#d1e7dd;border:1px solid #badbcc;border-radius:.5rem;color:#0f5132}label{display:block;font-weight:500;margin:1rem 0}select{border:1px solid #ccc;border-radius:.5rem;font-size:1rem;padding:.5rem;width:100%}.playlist-preview{display:flex;flex-direction:column;gap:1rem;margin-top:1rem;max-height:400px;overflow-y:auto}.song-item{align-items:center;transition:box-shadow .2s}.song-item:hover{box-shadow:0 2px 8px #0000000d}.remove-btn:hover{background:#d9363e}button[type=submit]{background:#1e90ff;border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:1rem;padding:.75rem;transition:background .2s;width:100%}button[type=submit]:hover{background:#0074e4}button[disabled]{cursor:not-allowed;opacity:.6}.song-item{align-items:flex-start;background:#fafafa;border:1px solid #eee;border-radius:.75rem;display:flex;flex-wrap:wrap;gap:1rem;padding:.75rem}.thumbnail{border-radius:.5rem;flex-shrink:0;height:80px;object-fit:cover;width:80px}.song-fields{display:flex;flex:1 1;flex-direction:column;gap:.5rem;min-width:150px}.song-fields input{border:1px solid #ccc;border-radius:.5rem;font-size:.9rem;padding:.5rem;width:100%}.remove-btn{align-self:center;background:#ff4d4f;border:none;border-radius:.5rem;color:#fff;cursor:pointer;padding:.5rem .75rem;transition:background .2s}@media (max-width:600px){.song-item{align-items:stretch;flex-direction:column}.thumbnail{height:auto;width:100%}.remove-btn{align-self:flex-end}}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{background-color:#282c34;color:#fff;padding:20px}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.6e82442e.css.map*/