:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;background-color:#0f0f0f;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}.playlist-creator{padding:1rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.05)}.btn-create-playlist{width:100%;padding:.875rem;background-color:var(--accent-primary);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s;box-shadow:0 4px 12px #1db9544d}.btn-create-playlist:hover{background-color:var(--accent-hover);transform:translateY(-1px);box-shadow:0 6px 16px #1db95466}.playlist-form{display:flex;flex-direction:column;gap:.75rem}.playlist-input{padding:.875rem;background-color:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text-primary);font-size:1rem}.playlist-input:focus{outline:none;border-color:var(--accent-primary);background-color:#ffffff1a}.form-buttons{display:flex;gap:.5rem}.playlist-list{flex:1;overflow-y:auto;padding:1rem 1.5rem}.playlist-list h3{margin-bottom:1rem;font-size:.875rem;color:#fff9;text-transform:uppercase;letter-spacing:1px;font-weight:700}.playlists{display:flex;flex-direction:column;gap:.5rem}.playlist-item{display:flex;align-items:center;justify-content:space-between;padding:1rem;background-color:transparent;border-radius:8px;cursor:pointer;transition:all .2s;border:1px solid transparent}.playlist-item:hover{background-color:#ffffff0d;border-color:#ffffff1a}.playlist-item.active{border-color:var(--accent-primary);background-color:#1db9541a;box-shadow:0 4px 12px #0003}.playlist-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.playlist-name{font-weight:600;color:var(--text-primary)}.playlist-count{font-size:.875rem;color:#fff9}.confirm-modal-overlay{position:fixed;inset:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.confirm-modal-container{background-color:var(--bg-secondary);border-radius:16px;border:1px solid var(--border-color);box-shadow:0 8px 32px #00000080;max-width:420px;width:90%;max-height:90vh;overflow:hidden;position:relative;animation:slideUp .3s ease;display:flex;flex-direction:column}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.confirm-modal-close{position:absolute;top:1rem;right:1rem;width:32px;height:32px;border-radius:8px;background-color:transparent;border:none;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:1}.confirm-modal-close:hover{background-color:var(--bg-hover);color:var(--text-primary)}.confirm-modal-content{padding:2.5rem 2rem 2rem;flex:1}.confirm-modal-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 .75rem;line-height:1.3}.confirm-modal-message{font-size:1rem;color:var(--text-secondary);margin:0;line-height:1.5}.confirm-modal-actions{padding:1rem 2rem 2rem;display:flex;gap:.75rem;border-top:1px solid var(--border-color);background-color:var(--bg-tertiary)}.confirm-modal-button{flex:1;padding:.75rem 1.5rem;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:1px solid transparent}.confirm-modal-button-cancel{background-color:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-color)}.confirm-modal-button-cancel:hover{background-color:var(--bg-hover);border-color:var(--border-color)}.confirm-modal-button-confirm{color:#fff}.confirm-modal-button-primary{background-color:var(--accent-primary)}.confirm-modal-button-primary:hover{background-color:var(--accent-hover)}.confirm-modal-button-danger{background-color:var(--danger)}.confirm-modal-button-danger:hover{background-color:#e53935;box-shadow:0 4px 12px #f443364d}.confirm-modal-button:active{transform:scale(.98)}@media(max-width:480px){.confirm-modal-container{width:95%;max-width:none;border-radius:12px}.confirm-modal-content{padding:2rem 1.5rem 1.5rem}.confirm-modal-title{font-size:1.25rem}.confirm-modal-message{font-size:.9375rem}.confirm-modal-actions{padding:1rem 1.5rem 1.5rem;flex-direction:column-reverse}.confirm-modal-button{width:100%}}.confirm-modal-button:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.confirm-modal-close:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.track-uploader-simple{display:flex;gap:1rem;padding:1rem 1.5rem;background-color:#1a1a1a99;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.05);flex-shrink:0}.upload-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background-color:var(--accent-primary);color:#fff;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s;white-space:nowrap;box-shadow:0 4px 12px #1db9544d}.upload-btn:hover:not(.disabled){background-color:var(--accent-hover);transform:translateY(-1px);box-shadow:0 6px 16px #1db95466}.upload-btn.disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.youtube-inline{flex:1;display:flex;align-items:center;gap:.75rem;background-color:#ffffff0d;padding:.5rem 1rem;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.youtube-inline svg{color:#fff9;flex-shrink:0}.youtube-inline input{flex:1;background:none;border:none;color:var(--text-primary);font-size:.95rem;outline:none}.youtube-inline input::placeholder{color:#fff6}.youtube-inline button{padding:.5rem 1rem;background-color:var(--accent-primary);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;font-size:.875rem;transition:all .2s;white-space:nowrap}.youtube-inline button:hover:not(:disabled){background-color:var(--accent-hover)}.youtube-inline button:disabled,.youtube-inline input:disabled{opacity:.6;cursor:not-allowed}@media(max-width:960px){.track-uploader-simple{flex-direction:column;align-items:stretch;padding:1rem}.upload-btn{width:100%;justify-content:center}.youtube-inline{width:100%}}.track-list{flex:1;overflow-y:auto;padding:.75rem;min-height:0}@media(max-width:768px){.track-list{padding-bottom:1rem}}.track-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;margin-bottom:.4rem;background-color:#ffffff08;border-radius:8px;border:1px solid rgba(255,255,255,.05);cursor:pointer;transition:all .2s;position:relative;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.track-item:hover{background-color:#ffffff14;border-color:#ffffff1a;transform:translate(2px)}.track-item.playing{background:linear-gradient(135deg,#667eea26,#764ba226);border-color:var(--accent-primary);box-shadow:0 4px 12px #1db95426}.track-item.pending{opacity:.7;cursor:not-allowed;background-color:#ffffff05}.track-item.pending:hover{background-color:#ffffff05;border-color:#ffffff0d;transform:none}.track-item.pending:hover .play-indicator{color:var(--text-secondary)}.play-indicator{width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:#fff6;transition:all .2s;flex-shrink:0}.track-item.playing .play-indicator{color:var(--accent-primary);filter:drop-shadow(0 0 4px rgba(29,185,84,.4))}.track-item:hover .play-indicator{color:var(--accent-primary)}.track-info{flex:1;min-width:0}.track-title{display:flex;align-items:center;gap:.4rem;margin-bottom:.15rem}.track-name{font-weight:600;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff}.track-item.playing .track-name{color:var(--accent-primary)}.track-meta{font-size:.75rem;color:#fff9}.track-status{font-size:.7rem;color:#ffc107e6;margin-top:.35rem;display:block;font-style:italic}.progress-bar{position:relative;width:100%;height:4px;background-color:#ffffff1a;border-radius:2px;overflow:hidden;margin-top:.35rem}.progress-bar-fill{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:2px;transition:width .3s ease;box-shadow:0 0 8px #667eea80;max-width:100%}.badge.success{padding:.15rem .4rem;font-size:.65rem;background-color:#1db95433;color:var(--accent-primary);border-radius:3px;font-weight:700;border:1px solid rgba(29,185,84,.3)}.badge.processing{padding:.15rem .4rem;font-size:.65rem;background-color:#ffc10733;color:#ffc107;border-radius:3px;font-weight:700;border:1px solid rgba(255,193,7,.3)}.delete-btn{opacity:0;transition:opacity .2s;color:#fff6}.track-item:hover .delete-btn{opacity:1}.delete-btn:hover{color:var(--danger);background-color:#f443361a}.track-name-display{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.edit-btn{opacity:0;transition:opacity .2s,background-color .2s;color:#ffffff80;padding:.25rem;flex-shrink:0}.track-item:hover .edit-btn{opacity:1}.edit-btn:hover{color:var(--accent-primary);background-color:#1db9541a}.track-name-edit{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.track-name-input{flex:1;min-width:0;padding:.4rem .6rem;background-color:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#fff;font-size:.95rem;font-weight:600;outline:none;transition:all .2s}.track-name-input:focus{background-color:#ffffff26;border-color:var(--accent-primary);box-shadow:0 0 0 2px #1db95433}.save-btn{color:var(--accent-primary);transition:all .2s;padding:.25rem;flex-shrink:0}.save-btn:hover{background-color:#1db95433;color:var(--accent-primary);transform:scale(1.1)}.cancel-btn{color:#fff9;transition:all .2s;padding:.25rem;flex-shrink:0}.cancel-btn:hover{background-color:#ffffff1a;color:#fff;transform:scale(1.1)}.lyrics-panel{position:fixed;top:50%;right:2rem;transform:translateY(-50%);width:400px;max-height:70vh;background:linear-gradient(135deg,#1a1a1af2,#141414eb);-webkit-backdrop-filter:blur(30px) saturate(180%);backdrop-filter:blur(30px) saturate(180%);border:1px solid rgba(255,255,255,.1);border-radius:16px;box-shadow:0 8px 32px #0009;display:flex;flex-direction:column;z-index:200;transition:all .4s cubic-bezier(.4,0,.2,1);animation:slideInRight .4s cubic-bezier(.4,0,.2,1)}.lyrics-panel.expanded{position:fixed!important;inset:0!important;width:100vw!important;height:100vh!important;max-height:100vh!important;transform:none!important;border-radius:0!important;border:none!important;z-index:2000!important;background:linear-gradient(135deg,#0a0a0afa,#050505f2);margin:0!important}@keyframes slideInRight{0%{opacity:0;transform:translateY(-50%) translate(100px)}to{opacity:1;transform:translateY(-50%) translate(0)}}.lyrics-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.lyrics-panel.expanded .lyrics-header{padding:1.5rem 2rem;background:#0003}.lyrics-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.lyrics-panel.expanded .lyrics-header h3{font-size:1.5rem}.lyrics-actions{display:flex;align-items:center;gap:.5rem}.btn-icon{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#ffffffb3;cursor:pointer;padding:.5rem;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-icon:hover{background:#ffffff1a;color:var(--text-primary);transform:scale(1.05)}.lyrics-controls{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.05);flex-shrink:0}.lyrics-panel.expanded .lyrics-controls{padding:1rem 2rem;justify-content:center;background:#0000001a}.lyrics-controls label{font-size:.75rem;font-weight:600;color:#fff9;min-width:90px}.opacity-slider{flex:1;height:4px;border-radius:2px;background:#ffffff1a;outline:none;-webkit-appearance:none;appearance:none;cursor:pointer}.lyrics-panel.expanded .opacity-slider{max-width:300px}.opacity-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent-primary);cursor:pointer;transition:all .2s;box-shadow:0 0 8px #1db95466}.opacity-slider::-webkit-slider-thumb:hover{background:var(--accent-hover);transform:scale(1.15)}.opacity-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent-primary);cursor:pointer;border:none;transition:all .2s;box-shadow:0 0 8px #1db95466}.opacity-slider::-moz-range-thumb:hover{background:var(--accent-hover);transform:scale(1.15)}.opacity-value{font-size:.75rem;font-weight:600;color:var(--accent-primary);min-width:40px;text-align:right}.lyrics-content{flex:1;overflow-y:auto;padding:1.5rem 1.25rem;scroll-behavior:smooth;text-align:center}.lyrics-panel.expanded .lyrics-content{padding:4rem 2rem;display:block}.lyrics-content-inner{min-height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center}.lyrics-content.empty{display:flex;align-items:center;justify-content:center}.no-lyrics-message{text-align:center;color:#ffffff80;font-size:.875rem;font-style:italic;margin:0;padding:2rem 1rem}.lyrics-panel.expanded .no-lyrics-message{font-size:1.5rem}.lyrics-line{margin:0;padding:.5rem 0;font-size:.95rem;line-height:1.6;color:#fff6;transition:all .3s ease;cursor:default;border-radius:8px}.lyrics-line:hover{background:#ffffff08;color:#fff9}.lyrics-line.active{color:var(--accent-primary);font-weight:700;font-size:1.2rem;transform:scale(1.05);text-shadow:0 0 20px rgba(29,185,84,.6);margin:1rem 0}.lyrics-line.past{color:#fff3;filter:blur(.5px)}.lyrics-panel.expanded .lyrics-line{font-size:1.8rem;padding:1rem 0;line-height:1.5;max-width:800px;margin-left:auto;margin-right:auto}.lyrics-panel.expanded .lyrics-line.active{font-size:2.8rem;margin:2.5rem auto;transform:scale(1.05);color:#fff;text-shadow:0 0 30px var(--accent-primary),0 0 60px rgba(29,185,84,.4)}.lyrics-panel.expanded .lyrics-line.past{font-size:1.5rem;opacity:.3}.lyrics-content::-webkit-scrollbar{width:6px}.lyrics-content::-webkit-scrollbar-track{background:#0003;border-radius:3px}.lyrics-content::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.lyrics-content::-webkit-scrollbar-thumb:hover{background:#ffffff40}@media(max-width:960px){.lyrics-panel{right:1rem;left:1rem;width:auto;max-height:60vh}}@media(max-width:768px){.lyrics-panel{top:auto;bottom:100px;transform:none;max-height:50vh;animation:slideInUp .4s cubic-bezier(.4,0,.2,1)}.lyrics-panel.expanded{animation:none!important;bottom:0!important;max-height:100vh!important}@keyframes slideInUp{0%{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}.lyrics-header h3{font-size:.9rem}.lyrics-controls{padding:.6rem 1rem}.lyrics-controls label{font-size:.7rem;min-width:80px}.lyrics-content{padding:1rem}.lyrics-line{font-size:.875rem}.lyrics-line.active{font-size:1rem}.lyrics-panel.expanded .lyrics-line{font-size:1.2rem}.lyrics-panel.expanded .lyrics-line.active{font-size:1.6rem;margin:1.5rem auto}}@media(max-width:480px){.lyrics-panel{right:.5rem;left:.5rem;bottom:90px;max-height:45vh}.lyrics-header{padding:.75rem 1rem}.lyrics-controls{flex-direction:column;align-items:flex-start;gap:.5rem}.lyrics-controls label{min-width:0}.opacity-slider{width:100%}}.chords-panel{position:fixed;bottom:100px;right:20px;width:350px;height:500px;background:#14141ed9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:16px;box-shadow:0 8px 32px #0000004d;z-index:9999;display:flex;flex-direction:column;transition:all .3s ease;color:#fff;overflow:hidden}.chords-panel.expanded{top:20px;bottom:100px;right:20px;width:400px;height:auto}@media(max-width:768px){.chords-panel{width:100%;left:0;right:0;bottom:0;border-radius:16px 16px 0 0;height:60vh}.chords-panel.expanded{top:0;height:100vh;width:100%;border-radius:0}}.chords-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid rgba(255,255,255,.1);background:#ffffff0d}.chords-header h3{margin:0;font-size:1.1rem;font-weight:600;color:#fff}.chords-actions{display:flex;gap:8px}.btn-icon{background:transparent;border:none;color:#ffffffb3;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-icon:hover{background:#ffffff1a;color:#fff}.chords-controls{padding:12px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid rgba(255,255,255,.05);font-size:.85rem;color:#ffffffb3}.opacity-slider{flex:1;height:4px;-webkit-appearance:none;background:#fff3;border-radius:2px;outline:none}.opacity-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:#4ecdc4;cursor:pointer;transition:transform .1s}.opacity-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.opacity-value{min-width:35px;text-align:right;font-variant-numeric:tabular-nums}.chords-content{flex:1;overflow-y:auto;padding:24px;text-align:center;scroll-behavior:smooth;position:relative}.chords-content.empty{display:flex;align-items:center;justify-content:center}.no-chords-message{color:#ffffff80;font-style:italic}.chord-item{padding:20px 0;transition:all .3s ease;opacity:.4;transform:scale(.9)}.chord-item.active{opacity:1;transform:scale(1.2);font-weight:700;color:#4ecdc4;text-shadow:0 0 20px rgba(78,205,196,.5)}.chord-item.past{opacity:.2}.chord-symbol{font-size:2.5rem;font-family:Inter,sans-serif;display:block}.chords-content::-webkit-scrollbar{width:6px}.chords-content::-webkit-scrollbar-track{background:#0000001a}.chords-content::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.chords-content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.audio-player{padding:.75rem 1rem;position:relative}.audio-player.mobile{padding:0}.player-content{width:100%}.player-content.hidden{display:none}.audio-player.empty{text-align:center;padding:1rem;color:#ffffff80}.player-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.05)}.player-header h2{font-size:1.1rem;flex:1;font-weight:600;color:#fff}.player-main-controls{display:flex;align-items:center;gap:.75rem}.player-header .btn-play{width:40px;height:40px;border-radius:50%;background-color:var(--accent-primary);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;box-shadow:0 0 12px #1db95466}.player-header .btn-play:hover:not(:disabled){background-color:var(--accent-hover);transform:scale(1.05);box-shadow:0 0 16px #1db95499}.player-header .btn-play:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.time-display{display:flex;align-items:center;gap:.35rem;font-size:.875rem;font-weight:600;color:var(--text-primary);min-width:90px}.time-current{color:var(--accent-primary)}.time-separator{color:#fff6;font-size:.75rem}.time-total{color:#fff9}.btn-lyrics{width:36px;height:36px;border-radius:8px;background-color:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#ffffffb3;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.btn-lyrics:hover{background-color:#ffffff1a;color:var(--accent-primary);border-color:var(--accent-primary);transform:scale(1.05)}.btn-lyrics:active{transform:scale(.98)}.control-btn{width:36px;height:36px;border-radius:8px;background-color:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#ffffffb3;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.control-btn:hover{background-color:#ffffff1a;color:var(--accent-primary);border-color:var(--accent-primary);transform:scale(1.05)}.control-btn.active{background-color:var(--accent-primary);color:#fff;border-color:var(--accent-primary);box-shadow:0 0 10px #1db9544d}.control-btn:active{transform:scale(.98)}.progress-section{margin-bottom:.75rem;padding:0}.progress-bar-container{width:100%;padding:.5rem 0;cursor:pointer}.progress-bar-bg{position:relative;width:100%;height:6px;background-color:#ffffff1a;border-radius:3px;overflow:visible;transition:height .2s}.progress-bar-container:hover .progress-bar-bg{height:8px}.progress-bar-container .progress-bar-fill{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-hover));border-radius:4px;transition:width .1s linear;z-index:1;box-shadow:0 0 8px #1db95480}.progress-bar-handle{position:absolute;top:50%;transform:translate(-50%,-50%);width:16px;height:16px;background-color:#fff;border:2px solid var(--accent-primary);border-radius:50%;box-shadow:0 2px 8px #0000004d;opacity:0;transition:opacity .2s;pointer-events:none;z-index:2}.progress-bar-container:hover .progress-bar-handle{opacity:1}.progress-bar-bg:active .progress-bar-handle{transform:translate(-50%,-50%) scale(1.2)}.loading-state{text-align:center;padding:1rem;color:#fff9;font-size:.875rem}.loading-state .text-small{margin-top:.25rem;font-size:.75rem;opacity:.7}.controls-container{display:flex;flex-direction:column;gap:.5rem}.controls-row{display:flex;gap:.75rem}.master-volume-compact{flex:1;display:flex;align-items:center;gap:.5rem;padding:.4rem .6rem;background-color:#ffffff0d;border-radius:4px;border:1px solid rgba(255,255,255,.05)}.control-label{font-size:.75rem;font-weight:600;color:var(--accent-primary);min-width:85px}.stems-row{display:grid;grid-template-columns:repeat(2,1fr);gap:.4rem}.stem-compact{display:flex;align-items:center;gap:.4rem;padding:.4rem .6rem;background-color:#ffffff0d;border-radius:4px;border:1px solid rgba(255,255,255,.05)}.stem-label{display:flex;align-items:center;gap:.5rem;min-width:65px;font-size:.75rem;font-weight:600;color:#ffffffe6}.stem-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.stem-color{width:8px;height:8px;border-radius:50%;flex-shrink:0}.btn-mute{background:none;border:none;color:#ffffff80;cursor:pointer;padding:.25rem;display:flex;align-items:center;transition:color .2s;flex-shrink:0}.btn-mute:hover{color:var(--text-primary)}.volume-icon{color:#ffffff80;flex-shrink:0}.volume-slider{flex:1;height:4px;border-radius:2px;background:#0000004d;outline:none;-webkit-appearance:none;appearance:none;min-width:100px}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent-primary);cursor:pointer;transition:all .2s;box-shadow:0 0 8px #1db95466}.volume-slider::-webkit-slider-thumb:hover{background:var(--accent-hover);transform:scale(1.1)}.volume-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent-primary);cursor:pointer;border:none;transition:all .2s;box-shadow:0 0 8px #1db95466}.volume-slider::-moz-range-thumb:hover{background:var(--accent-hover);transform:scale(1.1)}.volume-slider:disabled{opacity:.3;cursor:not-allowed}.volume-value{font-size:.75rem;color:#fff9;font-weight:600;min-width:30px;text-align:right;flex-shrink:0}.player-info{margin-top:.5rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.05);display:flex;align-items:center;justify-content:center;gap:1rem;font-size:.75rem;color:#ffffff80}.track-metadata{display:flex;align-items:center;gap:.75rem}.track-duration,.track-stems{color:#fff9;font-size:.75rem;font-weight:500}.disclaimer{color:#fff6;font-size:.7rem;text-align:center;font-style:italic;opacity:.7}.player-footer{position:fixed;bottom:0;left:0;right:0;background-color:#1a1a1ad9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.05);flex-shrink:0;z-index:100;box-shadow:0 -4px 20px #0006}@media(max-width:768px){.player-footer{max-height:none}.player-footer .audio-player.mobile:not(.expanded){max-height:70px}}.loading-stems{text-align:center;padding:1rem;color:#fff9;font-size:.875rem;background-color:#1a1a1ad9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.05)}.divider{height:1px;background-color:#ffffff0d;margin:.25rem 0}.metronome-controls{flex-direction:column;background-color:#ffffff0d;border-radius:4px;padding:.6rem;border:1px solid rgba(255,255,255,.05);gap:.5rem}.metronome-header{display:flex;align-items:center}.metronome-actions{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;width:100%;overflow:hidden}.btn-metronome{width:32px;height:32px;border-radius:6px;background-color:#ffffff1a;border:1px solid rgba(255,255,255,.1);color:#ffffff80;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.btn-metronome:hover{background-color:#ffffff26;color:var(--text-primary)}.btn-metronome.active{background-color:var(--accent-primary);color:#fff;border-color:var(--accent-primary);box-shadow:0 0 10px #1db9544d}.metronome-slider-group{display:flex;align-items:center;gap:.5rem;flex:1;min-width:120px;max-width:100%;overflow:hidden}.icon-small{color:#ffffff80;flex-shrink:0}.bpm-slider{flex:1;height:4px;border-radius:2px;background:#0000004d;outline:none;-webkit-appearance:none;appearance:none;min-width:80px}.bpm-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:var(--accent-primary);cursor:pointer;transition:all .2s}.bpm-slider::-webkit-slider-thumb:hover{background:var(--accent-hover);transform:scale(1.1)}.bpm-slider::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:var(--accent-primary);cursor:pointer;border:none;transition:all .2s}.bpm-value{font-size:.75rem;color:#fff9;font-weight:600;min-width:55px;max-width:70px;text-align:right;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:960px){.player-footer{margin-left:0;max-height:60vh;overflow-y:auto}.player-header{flex-direction:column;align-items:flex-start;gap:.75rem}.player-main-controls{width:100%;justify-content:space-between}.audio-player{padding:.85rem}.controls-container{padding:.75rem}.master-volume-compact{display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:auto auto;gap:.5rem;padding:.65rem}.control-label{grid-column:1 / -1;grid-row:1;width:100%;min-width:0;text-align:left;margin-bottom:.25rem}.master-volume-compact .volume-icon{grid-column:1;grid-row:2}.master-volume-compact .volume-slider{grid-column:2;grid-row:2;min-width:0}.master-volume-compact .volume-value{grid-column:3;grid-row:2}.stems-row{gap:.5rem}.stem-compact{display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:auto auto;gap:.5rem;align-items:center;padding:.65rem}.stem-label{grid-column:1;grid-row:1;min-width:0}.stem-compact .btn-mute{grid-column:2;grid-row:1;justify-self:end}.stem-compact .volume-slider{grid-column:1 / 3;grid-row:2;width:100%;min-width:0}.stem-compact .volume-value{grid-column:3;grid-row:2}}@media(max-width:480px){.player-footer{max-height:55vh}.audio-player{padding:.75rem}.controls-container,.stem-compact,.master-volume-compact{padding:.5rem}}.mini-player{display:none}@media(max-width:768px){.audio-player.mobile{padding:0}.mini-player{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background-color:#1a1a1af2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.1);cursor:pointer;transition:all .3s ease}.mini-player:active{background-color:#1a1a1afa}.btn-play-mini{width:36px;height:36px;border-radius:50%;background-color:var(--accent-primary);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;box-shadow:0 0 12px #1db95466}.btn-play-mini:hover:not(:disabled){background-color:var(--accent-hover);transform:scale(1.05);box-shadow:0 0 16px #1db95499}.btn-play-mini:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.mini-player-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.mini-player-title{font-size:.9rem;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.mini-player-time{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:#fff9}.btn-expand{background:none;border:none;color:#ffffffb3;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.btn-expand:hover{color:var(--accent-primary)}.btn-collapse{background:none;border:none;color:#ffffffb3;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;position:absolute;top:.5rem;right:.5rem}.btn-collapse:hover{color:var(--accent-primary)}.audio-player.mobile.expanded .player-content{display:block;max-height:70vh;overflow-y:auto;padding:.75rem 1rem}.audio-player.mobile.expanded .player-header{padding-right:3rem}.audio-player.mobile:not(.expanded) .player-content{display:none}.metronome-controls{padding:.5rem}.metronome-actions{gap:.75rem;flex-wrap:wrap}.metronome-slider-group{min-width:100px;max-width:100%}.bpm-value{min-width:50px;max-width:60px;font-size:.7rem}.control-label{font-size:.7rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}}.payment-modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease-out}.payment-modal{background:#14141ef2;border:1px solid rgba(255,255,255,.1);border-radius:20px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.payment-modal-header{padding:30px 30px 20px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center}.payment-modal-header h2{margin:0;font-size:24px;font-weight:600;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.payment-modal-close{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;color:#ffffffb3}.payment-modal-close:hover{background:#ffffff1a;color:#fff;transform:rotate(90deg)}.payment-modal-body{padding:30px}.plan-summary{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:20px;margin-bottom:30px}.plan-summary h3{margin:0 0 10px;font-size:20px;color:#fff}.plan-summary .plan-price{font-size:32px;font-weight:700;color:#667eea;margin:10px 0}.plan-summary .plan-description{color:#fff9;font-size:14px;margin:10px 0 0}.payment-methods{display:flex;gap:15px;margin-bottom:30px}.payment-method-btn{flex:1;padding:15px;background:#ffffff08;border:2px solid rgba(255,255,255,.1);border-radius:12px;color:#fff9;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.payment-method-btn:hover{background:#ffffff0d;border-color:#fff3}.payment-method-btn.active{background:linear-gradient(135deg,#667eea33,#764ba233);border-color:#667eea;color:#fff}.payment-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:#fffc;font-size:14px;font-weight:500}.form-group input,.form-group select{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:12px 16px;color:#fff;font-size:16px;transition:all .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;background:#ffffff14}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:15px}.pix-container{display:flex;flex-direction:column;align-items:center;gap:20px;padding:20px}.qr-code-container{background:#fff;padding:20px;border-radius:12px;display:flex;flex-direction:column;align-items:center;gap:15px}.qr-code-container img{max-width:250px;width:100%;height:auto}.pix-code-container{width:100%;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:12px;display:flex;align-items:center;gap:10px}.pix-code-text{flex:1;color:#fffc;font-family:monospace;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.copy-btn{background:#667eea;border:none;border-radius:6px;padding:8px 16px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px}.copy-btn:hover{background:#5568d3;transform:translateY(-1px)}.copy-btn.copied{background:#10b981}.payment-status{text-align:center;padding:20px;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:12px}.payment-status.pending{border-color:#fbbf244d;background:#fbbf240d}.payment-status.success{border-color:#10b9814d;background:#10b9810d}.payment-status.error{border-color:#ef44444d;background:#ef44440d}.payment-status-icon{font-size:48px;margin-bottom:15px}.payment-status h3{margin:0 0 10px;font-size:20px;color:#fff}.payment-status p{margin:0;color:#ffffffb3;font-size:14px}.expiration-timer{text-align:center;color:#fbbf24;font-size:14px;margin-top:15px}.payment-actions{display:flex;gap:15px;margin-top:20px}.btn-payment{flex:1;padding:14px 24px;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.btn-payment-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-payment-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 30px #667eea4d}.btn-payment-primary:disabled{opacity:.5;cursor:not-allowed}.btn-payment-secondary{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#fffc}.btn-payment-secondary:hover{background:#ffffff14}.loading-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:12px 16px;color:#fca5a5;font-size:14px;margin-bottom:20px}@media(max-width:768px){.payment-modal{max-width:100%;margin:0;border-radius:20px 20px 0 0;max-height:95vh}.payment-modal-header,.payment-modal-body{padding:20px}.payment-methods{flex-direction:column}.form-row{grid-template-columns:1fr}.payment-actions{flex-direction:column}.qr-code-container img{max-width:200px}}.plans-container{position:relative;width:100%;height:100%;min-height:100%;display:flex;flex-direction:column;align-items:center;overflow:hidden;margin:0;padding:0}.plans-background{position:absolute;top:0;left:0;width:100%;height:100%;background-image:url(/icone-zabumba-300px.png);background-size:cover;background-position:center;background-repeat:no-repeat;z-index:0}.plans-background:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#0f0f0fe6,#0f0f0fb3,#0f0f0fcc);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1}.plans-content{position:relative;z-index:2;width:100%;max-width:1200px;padding:2rem;display:flex;flex-direction:column;align-items:center;gap:2rem;height:100%;overflow-y:auto}.plans-header{text-align:center;margin-bottom:1rem;display:flex;flex-direction:column;align-items:center;gap:.5rem}.plans-title{margin:0;line-height:1.2}.title-gradient{font-size:3.5rem;font-weight:800;background:linear-gradient(135deg,#fff,#a5b4fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 4px 20px rgba(0,0,0,.3);letter-spacing:-1px}.plans-subtitle{font-size:1.1rem;color:#ffffffb3;margin:0;font-weight:300}.plans-admin-actions{width:100%;display:flex;justify-content:flex-end;margin-bottom:1rem}.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;width:100%;padding-bottom:2rem}.plan-card{background:#ffffff08;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.05);border-radius:24px;padding:2.5rem;display:flex;flex-direction:column;gap:2rem;transition:all .3s ease;position:relative;overflow:hidden}.plan-card:hover{transform:translateY(-5px);background:#ffffff0d;border-color:#ffffff1a;box-shadow:0 20px 40px #0000004d}.plan-card.current-plan{border-color:var(--accent-primary);background:#1db9540d}.current-badge{position:absolute;top:1rem;right:1rem;background:var(--accent-primary);color:#000;font-size:.75rem;font-weight:700;padding:.25rem .75rem;border-radius:20px;text-transform:uppercase}.plan-header-card{text-align:center;display:flex;flex-direction:column;gap:1rem}.plan-header-card h3{font-size:1.5rem;font-weight:700;margin:0;color:#fff}.plan-price{display:flex;align-items:baseline;justify-content:center;gap:.25rem;color:#fff}.currency{font-size:1.25rem;font-weight:500;color:#fff9}.amount{font-size:3rem;font-weight:800;line-height:1}.period{font-size:1rem;color:#fff9}.plan-desc{font-size:.95rem;color:#fff9;margin:0;line-height:1.5}.plan-features{display:flex;flex-direction:column;gap:1rem;flex:1}.feature-item{display:flex;align-items:center;gap:.75rem;color:#fffc;font-size:.95rem}.check-icon{color:var(--accent-primary);flex-shrink:0}.plan-footer{display:flex;flex-direction:column;gap:1rem}.btn-plan{width:100%;padding:1rem;border-radius:12px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s;border:none}.btn-subscribe{background:#fff;color:#000}.btn-subscribe:hover:not(:disabled){background:#f0f0f0;transform:translateY(-2px)}.btn-cancel{background:#f443361a;color:var(--danger);border:1px solid rgba(244,67,54,.2)}.btn-cancel:hover:not(:disabled){background:#f4433633}.admin-controls{display:flex;justify-content:center;gap:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}.admin-controls button{background:none;border:none;color:#ffffff80;cursor:pointer;padding:.5rem;border-radius:8px;transition:all .2s}.admin-controls button:hover{background:#ffffff1a;color:#fff}.admin-controls .delete-btn{color:var(--danger, #ff4444)}.admin-controls .delete-btn:hover{background:#f443361a;color:#ff1744}.plans-loading,.plans-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:#fff9;z-index:2;position:relative}.plans-error{background:#f443361a;border:1px solid rgba(244,67,54,.2);color:#ff8a80;padding:1rem;border-radius:12px;width:100%;text-align:center}.plans-form-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem}.plans-form-container{background:#1a1a1a;border:1px solid rgba(255,255,255,.1);border-radius:24px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080}.plans-form-header{padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center}.plans-form-header h2{margin:0;font-size:1.25rem}.plans-form{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#fffc;font-size:.9rem}.form-group input,.form-group textarea{width:100%;padding:.75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-primary);background:#ffffff1a}.form-actions{display:flex;gap:1rem;margin-top:1rem}@media(max-width:768px){.plans-content{padding:1.5rem}.title-gradient{font-size:2.5rem}.plans-grid{grid-template-columns:1fr;max-width:400px}}@media(max-width:480px){.plans-content{padding:1rem}.title-gradient{font-size:2rem}}.playlist-drawer-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999;animation:fadeIn .3s ease-out}.playlist-drawer{position:fixed;top:0;right:-400px;width:400px;height:100%;background:#141414f2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-left:1px solid rgba(255,255,255,.1);box-shadow:-4px 0 24px #0000004d;z-index:1000;transition:right .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow:hidden}.playlist-drawer.open{right:0}.playlist-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1);background:#ffffff05}.playlist-drawer-header h2{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary);background:linear-gradient(135deg,#fff 0%,var(--accent-primary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.playlist-drawer-close{background:transparent;border:none;color:#ffffffb3;cursor:pointer;padding:.5rem;border-radius:8px;transition:all .2s;display:flex;align-items:center;justify-content:center}.playlist-drawer-close:hover{background:#ffffff1a;color:var(--text-primary)}.playlist-drawer-content{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:1rem}.playlist-drawer-content::-webkit-scrollbar{width:8px}.playlist-drawer-content::-webkit-scrollbar-track{background:#ffffff0d}.playlist-drawer-content::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.playlist-drawer-content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@media(max-width:768px){.playlist-drawer{width:100%;right:-100%}}@media(max-width:480px){.playlist-drawer-header{padding:1rem}.playlist-drawer-header h2{font-size:1.25rem}}.home-container{position:relative;width:100%;height:100%;min-height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;flex:1;margin:0;padding:0}.home-background{position:absolute;top:0;left:0;width:100%;height:100%;background-image:url(/icone-zabumba-300px.png);background-size:cover;background-position:center;background-repeat:no-repeat;z-index:0}.home-background:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#0f0f0fe6,#0f0f0fb3,#0f0f0fcc);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1}.home-content-wrapper{position:relative;z-index:2;width:100%;max-width:1200px;padding:2rem;display:flex;flex-direction:column;align-items:center;gap:4rem;height:100%;justify-content:center;overflow-y:auto}.home-hero{text-align:center;display:flex;flex-direction:column;align-items:center;gap:2rem;max-width:800px;animation:fadeInDown 1s ease-out}.home-title{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin:0}.title-gradient{font-size:5rem;font-weight:800;background:linear-gradient(135deg,#fff,#a5b4fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 10px 30px rgba(0,0,0,.5);letter-spacing:-2px;line-height:1.1}.title-subtitle{font-size:1.5rem;font-weight:300;color:var(--accent-primary);text-transform:uppercase;letter-spacing:4px;opacity:.9}.home-description{font-size:1.25rem;line-height:1.6;color:#fffc;margin:0;max-width:600px;font-weight:300}.home-actions{display:flex;gap:1.5rem;margin-top:1rem}.home-action-btn{padding:1rem 2.5rem;border-radius:50px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;gap:.75rem;border:none;position:relative;overflow:hidden}.primary-btn{background:var(--accent-primary);color:#000;box-shadow:0 4px 20px #1db95466}.primary-btn:hover{transform:translateY(-3px);box-shadow:0 8px 30px #1db95499;background:var(--accent-hover)}.secondary-btn{background:#ffffff1a;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.secondary-btn:hover{background:#fff3;transform:translateY(-3px);border-color:#fff6}.home-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;width:100%;animation:fadeInUp 1s ease-out .5s backwards}.feature-card{background:#ffffff08;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.05);padding:2rem;border-radius:20px;transition:all .3s ease;display:flex;flex-direction:column;gap:1rem;align-items:flex-start}.feature-card:hover{transform:translateY(-5px);background:#ffffff12;border-color:#ffffff1a;box-shadow:0 10px 40px #0003}.feature-icon{background:#1db9541a;color:var(--accent-primary);padding:12px;border-radius:12px;display:flex;align-items:center;justify-content:center}.feature-card h3{margin:0;font-size:1.25rem;font-weight:600;color:#fff}.feature-card p{margin:0;font-size:.95rem;color:#fff9;line-height:1.5}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.home-content-wrapper{padding:1.5rem;gap:3rem}.title-gradient{font-size:3.5rem}.title-subtitle{font-size:1.1rem}.home-description{font-size:1rem}.home-actions{flex-direction:column;width:100%;gap:1rem}.home-action-btn{width:100%;justify-content:center}.home-features{grid-template-columns:1fr}}@media(max-width:480px){.title-gradient{font-size:2.8rem}.home-hero{gap:1.5rem}}.login-container{position:relative;width:100%;height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;margin:0;padding:0}.login-background{position:absolute;top:0;left:0;width:100%;height:100%;background-image:url(/icone-zabumba-300px.png);background-size:cover;background-position:center;background-repeat:no-repeat;z-index:0}.login-background:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#0f0f0fe6,#0f0f0fb3,#0f0f0fcc);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1}.login-content{position:relative;z-index:2;width:100%;max-width:450px;padding:20px;animation:fadeInUp .8s ease-out}.login-card{background:#ffffff08;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.05);border-radius:24px;padding:3rem 2.5rem;box-shadow:0 20px 60px #0006;text-align:center;display:flex;flex-direction:column;gap:2.5rem}.login-header{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.logo-container{width:200px;height:200px;background:transparent;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:.5rem;position:relative;animation:float 3s ease-in-out infinite}.logo-container:before{content:"";position:absolute;width:100%;height:100%;border-radius:50%;background:radial-gradient(circle,rgba(165,180,252,.1) 0%,transparent 70%);animation:pulse 2s ease-in-out infinite;z-index:-1}.logo-wrapper{position:relative;width:200px;height:200px;display:flex;align-items:center;justify-content:center;overflow:visible}.logo-wrapper:before{content:"";position:absolute;width:120%;height:120%;border-radius:50%;background:radial-gradient(circle,rgba(165,180,252,.15) 0%,transparent 70%);animation:glow 3s ease-in-out infinite;z-index:-1;pointer-events:none}.login-logo{width:200px;height:200px;object-fit:contain;mix-blend-mode:multiply;filter:brightness(1.1) contrast(1.15) saturate(1.1) drop-shadow(0 8px 24px rgba(0,0,0,.5)) drop-shadow(0 0 30px rgba(165,180,252,.3)) drop-shadow(0 4px 12px rgba(0,0,0,.3));animation:logoMove 4s ease-in-out infinite;position:relative;z-index:1;image-rendering:auto;will-change:transform}@keyframes glow{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}@keyframes float{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-10px) rotate(2deg)}50%{transform:translateY(-5px) rotate(0)}75%{transform:translateY(-10px) rotate(-2deg)}}@keyframes logoMove{0%,to{transform:translateY(0) rotate(0) scale(1)}25%{transform:translateY(-8px) rotate(3deg) scale(1.02)}50%{transform:translateY(-4px) rotate(0) scale(1)}75%{transform:translateY(-8px) rotate(-3deg) scale(1.02)}}@keyframes pulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:.6;transform:scale(1.1)}}.login-title{margin:0;line-height:1.2}.title-gradient{font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,#fff,#a5b4fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 4px 20px rgba(0,0,0,.3);letter-spacing:-1px}.login-header p{margin:0;font-size:1rem;color:#ffffffb3;line-height:1.6;font-weight:300}.google-login-btn{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:16px 24px;font-size:16px;font-weight:600;color:#1a1a1a;background:#fff;border:none;border-radius:16px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #0000001a}.google-login-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #ffffff26;background:#f8f9fa}.google-login-btn:active{transform:translateY(0);box-shadow:0 2px 8px #0000001a}.google-icon{width:24px;height:24px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:480px){.login-card{padding:2rem 1.5rem}.logo-container,.login-logo{width:150px;height:150px}.title-gradient{font-size:2rem}.login-header p{font-size:.95rem}}.user-profile-container{position:absolute;bottom:0;left:0;right:0;background-color:var(--bg-secondary);border-top:1px solid var(--border-color)}.user-profile-header{width:100%;padding:1rem;display:flex;align-items:center;justify-content:space-between;gap:.75rem;background:none;border:none;cursor:pointer;transition:background-color .2s ease;color:var(--text-primary)}.user-profile-header:hover{background-color:var(--bg-hover)}.user-profile-info{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.user-profile-avatar{width:48px;height:48px;min-width:48px;min-height:48px;border-radius:50%;object-fit:cover;object-position:center;border:2px solid var(--accent-primary);box-shadow:0 2px 8px #1db95433;flex-shrink:0;display:block}.user-profile-avatar-placeholder{width:48px;height:48px;min-width:48px;min-height:48px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.user-profile-details{flex:1;min-width:0;text-align:left}.user-profile-name{font-size:.9375rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0 0 4px}.user-profile-email{font-size:.8125rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.user-profile-plan{font-size:.75rem;color:var(--accent-primary);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:4px 0 0}.user-profile-dropdown{border-top:1px solid var(--border-color);animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.user-profile-menu{padding:1rem;background-color:var(--bg-tertiary)}.user-profile-section{margin-bottom:1rem}.user-profile-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;color:var(--text-secondary);letter-spacing:.5px;margin:0 0 .75rem}.user-profile-section-content{background-color:var(--bg-secondary);border-radius:8px;padding:.75rem;border:1px solid var(--border-color)}.user-profile-field{display:flex;justify-content:space-between;align-items:baseline;padding:.5rem 0;gap:1rem}.user-profile-field:not(:last-child){border-bottom:1px solid var(--border-color)}.user-profile-label{font-size:.8125rem;font-weight:500;color:var(--text-secondary);flex-shrink:0}.user-profile-value{font-size:.875rem;color:var(--text-primary);text-align:right;word-break:break-word}.user-profile-value.user-id{font-family:Courier New,monospace;font-size:.75rem;color:var(--text-secondary)}.logout-button{width:100%;padding:.75rem 1rem;background-color:transparent;border:1px solid var(--border-color);color:var(--text-primary);border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.875rem;font-weight:600}.logout-button:hover{background-color:#f443361a;color:var(--danger);border-color:var(--danger)}.sidebar{padding-bottom:0}.user-profile-container.expanded{max-height:350px;overflow-y:auto}@media(max-width:480px){.user-profile-avatar,.user-profile-avatar-placeholder{width:40px;height:40px;min-width:40px;min-height:40px}.user-profile-name{font-size:.875rem}.user-profile-email{font-size:.75rem}.user-profile-field{flex-direction:column;align-items:flex-start;gap:.25rem}.user-profile-value{text-align:left}}*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0f0f0f;--bg-secondary: #1a1a1a;--bg-tertiary: #242424;--bg-hover: #2a2a2a;--text-primary: #ffffff;--text-secondary: #b3b3b3;--accent-primary: #1db954;--accent-hover: #1ed760;--border-color: #333333;--danger: #f44336;--shadow: rgba(0, 0, 0, .5)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);overflow:hidden}.app{height:100vh;display:flex;flex-direction:column;position:relative;overflow:hidden}.app-background{position:absolute;top:0;left:0;width:100%;height:100%;background-image:url(/icone-zabumba-300px.png);background-size:cover;background-position:center;background-repeat:no-repeat;z-index:0}.app-background:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#0f0f0fe6,#0f0f0fb3,#0f0f0fcc);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1}.menu-toggle{position:fixed;top:1rem;left:1rem;z-index:1001;width:48px;height:48px;border-radius:12px;background-color:#ffffff1a;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 4px 12px #0003}.menu-toggle:hover{background-color:#fff3;transform:scale(1.05)}.sidebar{position:fixed;top:0;left:0;bottom:0;width:320px;background:linear-gradient(135deg,#1a1a1af2,#141414eb);-webkit-backdrop-filter:blur(30px) saturate(180%);backdrop-filter:blur(30px) saturate(180%);border-right:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;overflow:hidden;transform:translate(-100%);transition:transform .4s cubic-bezier(.4,0,.2,1);z-index:1000;box-shadow:2px 0 30px #00000080}.sidebar.open{transform:translate(0)}.sidebar-nav{padding:1.5rem .75rem;border-bottom:1px solid rgba(255,255,255,.05);animation:slideInLeft .5s ease-out}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.nav-item{width:100%;display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:#ffffff05;border:1px solid rgba(255,255,255,.03);color:#ffffffb3;cursor:pointer;border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1);font-size:1rem;font-weight:500;text-align:left;margin-bottom:.5rem;position:relative;overflow:hidden}.nav-item:before{content:"";position:absolute;left:0;top:0;height:100%;width:3px;background:var(--accent-primary);transform:scaleY(0);transition:transform .3s ease}.nav-item:hover{background:#ffffff14;border-color:#ffffff1a;color:var(--text-primary);transform:translate(4px);box-shadow:0 4px 12px #0003}.nav-item.active{background:#1db9541f;border-color:#1db9544d;color:var(--accent-primary);font-weight:600;box-shadow:0 4px 16px #1db95433}.nav-item.active:before{transform:scaleY(1)}.nav-item svg{transition:transform .3s ease}.nav-item:hover svg,.nav-item.active svg{transform:scale(1.1)}.overlay{position:fixed;inset:0;background-color:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999;animation:fadeIn .3s ease;cursor:pointer}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background-color:transparent;min-height:0;padding-bottom:80px;position:relative;z-index:2}@media(max-width:768px){.main-content{padding-bottom:70px}}.main-header{padding:1rem 1.5rem 1rem 5rem;border-bottom:1px solid rgba(255,255,255,.05);background-color:#1a1a1a99;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);flex-shrink:0}.main-header h1{margin:0;font-size:1.75rem;font-weight:700;display:flex;align-items:center;gap:.75rem;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.3)}.header-logo{width:32px;height:32px;object-fit:contain;filter:drop-shadow(0 0 8px rgba(255,255,255,.3))}.current-playlist-name{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;padding:.5rem 1rem;background:#1db9541a;border:1px solid rgba(29,185,84,.2);border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:slideInDown .4s ease-out}@keyframes slideInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.playlist-label{font-size:.875rem;font-weight:600;color:#fff9;text-transform:uppercase;letter-spacing:.5px}.playlist-name-text{font-size:1rem;font-weight:700;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-hover) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.btn-primary{flex:1;padding:.875rem;background-color:var(--accent-primary);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 4px 12px #1db9544d}.btn-primary:hover:not(:disabled){background-color:var(--accent-hover);transform:translateY(-1px);box-shadow:0 6px 16px #1db95466}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.btn-secondary{flex:1;padding:.875rem;background-color:#ffffff0d;color:var(--text-primary);border:1px solid rgba(255,255,255,.1);border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.btn-secondary:hover:not(:disabled){background-color:#ffffff1a;border-color:#fff3}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.btn-icon{background:none;border:none;color:#fff9;cursor:pointer;padding:.5rem;border-radius:6px;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-icon:hover{color:var(--text-primary);background-color:#ffffff1a}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;color:#ffffff80;gap:1rem;flex:1}.empty-state svg{opacity:.5}.empty-state p{margin:0}.empty-state-small{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;text-align:center;color:#ffffff80;gap:.5rem}.empty-state-small svg{opacity:.5}.empty-state-small p{margin:0;font-size:.875rem}.badge{padding:.2rem .5rem;border-radius:4px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px}.badge.success{background-color:#1db95433;color:var(--accent-primary);border:1px solid rgba(29,185,84,.3)}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.admin-panel{padding:2rem;max-width:1200px;margin:0 auto;width:100%;overflow-y:auto;height:100%}.admin-header{margin-bottom:2rem}.admin-tabs{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:1rem}.tab-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;font-weight:600;border-radius:8px;transition:all .2s}.tab-btn:hover{background:#ffffff0d;color:var(--text-primary)}.tab-btn.active{background:#1db9541a;color:var(--accent-primary)}.card{background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.filters-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;align-items:end;margin-top:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;color:var(--text-secondary)}.form-group input,.form-group select{padding:.75rem;background:#0003;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--text-primary);font-size:.9rem}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--accent-primary)}.form-actions{display:flex;gap:.5rem}.users-table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:1rem;text-align:left;border-bottom:1px solid rgba(255,255,255,.05);overflow:hidden;word-break:break-word;max-width:100%}.users-table th{color:var(--text-secondary);font-weight:600;font-size:.875rem}.user-info{display:flex;align-items:center;gap:.75rem}.user-avatar-small{width:32px;height:32px;border-radius:50%;object-fit:cover}.user-email{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;word-break:break-all}.plan-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;background:#ffffff1a;color:var(--text-secondary)}.plan-badge.active{background:#1db95426;color:var(--accent-primary)}.manage-user-plans{width:100%;max-width:100%}.results-section{width:100%;margin-top:1.5rem}.table-container{width:100%;overflow-x:auto}.modal-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000}.modal-content{background:var(--bg-secondary);border:1px solid rgba(255,255,255,.1);border-radius:16px;width:100%;max-width:500px;padding:2rem;box-shadow:0 20px 50px #00000080}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.close-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:50%;transition:all .2s}.close-btn:hover{background:#ffffff1a;color:var(--text-primary)}.user-summary{background:#ffffff08;padding:1rem;border-radius:8px;margin-bottom:1.5rem}.user-summary p{margin:.5rem 0;font-size:.9rem}.full-width{width:100%}.modal-actions{display:flex;gap:1rem;margin-top:2rem}.status-message{display:flex;align-items:center;gap:.5rem;padding:1rem;border-radius:8px;margin-top:1rem;font-size:.9rem}.status-message.success{background:#1db9541a;color:var(--accent-primary)}.status-message.error{background:#f443361a;color:var(--danger)}.admin-note{margin-top:1.5rem;text-align:center;color:var(--text-secondary);opacity:.7}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#0000001a}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#fff3}@media(max-width:960px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.main-header h1{font-size:1.35rem}}@media(max-width:768px){.sidebar{width:100%;max-width:320px}}@media(max-width:480px){.main-header{padding:.75rem 1rem .75rem 3.5rem}.main-header h1{font-size:1.2rem}.current-playlist-name{flex-direction:column;align-items:flex-start;gap:.25rem;padding:.5rem .75rem}.playlist-label{font-size:.75rem}.playlist-name-text{font-size:.9rem}}@media(max-width:768px){.filters-form{grid-template-columns:1fr;gap:.75rem}.form-actions{flex-direction:column;width:100%}.form-actions button{width:100%}.table-container{overflow-x:visible}.users-table,.users-table thead,.users-table tbody,.users-table th,.users-table td,.users-table tr{display:block}.users-table thead tr{position:absolute;top:-9999px;left:-9999px}.users-table tr{border:1px solid rgba(255,255,255,.1);border-radius:8px;margin-bottom:1rem;padding:1rem;background-color:#ffffff08;overflow:hidden;max-width:100%;box-sizing:border-box}.users-table td{border:none;position:relative;padding:.5rem .5rem .5rem 40%;text-align:left;min-height:2.5rem;display:flex;align-items:center;overflow:hidden;word-break:break-word;max-width:100%;box-sizing:border-box}.users-table td{flex-wrap:nowrap}.users-table td>*{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;min-width:0;flex:1}.users-table td .user-email{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;min-width:0;word-break:break-all;flex:1}.users-table td:before{content:attr(data-label);position:absolute;left:0;width:35%;padding-right:10px;padding-left:.5rem;white-space:nowrap;font-weight:600;color:var(--text-secondary);font-size:.875rem;box-sizing:border-box;overflow:hidden;text-overflow:ellipsis}.users-table td:first-child{padding-left:0;padding-top:0;margin-bottom:.5rem}.users-table td:first-child:before{display:none}.user-info{width:100%}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.manage-user-plans{padding:0}.results-section{margin-top:1rem}}@media(max-width:480px){.admin-panel,.card{padding:1rem}.filters-section h3{font-size:1rem;margin-bottom:.75rem}.users-table td{padding-left:35%;padding-right:.5rem;font-size:.875rem;overflow:hidden;word-break:break-all;box-sizing:border-box}.users-table td:before{width:30%;font-size:.75rem;padding-left:.5rem}.users-table td{flex-wrap:nowrap}.users-table td>*{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1}.users-table td .user-email{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;min-width:0;word-break:break-all;flex:1}.users-table td[data-label=Ações]{padding-left:0;padding-top:.75rem}.users-table td[data-label=Ações]:before{display:none}.users-table td[data-label=Ações]>div{justify-content:flex-start}.user-avatar-small{width:28px;height:28px}}.app-loading{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;gap:20px;background-color:var(--bg-primary)}.spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.1);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
