:root{--bg-base:#0a0a0a;--bg-elevated:#111;--bg-card:#181818;--bg-hover:#242424;--bg-input:#1a1a1a;--accent:#3ddc84;--accent-dim:#2ab86a;--accent-glow:#3ddc8426;--danger:#e85d5d;--warning:#f5a623;--info:#4a9eff;--text-primary:#fff;--text-secondary:#b3b3b3;--text-muted:#535353;--border:#ffffff14;--sidebar-width:260px;--player-height:88px;--topbar-height:56px;--mobile-nav-height:56px;--radius:8px;--radius-lg:12px;--transition:0.2s ease;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px);--safe-left:env(safe-area-inset-left,0px);--safe-right:env(safe-area-inset-right,0px)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{height:100%;height:-webkit-fill-available}body{-webkit-text-size-adjust:100%;background:#0a0a0a;background:var(--bg-base);color:#fff;color:var(--text-primary);font-family:Arial,sans-serif;min-height:100vh;min-height:-webkit-fill-available;overflow:hidden;overscroll-behavior:none}#root,body{height:100%}#root{display:flex;flex-direction:column;height:-webkit-fill-available;padding-top:env(safe-area-inset-top,0);padding-top:var(--safe-top)}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#242424;background:var(--bg-hover);border-radius:3px}.app-layout{display:grid;grid-template-columns:260px 1fr;grid-template-columns:var(--sidebar-width) 1fr;grid-template-rows:1fr 88px;grid-template-rows:1fr var(--player-height);height:calc(100vh - env(safe-area-inset-top,    0px));height:calc(100vh - var(--safe-top));height:calc(100% - env(safe-area-inset-top,    0px));height:calc(100% - var(--safe-top));overflow:hidden}.sidebar{background:#000;border-right:1px solid #ffffff14;border-right:1px solid var(--border);display:flex;flex-direction:column;gap:4px;grid-column:1;padding:20px 12px}.main-content,.sidebar{grid-row:1;overflow-y:auto}.main-content{-webkit-overflow-scrolling:touch;background:linear-gradient(180deg,#121f12,#111 280px);background:linear-gradient(180deg,#121f12 0,var(--bg-elevated) 280px);grid-column:2;max-width:100%;overflow-x:hidden}.player-bar{background:#111;background:var(--bg-elevated);border-top:1px solid #ffffff14;border-top:1px solid var(--border);gap:12px;grid-column:1/3;grid-row:2;padding:0 16px env(safe-area-inset-bottom,0);padding-bottom:var(--safe-bottom);z-index:200}.player-bar,.topbar{align-items:center;display:flex;overflow:hidden}.topbar{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#0a0a0ae6;border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--border);flex-shrink:0;height:56px;height:var(--topbar-height);justify-content:space-between;padding:0 20px;position:sticky;top:0;z-index:100}.page-content{max-width:100%;overflow-x:hidden;padding:20px 20px 40px;width:100%}.sidebar-logo{align-items:center;display:flex;gap:10px;padding:4px 10px 16px}.sidebar-logo-icon{font-size:26px}.sidebar-logo-text{color:#3ddc84;color:var(--accent);font-family:Arial,sans-serif;font-size:17px;font-weight:800}.nav-section-title{color:#535353;color:var(--text-muted);font-size:10px;font-weight:700;letter-spacing:1.2px;padding:12px 10px 6px;text-transform:uppercase}.nav-item{align-items:center;background:none;border:none;border-radius:8px;border-radius:var(--radius);color:#b3b3b3;color:var(--text-secondary);cursor:pointer;display:flex;font-family:Arial,sans-serif;font-size:13px;font-weight:600;gap:12px;padding:9px 10px;text-decoration:none;transition:all .2s ease;transition:all var(--transition);width:100%}.nav-item.active,.nav-item:hover{background:#242424;background:var(--bg-hover);color:#fff;color:var(--text-primary)}.nav-item.active .nav-icon{color:#3ddc84;color:var(--accent)}.nav-icon{flex-shrink:0;font-size:18px;text-align:center;width:22px}.songs-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.song-card{background:#181818;background:var(--bg-card);border-radius:12px;border-radius:var(--radius-lg);cursor:pointer;overflow:hidden;padding:14px;position:relative;transition:background .2s ease,transform .2s ease;transition:background var(--transition),transform var(--transition)}.song-card:hover{background:#242424;background:var(--bg-hover);transform:translateY(-2px)}.song-card:hover .play-overlay{opacity:1;transform:translateY(0)}.song-card-cover{aspect-ratio:1;background:#242424;background:var(--bg-hover);border-radius:8px;border-radius:var(--radius);display:block;margin-bottom:10px;object-fit:cover;width:100%}.song-card-title{color:#fff;color:var(--text-primary);font-size:13px;font-weight:700;margin-bottom:3px}.song-card-sub,.song-card-title{font-family:Arial,sans-serif;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-card-sub{color:#b3b3b3;color:var(--text-secondary);font-size:12px}.play-overlay{background:#3ddc84;background:var(--accent);border:none;border-radius:50%;bottom:58px;box-shadow:0 4px 14px #3ddc8466;color:#000;display:flex;font-size:14px;height:38px;justify-content:center;opacity:0;position:absolute;right:14px;transform:translateY(6px);transition:all .2s ease;transition:all var(--transition);width:38px}.play-overlay,.song-row{align-items:center;cursor:pointer}.song-row{grid-gap:10px;border-radius:8px;border-radius:var(--radius);display:grid;gap:10px;grid-template-columns:44px 1fr auto;overflow:hidden;padding:7px 10px;transition:background .2s ease;transition:background var(--transition)}.song-row:hover{background:#242424;background:var(--bg-hover)}.song-row.active .song-row-title{color:#3ddc84!important;color:var(--accent)!important}.song-row-cover{background:#242424;background:var(--bg-hover);border-radius:4px;flex-shrink:0;height:38px;object-fit:cover;width:38px}.song-row-title{color:#fff;color:var(--text-primary);font-size:13px;font-weight:600}.song-row-sub,.song-row-title{font-family:Arial,sans-serif;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-row-right,.song-row-sub{color:#535353;color:var(--text-muted);font-size:12px}.song-row-right{flex-shrink:0;white-space:nowrap}.player-info{align-items:center;display:flex;flex-shrink:0;gap:10px;min-width:0;width:240px}.player-cover{background:#242424;background:var(--bg-hover);border-radius:4px;flex-shrink:0;height:48px;object-fit:cover;width:48px}.player-title{font-size:13px;font-weight:700}.player-artist,.player-title{font-family:Arial,sans-serif;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-artist{color:#b3b3b3;color:var(--text-secondary);font-size:11px}.player-center{flex:1 1;flex-direction:column;gap:5px;max-width:500px;min-width:0}.player-btns,.player-center{align-items:center;display:flex}.player-btns{gap:12px}.ctrl-btn{align-items:center;background:none;border:none;border-radius:50%;color:#b3b3b3;color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;font-size:16px;justify-content:center;padding:4px;transition:all .2s ease;transition:all var(--transition)}.ctrl-btn:hover{color:#fff;color:var(--text-primary);transform:scale(1.1)}.ctrl-btn.active{color:#3ddc84;color:var(--accent)}.play-btn{align-items:center;background:#fff;background:var(--text-primary);border:none;border-radius:50%;color:#000;cursor:pointer;display:flex;flex-shrink:0;font-size:12px;height:32px;justify-content:center;transition:transform .2s ease;transition:transform var(--transition);width:32px}.play-btn:hover{transform:scale(1.07)}.play-btn:disabled{cursor:default;opacity:.4}.progress-row{align-items:center;color:#535353;color:var(--text-muted);display:flex;font-family:Arial,sans-serif;font-size:11px;gap:8px;width:100%}.progress-bar{background:#242424;background:var(--bg-hover);border-radius:2px;cursor:pointer;flex:1 1;height:4px;position:relative}.progress-fill{background:#535353;background:var(--text-muted);border-radius:2px;height:100%;pointer-events:none;transition:width .1s linear}.progress-bar:hover .progress-fill{background:#3ddc84;background:var(--accent)}.player-right{align-items:center;display:flex;flex-shrink:0;gap:8px;justify-content:flex-end;width:240px}.volume-slider{appearance:none;-webkit-appearance:none;background:#242424;background:var(--bg-hover);border-radius:2px;cursor:pointer;height:4px;outline:none;width:70px}.volume-slider::-webkit-slider-thumb{appearance:none;background:#fff;background:var(--text-primary);border-radius:50%;height:11px;width:11px}.lyrics-panel{backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);background:#080808f5;border-left:1px solid #ffffff14;border-left:1px solid var(--border);bottom:88px;bottom:var(--player-height);display:flex;flex-direction:column;position:fixed;right:0;top:env(safe-area-inset-top,0);top:var(--safe-top);transform:translateX(100%);transition:transform .3s ease;width:320px;z-index:150}.lyrics-panel.open{transform:translateX(0)}.lyrics-header{align-items:center;border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:18px 20px 14px}.lyrics-body{display:flex;flex:1 1;flex-direction:column;gap:2px;overflow-y:auto;padding:20px}.lyric-line{color:#535353;color:var(--text-muted);font-family:Arial,sans-serif;font-size:16px;font-weight:500;line-height:1.5;padding:5px 0;transition:all .3s ease}.lyric-line.current{color:#3ddc84;color:var(--accent);font-size:20px;font-weight:700}.lyric-line.past{opacity:.4}.auth-page{-webkit-overflow-scrolling:touch;align-items:center;background:radial-gradient(ellipse at 50% 0,#0d2a0d 0,#0a0a0a 70%);background:radial-gradient(ellipse at 50% 0,#0d2a0d 0,var(--bg-base) 70%);display:flex;justify-content:center;min-height:100vh;min-height:-webkit-fill-available;overflow:auto;padding:20px}.auth-card{background:#181818;background:var(--bg-card);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:16px;max-width:400px;padding:32px 28px;width:100%}.auth-logo{margin-bottom:24px;text-align:center}.auth-logo-icon{display:block;font-size:40px;margin-bottom:8px}.auth-logo-text{color:#3ddc84;color:var(--accent);font-size:22px}.auth-logo-text,.auth-title{font-family:Arial,sans-serif;font-weight:800}.auth-title{font-size:20px;margin-bottom:6px}.auth-subtitle{color:#b3b3b3;color:var(--text-secondary);font-family:Arial,sans-serif;font-size:13px;margin-bottom:20px}.form-group{margin-bottom:12px}.form-label{color:#b3b3b3;color:var(--text-secondary);display:block;font-size:11px;font-weight:700;letter-spacing:.5px;margin-bottom:5px;text-transform:uppercase}.form-input,.form-label{font-family:Arial,sans-serif}.form-input{-webkit-appearance:none;background:#1a1a1a;background:var(--bg-input);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);color:#fff;color:var(--text-primary);font-size:14px;outline:none;padding:10px 14px;transition:border-color .2s ease;transition:border-color var(--transition);width:100%}.form-input:focus{border-color:#3ddc84;border-color:var(--accent)}.form-input::placeholder{color:#535353;color:var(--text-muted)}.form-input.error{border-color:#e85d5d;border-color:var(--danger)}.form-error{color:#e85d5d;color:var(--danger);gap:4px;margin-top:5px}.divider,.form-error{align-items:center;display:flex;font-family:Arial,sans-serif;font-size:12px}.divider{color:#535353;color:var(--text-muted);gap:12px;margin:16px 0}.divider:after,.divider:before{background:#ffffff14;background:var(--border);content:"";flex:1 1;height:1px}.btn{-webkit-tap-highlight-color:transparent;align-items:center;border:none;border-radius:24px;cursor:pointer;display:inline-flex;font-family:Arial,sans-serif;font-size:13px;font-weight:700;gap:8px;justify-content:center;padding:9px 20px;text-decoration:none;transition:all .2s ease;transition:all var(--transition);white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:#3ddc84;background:var(--accent);color:#000;padding:11px;width:100%}.btn-primary:hover:not(:disabled){background:#2ab86a;background:var(--accent-dim)}.btn-google{background:#fff;border:1px solid #ddd;color:#333;padding:10px;width:100%}.btn-secondary{background:#0000;border:1px solid #ffffff14;border:1px solid var(--border);color:#fff;color:var(--text-primary)}.btn-secondary:hover{background:#242424;background:var(--bg-hover)}.btn-danger{background:#e85d5d;background:var(--danger);color:#fff}.btn-sm{font-size:12px;padding:5px 14px}.btn-icon{-webkit-tap-highlight-color:transparent;background:none;border:none;border-radius:4px;color:#b3b3b3;color:var(--text-secondary);cursor:pointer;font-family:Arial,sans-serif;font-size:16px;padding:4px;transition:color .2s ease;transition:color var(--transition)}.btn-icon:hover{color:#fff;color:var(--text-primary)}.badge{align-items:center;border-radius:10px;display:inline-flex;font-family:Arial,sans-serif;font-size:11px;font-weight:700;gap:3px;padding:2px 8px}.badge-admin{background:#f5a62326;color:#f5a623;color:var(--warning)}.badge-premium{background:#3ddc8426;color:#3ddc84;color:var(--accent)}.badge-user{background:#ffffff14;color:#b3b3b3;color:var(--text-secondary)}.badge-done{background:#3ddc841f;color:#3ddc84;color:var(--accent)}.badge-pending{background:#f5a6231f;color:#f5a623;color:var(--warning)}.badge-error{background:#e85d5d1f;color:#e85d5d;color:var(--danger)}.section-title{font-family:Arial,sans-serif;font-size:20px;font-weight:800}.section-header{justify-content:space-between;margin-bottom:16px}.modal-overlay,.section-header{align-items:center;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;inset:0;justify-content:center;padding:16px;position:fixed;z-index:500}.modal{background:#181818;background:var(--bg-card);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:16px;max-height:90vh;max-width:460px;overflow-y:auto;padding:24px;width:100%}.modal-title{align-items:center;display:flex;font-family:Arial,sans-serif;font-size:17px;font-weight:800;justify-content:space-between;margin-bottom:18px}.import-report{background:#181818;background:var(--bg-card);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius-lg);margin-top:14px;padding:18px}.report-summary{display:flex;flex-wrap:wrap;gap:18px;margin-bottom:14px}.report-stat{text-align:center}.report-stat-value{font-family:Arial,sans-serif;font-size:24px;font-weight:800}.report-stat-label{color:#535353;color:var(--text-muted);font-family:Arial,sans-serif;font-size:11px;letter-spacing:.5px;text-transform:uppercase}.report-section{margin-top:12px}.report-section-title{color:#535353;color:var(--text-muted);font-family:Arial,sans-serif;font-size:11px;font-weight:700;letter-spacing:.8px;margin-bottom:7px;text-transform:uppercase}.report-list{display:flex;flex-direction:column;gap:3px;max-height:200px;overflow-y:auto}.report-item{align-items:center;border-radius:5px;display:flex;font-family:Arial,sans-serif;font-size:12px;gap:6px;justify-content:space-between;padding:5px 9px}.report-item-added{background:#3ddc8414}.report-item-dup{background:#f5a62314}.report-item-fail{background:#e85d5d14}.loading-state{align-items:center;color:#535353;color:var(--text-muted);display:flex;flex-direction:column;gap:14px;justify-content:center;padding:80px 20px}.spinner{animation:spin .7s linear infinite;border:3px solid #242424;border-top-color:#3ddc84;border:3px solid var(--bg-hover);border-radius:50%;border-top-color:var(--accent);height:28px;width:28px}@keyframes spin{to{transform:rotate(1turn)}}.admin-table{border-collapse:collapse;font-family:Arial,sans-serif;font-size:13px;width:100%}.admin-table th{border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--border);color:#535353;color:var(--text-muted);font-size:11px;font-weight:700;letter-spacing:.8px;padding:9px 11px;text-align:left;text-transform:uppercase}.admin-table td{border-bottom:1px solid #ffffff08;padding:9px 11px;vertical-align:middle}.admin-table tr:hover td{background:#242424;background:var(--bg-hover)}.mobile-miniplayer,.mobile-nav{display:none}@keyframes bar1{0%,to{height:3px}50%{height:14px}}@keyframes bar2{0%,to{height:10px}33%{height:3px}66%{height:14px}}@keyframes bar3{0%,to{height:14px}50%{height:3px}}@keyframes bar4{0%,to{height:5px}40%{height:14px}}@media (max-width:768px){.app-layout{display:flex;flex-direction:column;height:100%;overflow:hidden;width:100%}.sidebar{display:none}.main-content{-webkit-overflow-scrolling:touch;flex:1 1;overflow-x:hidden;overflow-y:auto;padding-bottom:calc(116px + env(safe-area-inset-bottom, 0px));padding-bottom:calc(var(--mobile-nav-height) + 60px + var(--safe-bottom))}.player-bar{display:none}.topbar{flex-shrink:0;height:52px;overflow:hidden;padding:0 14px;width:100%}.mobile-nav{align-items:center;background:#000;border-top:1px solid #ffffff14;border-top:1px solid var(--border);bottom:0;display:flex;height:calc(56px + env(safe-area-inset-bottom, 0px));height:calc(var(--mobile-nav-height) + var(--safe-bottom));justify-content:space-around;left:0;padding-bottom:env(safe-area-inset-bottom,0);padding-bottom:var(--safe-bottom);padding-left:env(safe-area-inset-left,0);padding-left:var(--safe-left);padding-right:env(safe-area-inset-right,0);padding-right:var(--safe-right);position:fixed;right:0;z-index:201}.mobile-miniplayer{bottom:calc(56px + env(safe-area-inset-bottom, 0px));bottom:calc(var(--mobile-nav-height) + var(--safe-bottom));display:block;left:6px;position:fixed;right:6px;z-index:200}.songs-grid{gap:10px;grid-template-columns:repeat(2,1fr)}.page-content{overflow-x:hidden;padding:12px 12px 16px}.auth-page{align-items:flex-start;padding:max(32px,20px) 16px 20px}.auth-card{border-radius:14px;max-width:100%;padding:22px 18px}.modal-overlay{align-items:flex-end;padding:8px}.modal{border-radius:20px 20px 14px 14px;margin-bottom:0;max-height:88vh;padding:22px 18px}.admin-table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}.lyrics-panel{bottom:calc(116px + env(safe-area-inset-bottom, 0px));bottom:calc(var(--mobile-nav-height) + 60px + var(--safe-bottom));left:0;width:100%}.btn{min-height:40px}.btn-sm{min-height:32px}.song-card:hover{transform:none}}@media (max-width:360px){.songs-grid{gap:8px;grid-template-columns:repeat(2,1fr)}.page-content{padding:10px 10px 12px}.topbar{padding:0 10px}.auth-card{padding:18px 14px}}
/*# sourceMappingURL=main.f324a032.css.map*/