.upload-modal{width:min(92vw,520px);max-height:calc(100svh - var(--banner-h) - var(--footer-h));display:flex;flex-direction:column;overflow:hidden}#upload-overlay.open{padding-top:var(--banner-h);padding-bottom:var(--footer-h);box-sizing:border-box}.upload-modal .auth-modal-header{flex-shrink:0}.upload-quota{flex-shrink:0;margin:10px 0 6px;display:flex;flex-direction:column;gap:6px}.upload-quota-bar{height:6px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}.upload-quota-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent),var(--teal));width:0%;transition:width .4s,background .3s}.upload-quota-fill.warn{background:#b46400}.upload-quota-fill.full{background:#a01e1e}.upload-quota-text{font-size:.82rem;opacity:.75}.upload-step{padding-right:14px;flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.upload-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:36px 20px;margin:8px 0;border:2px dashed rgba(255,255,255,.18);border-radius:16px;cursor:pointer;transition:border-color .2s,background .2s;text-align:center}.upload-dropzone.dragover,.upload-dropzone:hover{border-color:rgba(255,255,255,.4);background:rgba(255,255,255,.06)}.upload-dropzone:focus-visible{outline:rgba(255,255,255,.3) solid 2px;outline-offset:2px}.upload-dropzone-icon{width:32px;height:32px;opacity:.5;pointer-events:none}.upload-dropzone-title{font-weight:700;font-size:1rem}.upload-dropzone-hint{font-size:.82rem;opacity:.65;line-height:1.3}.upload-file-list{display:flex;flex-direction:column;gap:10px;margin:8px 0 12px;padding-right:4px}.upload-file-card{display:flex;gap:12px;padding:12px;border-radius:14px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1)}.upload-file-cover{flex-shrink:0;width:64px;height:64px;border-radius:10px;object-fit:cover;background:rgba(255,255,255,.06)}.upload-file-cover.placeholder{display:flex;align-items:center;justify-content:center;font-size:28px;opacity:.35}.upload-file-fields{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.upload-file-fields label{display:flex;flex-direction:column;gap:2px;font-size:.78rem;font-weight:700;opacity:.7;color:rgba(255,255,255,.85)}.upload-file-fields input{width:100%;box-sizing:border-box;padding:6px 8px;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.08);color:#fff;font:inherit;font-size:.88rem;font-weight:500;outline:0}.upload-file-fields input:focus{border-color:rgba(255,255,255,.35)}.upload-file-meta{font-size:.75rem;opacity:.55;margin-top:2px}.upload-file-remove{flex-shrink:0;align-self:flex-start;border:none;background:0 0;font-size:20px;line-height:1;cursor:pointer;opacity:.5;padding:4px;color:#fff}.upload-file-remove:hover{opacity:1}.upload-progress-list{display:flex;flex-direction:column;gap:8px;margin:8px 0 12px}.upload-progress-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);font-size:.88rem}.upload-progress-item .prog-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-progress-item .prog-status{flex-shrink:0;font-size:.78rem;font-weight:700;opacity:.7}.upload-progress-item .prog-status.done{color:#50c878}.upload-progress-item .prog-status.error{color:#ff6b6b}.upload-progress-overall{margin:4px 0 12px;display:flex;flex-direction:column;gap:6px}.upload-progress-bar{height:8px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}.upload-progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent),var(--teal));width:0%;transition:width .3s}.upload-progress-text{font-size:.82rem;opacity:.7}@media (max-width:863px){.upload-modal{width:100%;max-height:calc(var(--app-h,100svh) - var(--safe-top,0px) - var(--safe-bottom,0px) - 16px)}.upload-file-card{flex-direction:column;align-items:stretch}.upload-file-cover{width:100%;height:120px;border-radius:10px}}.upload-file-list,.upload-step{scrollbar-width:thin;scrollbar-color:var(--light-purple) transparent;scrollbar-gutter:stable}.upload-file-list::-webkit-scrollbar,.upload-step::-webkit-scrollbar{width:10px}.upload-file-list::-webkit-scrollbar-track,.upload-step::-webkit-scrollbar-track{background:0 0}.upload-file-list::-webkit-scrollbar-thumb,.upload-step::-webkit-scrollbar-thumb{background:var(--light-purple);border-radius:999px}.upload-file-list::-webkit-scrollbar-button,.upload-step::-webkit-scrollbar-button{width:0!important;height:0!important;display:none!important}.upload-file-list::-webkit-scrollbar-track-piece:end,.upload-file-list::-webkit-scrollbar-track-piece:start,.upload-step::-webkit-scrollbar-track-piece:end,.upload-step::-webkit-scrollbar-track-piece:start{background:0 0!important}.cloud-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 24px;min-height:40vh;gap:12px;opacity:.85}.cloud-empty-icon{margin-bottom:8px}.cloud-empty-title{font-size:1.5rem;font-weight:600;color:rgba(255,255,255,.9);margin:0}.cloud-empty-sub{font-size:.95rem;color:rgba(255,255,255,.55);margin:0;max-width:320px;line-height:1.5}.cloud-empty-sub strong{color:rgba(var(--accent-rgb),.95)}.song-menu-cloud-delete{color:#ff6b6b!important}.song-menu-cloud-delete img.menu-icon{filter:brightness(0) saturate(100%) invert(55%) sepia(90%) saturate(700%) hue-rotate(325deg)}.upload-bg-badge{display:inline-flex;align-items:center;gap:5px;margin-left:10px;padding:3px 10px 3px 8px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:rgba(124,92,252,.18);color:var(--teal);font-family:inherit;font-size:.72rem;font-weight:700;line-height:1;white-space:nowrap;cursor:pointer;vertical-align:middle;transition:background .2s,transform .15s;animation:1.8s ease-in-out infinite uploadBadgePulse}.upload-bg-badge:hover{background:rgba(124,92,252,.32);transform:scale(1.06)}.upload-bg-badge-icon{flex-shrink:0;animation:1.2s ease-in-out infinite uploadBadgeArrow}@keyframes uploadBadgePulse{0%,100%{opacity:1}50%{opacity:.7}}@keyframes uploadBadgeArrow{0%,100%{transform:translateY(0)}50%{transform:translateY(-2px)}}.upload-bg-badge.done{animation:none;color:#50c878;background:rgba(80,200,120,.12);border-color:rgba(80,200,120,.2)}.upload-bg-badge.done .upload-bg-badge-icon{animation:none}.premium-section{margin-top:4px}.premium-status{display:flex;align-items:center;gap:10px;margin-bottom:12px}.premium-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.premium-badge.free{background:rgba(255,255,255,.08);color:rgba(255,255,255,.5);border:1px solid rgba(255,255,255,.12)}.premium-badge.premium{background:linear-gradient(135deg,#c9a44a,#f0d78c);color:#1a1a1a;border:none}.premium-info{font-size:.8rem;color:rgba(255,255,255,.45);margin:0}.premium-info.small{font-size:.72rem;margin-top:8px}.premium-pitch{font-size:.85rem;color:rgba(255,255,255,.7);margin:0 0 14px;line-height:1.5}.premium-price-btn{width:100%;padding:14px 20px;border-radius:10px;border:1px solid #c9a44a;background:rgba(201,164,74,.08);color:#fff;cursor:pointer;transition:.2s}.premium-price-btn:hover{background:rgba(201,164,74,.18)}.premium-price{font-size:1.1rem;font-weight:600}.premium-price-btn:disabled{opacity:.5;cursor:not-allowed}.profile-divider{height:1px;background:rgba(255,255,255,.08);margin:18px 0}