@import"https://fonts.googleapis.com/css2?family=Fredoka+One:wght@400&family=Ubuntu:wght@300;400;700&display=swap";:root{font-family: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}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--groove-purple: #6a0572;--groove-pink: #a663cc;--groove-orange: #ff6b35;--groove-yellow: #f7b801;--groove-cyan: #00a8cc;--groove-dark: #1a1a2e;--groove-darker: #16213e;--groove-light: #eee2ff;--shadow-glow: 0 0 20px rgba(166, 99, 204, .3);--shadow-card: 0 8px 25px rgba(0, 0, 0, .2)}*{margin:0;padding:0;box-sizing:border-box}html{width:100%;overflow-x:hidden}#root{width:100%}body{font-family:Ubuntu,sans-serif;background:linear-gradient(135deg,var(--groove-dark) 0%,var(--groove-darker) 100%);color:var(--groove-light);min-height:100vh;overflow-x:hidden;width:100vw;margin:0;padding:0}.app{min-height:100vh;width:100%;max-width:100vw;padding:20px;margin:0 auto;background:radial-gradient(circle at 20% 80%,var(--groove-purple) 0%,transparent 50%),radial-gradient(circle at 80% 20%,var(--groove-cyan) 0%,transparent 50%),radial-gradient(circle at 40% 40%,var(--groove-pink) 0%,transparent 50%);position:relative;overflow-x:hidden}.app:before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.02'%3E%3Ccircle cx='30' cy='30' r='4'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") repeat;pointer-events:none}.app-header{text-align:center;margin-bottom:40px;position:relative;z-index:1;width:100%;max-width:100%}.app-title{font-family:Fredoka One,cursive;font-size:clamp(2rem,8vw,3.5rem);background:linear-gradient(45deg,var(--groove-yellow),var(--groove-orange),var(--groove-pink));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:10px;text-shadow:2px 2px 4px rgba(0,0,0,.3);animation:glow 3s ease-in-out infinite alternate;word-wrap:break-word}@keyframes glow{0%{filter:drop-shadow(0 0 5px rgba(166,99,204,.5))}to{filter:drop-shadow(0 0 15px rgba(166,99,204,.8))}}.app-subtitle{font-size:clamp(1rem,3vw,1.2rem);color:var(--groove-light);opacity:.8;font-weight:300;margin-bottom:15px;word-wrap:break-word}.credits{margin-bottom:20px;width:100%;display:flex;justify-content:center}.credits-text{display:inline-block;font-size:clamp(.8rem,2.5vw,.95rem);font-weight:400;color:var(--groove-light);opacity:.7;position:relative;padding:8px 20px;border-radius:20px;background:linear-gradient(135deg,#a663cc33,#00a8cc33);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:all .3s ease;cursor:default;text-align:center;white-space:nowrap}.credits-text:before{content:"✨";margin-right:8px;animation:sparkle 2s ease-in-out infinite}.credits-text:hover{opacity:1;transform:translateY(-2px);box-shadow:0 4px 15px #a663cc4d}@keyframes sparkle{0%,to{transform:scale(1) rotate(0);opacity:.7}50%{transform:scale(1.1) rotate(180deg);opacity:1}}.empty-state{margin:20px auto;padding:20px;background:#ffffff1a;border-radius:15px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);max-width:500px;width:100%}.empty-state p{color:var(--groove-light);opacity:.8;text-align:center}.error-banner{background:linear-gradient(135deg,#ff4757,#ff6b8a);color:#fff;padding:15px 20px;margin:20px auto;max-width:90%;width:100%;border-radius:15px;display:flex;align-items:center;gap:15px;box-shadow:0 4px 15px #ff47574d;animation:slideIn .3s ease-out;position:relative;z-index:2}@keyframes slideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.error-icon{font-size:1.2rem;flex-shrink:0}.error-text{flex:1;font-weight:500;word-wrap:break-word}.error-close{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s;flex-shrink:0}.error-close:hover{background-color:#fff3}.music-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(280px,100%),1fr));gap:25px;max-width:1200px;width:100%;margin:0 auto;padding:0 10px 120px;position:relative;z-index:1;justify-items:center}.song-card{background:linear-gradient(145deg,#ffffff1a,#ffffff0d);border-radius:20px;padding:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow-card);transition:all .3s cubic-bezier(.25,.46,.45,.94);position:relative;overflow:hidden;width:100%;max-width:320px}.song-card:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s}.song-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:var(--shadow-glow),var(--shadow-card)}.song-card:hover:before{left:100%}.song-card.playing{border:2px solid var(--groove-yellow);box-shadow:0 0 30px #f7b80166,var(--shadow-card);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 0 30px #f7b80166,var(--shadow-card)}50%{box-shadow:0 0 40px #f7b80199,var(--shadow-card)}}.song-cover{width:100%;height:180px;margin-bottom:15px;border-radius:15px;overflow:hidden;position:relative}.song-cover img{width:100%;height:100%;object-fit:cover}.placeholder-cover{width:100%;height:100%;background:linear-gradient(135deg,var(--groove-purple),var(--groove-pink));display:flex;align-items:center;justify-content:center;position:relative}.musical-note{font-size:4rem;color:#fffc;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.song-info{margin-bottom:15px;text-align:center}.song-name{font-size:1.3rem;font-weight:700;color:var(--groove-light);margin-bottom:8px;line-height:1.3;word-wrap:break-word}.song-duration{color:var(--groove-light);opacity:.7;font-size:.9rem;font-weight:300;margin-bottom:4px}.song-file{color:var(--groove-light);opacity:.5;font-size:.8rem;font-weight:300;font-family:Ubuntu,monospace;word-wrap:break-word;word-break:break-all}.play-button{width:60px;height:60px;border-radius:50%;border:none;background:linear-gradient(135deg,var(--groove-orange),var(--groove-yellow));color:#fff;font-size:1.5rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #ff6b354d;display:flex;align-items:center;justify-content:center;margin:0 auto}.play-button:hover{transform:scale(1.1);box-shadow:0 6px 20px #ff6b3580}.play-button.playing{background:linear-gradient(135deg,var(--groove-pink),var(--groove-purple));animation:rotate 3s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.player-bar{position:fixed;bottom:0;left:0;right:0;width:100%;background:linear-gradient(135deg,#1a1a2ef2,#16213ef2);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.1);padding:20px;z-index:1000;box-sizing:border-box}.player-info{text-align:center;margin-bottom:15px;width:100%}.now-playing{font-size:1.1rem;font-weight:600;color:var(--groove-yellow);word-wrap:break-word}.player-controls{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:15px;width:100%;flex-wrap:wrap}.control-button{width:50px;height:50px;border-radius:50%;border:none;background:linear-gradient(135deg,var(--groove-cyan),var(--groove-purple));color:#fff;font-size:1.2rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.control-button:hover{transform:scale(1.1)}.time-info{color:var(--groove-light);font-family:Ubuntu,monospace;font-size:.9rem;white-space:nowrap}.progress-container{width:100%;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden;margin:0 auto;max-width:600px}.progress-bar{height:100%;background:linear-gradient(90deg,var(--groove-cyan),var(--groove-pink));transition:width .1s ease;border-radius:3px}@media (max-width: 768px){.app{padding:15px}.music-grid{grid-template-columns:1fr;gap:20px;padding:0 0 120px}.song-card{max-width:100%}.player-bar{padding:15px}.player-controls{gap:15px}.error-banner{margin:15px auto;padding:12px 15px;max-width:95%}.credits-text{padding:6px 16px}}@media (max-width: 480px){.app{padding:10px}.song-cover{height:150px}.song-name{font-size:1.1rem}.error-banner{flex-direction:column;text-align:center;gap:10px;margin:10px auto;max-width:95%}.credits-text{padding:5px 14px;white-space:normal;word-wrap:break-word}.player-controls{gap:10px}.time-info{font-size:.8rem}.music-grid{gap:15px}}@media (max-width: 360px){.app{padding:8px}.song-card{padding:15px}.player-bar{padding:12px}.credits-text{padding:4px 12px;font-size:.75rem}}
