*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a0a;--surface:#111113;--card:#18181b;--border:#27272a;--primary:#a78bfa;--primary-hover:#8b5cf6;--text:#f4f4f5;--muted:#71717a;--success:#22c55e;--danger:#f87171;--radius:10px;--font:-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:40px;--container-pad:16px;--top-nav-h:56px;--bottom-nav-h:60px;--player-h:72px}@media (min-width:640px){:root{--container-pad:24px;--bottom-nav-h:0px}}body{min-height:100vh}body,main{background:var(--bg);color:var(--text);font-family:var(--font);line-height:1.5;-webkit-font-smoothing:antialiased}main{min-height:90vh}a{color:inherit;text-decoration:none}.container{max-width:900px;margin:0 auto;padding:0 var(--container-pad)}.page{padding-top:var(--space-lg);padding-bottom:calc(var(--space-xl) + var(--bottom-nav-h) + 64px)}@media (min-width:640px){.page{padding-top:var(--space-xl);padding-bottom:calc(var(--space-xl) + var(--player-h))}}.page-title{font-size:1.4rem;font-weight:700;margin-bottom:var(--space-lg)}nav{border-bottom:1px solid var(--border);background:hsla(0,0%,4%,.94);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);position:-webkit-sticky;position:sticky;top:0;z-index:40}.nav-inner{display:flex;align-items:center;justify-content:space-between;height:var(--top-nav-h)}.nav-logo{font-size:1rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--primary)}.nav-links{display:flex;gap:.05rem;align-items:center}@media (max-width:639px){.nav-links{display:none}}.nav-mobile-profile{display:none;color:var(--text);margin-left:auto;padding:.25rem;line-height:0}@media (max-width:639px){.nav-mobile-profile{display:flex;align-items:center;justify-content:center}}.nav-link{position:relative;padding:.4rem .8rem;border-radius:8px;font-size:.82rem;font-weight:500;color:var(--muted);transition:color .18s;font-family:var(--font);background:none;border:none;cursor:pointer;letter-spacing:.01em}.nav-link.active,.nav-link:hover{color:var(--text)}.nav-link.active:after{content:"";position:absolute;bottom:-1px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--primary)}.bottom-nav{display:none}@media (max-width:639px){.bottom-nav{display:flex;position:fixed;top:auto;bottom:0;left:0;width:100%;height:var(--bottom-nav-h);background:rgba(8,8,8,.98);border-top:1px solid hsla(0,0%,100%,.07);z-index:50;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);padding-bottom:max(env(safe-area-inset-bottom),0px)}}.bottom-nav-item{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--muted);font-size:.58rem;font-weight:500;letter-spacing:.03em;text-transform:uppercase;text-decoration:none;transition:color .18s;min-height:44px;border:none;background:none;cursor:pointer;font-family:var(--font);position:relative}.bottom-nav-item:hover{color:hsla(240,5%,96%,.6)}.bottom-nav-item.active{color:var(--text)}.bottom-nav-item.active:before{content:"";position:absolute;top:4px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--primary)}.bottom-nav-item svg{width:22px;height:22px;flex-shrink:0;transition:transform .18s}.bottom-nav-item.active svg{transform:scale(1.08)}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;border:none;border-radius:var(--radius);font-size:.875rem;font-weight:500;cursor:pointer;transition:opacity .15s;font-family:var(--font);white-space:nowrap}@media (max-width:639px){.btn{min-height:44px;padding:.6rem 1.2rem}}.btn:hover{opacity:.82}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text)}.btn-ghost{background:transparent;border:none;color:var(--muted)}.btn-danger{background:rgba(239,68,68,.12);color:var(--danger);border:1px solid rgba(239,68,68,.25)}.btn-sm{min-height:unset;padding:.35rem .75rem;font-size:.8rem}.icon-btn{width:40px;height:40px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:background .15s;background:hsla(0,0%,100%,.06);color:var(--text);flex-shrink:0}.icon-btn:hover{background:hsla(0,0%,100%,.12)}.icon-btn:disabled{opacity:.4;cursor:not-allowed}.card{display:block;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);transition:border-color .2s,box-shadow .2s,transform .15s;overflow:hidden}.card:hover{border-color:rgba(167,139,250,.4);box-shadow:0 4px 24px rgba(167,139,250,.08)}.song-card{padding:0;position:relative}.song-card-cover{position:relative;aspect-ratio:16/9;background:var(--surface);overflow:hidden}.song-card-cover img{width:100%;height:100%;object-fit:cover;display:block}.song-card-cover-placeholder{width:100%;height:100%;font-size:2rem;color:var(--border)}.song-card-cover-placeholder,.song-card-play-overlay{display:flex;align-items:center;justify-content:center}.song-card-play-overlay{position:absolute;inset:0;background:rgba(0,0,0,.35);opacity:0;transition:opacity .2s;pointer-events:none}.song-card-cover:hover .song-card-play-overlay,.song-card:hover .song-card-play-overlay{opacity:1}@media (hover:none){.song-card-play-overlay{opacity:1;background:rgba(0,0,0,.15)}}.song-card-play-btn{border-radius:50%;background:hsla(0,0%,100%,.92);display:flex;align-items:center;justify-content:center;color:#000;border:none;cursor:pointer;transition:transform .15s,background .15s,box-shadow .15s;pointer-events:auto;box-shadow:0 2px 8px rgba(0,0,0,.4)}.song-card-play-btn:hover{transform:scale(1.12);background:#fff;box-shadow:0 4px 16px rgba(0,0,0,.5)}.song-card-body{padding:.65rem .75rem .75rem}.song-card-menu-btn{position:absolute;top:var(--space-sm);right:var(--space-sm);width:30px;height:30px;border-radius:50%;background:rgba(0,0,0,.6);border:1px solid hsla(0,0%,100%,.15);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;line-height:1;z-index:2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background .15s}.song-card-menu-btn:hover{background:rgba(139,92,246,.8)}.badge{display:inline-block;padding:.2rem .6rem;border-radius:9999px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.badge-primary{background:rgba(139,92,246,.18);color:var(--primary)}.tag{display:inline-block;padding:.15rem .5rem;border-radius:4px;font-size:.75rem;margin:.15rem .15rem 0 0}.tag,.tag-chip{background:hsla(0,0%,100%,.06);color:var(--muted)}.tag-chip{display:inline-flex;align-items:center;padding:.35rem .75rem;border:1px solid var(--border);border-radius:9999px;font-size:.8rem;cursor:pointer;transition:background .15s,color .15s,border-color .15s;-webkit-user-select:none;-moz-user-select:none;user-select:none}.tag-chip:hover{border-color:var(--primary);color:var(--text)}.tag-chip.selected{background:rgba(139,92,246,.2);border-color:var(--primary);color:var(--primary);font-weight:600}label{display:block;font-size:.8rem;color:var(--muted);margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.05em}input[type=email],input[type=password],input[type=search],input[type=text],input[type=url],select,textarea{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.9rem;padding:.65rem .9rem;outline:none;transition:border-color .15s;font-family:var(--font)}@media (max-width:639px){input[type=email],input[type=password],input[type=search],input[type=text],input[type=url],select,textarea{font-size:16px;padding:.75rem 1rem}}input[type=email]:focus,input[type=password]:focus,input[type=search]:focus,input[type=text]:focus,input[type=url]:focus,select:focus,textarea:focus{border-color:var(--primary)}input::placeholder,textarea::placeholder{color:var(--muted)}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}input[type=file]{width:100%;background:var(--surface);border:2px dashed var(--border);border-radius:var(--radius);color:var(--muted);font-size:.875rem;padding:1.25rem .9rem;cursor:pointer;transition:border-color .15s;font-family:var(--font);text-align:center}input[type=file]:hover{border-color:var(--primary)}audio{width:100%;border-radius:var(--radius);height:42px}.transcription{color:var(--text);white-space:pre-wrap;background:var(--surface);padding:var(--space-lg);border-radius:var(--radius);border:1px solid var(--border);letter-spacing:.01em}.lyrics-textarea,.transcription{font-family:Georgia,Times New Roman,serif;font-size:1rem;line-height:2}.lyrics-textarea{resize:vertical;min-height:320px}.search-bar{margin-bottom:var(--space-lg)}.song-group{margin-bottom:var(--space-xl)}.group-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:.85rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-gap:var(--space-md);gap:var(--space-md)}@media (max-width:480px){.grid{grid-template-columns:repeat(2,1fr);gap:var(--space-sm)}}.empty{text-align:center;padding:4rem var(--space-lg);color:var(--muted)}.empty h3{font-size:1.1rem;font-weight:400;margin-bottom:.5rem}.error{color:var(--danger);font-size:.85rem}.status-msg{color:var(--muted);font-size:.85rem}.song-page{max-width:680px}.song-cover-block{width:100%;max-width:280px;aspect-ratio:1;border-radius:calc(var(--radius) * 1.5);overflow:hidden;border:1px solid var(--border);background:var(--card);flex-shrink:0}@media (max-width:639px){.song-cover-block{max-width:100%;border-radius:var(--radius)}}.song-cover-block img{width:100%;height:100%;object-fit:cover;display:block}.song-cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:4rem;color:var(--border)}.song-actions-strip{display:flex;flex-wrap:wrap;gap:var(--space-sm);align-items:center}.song-section{margin-bottom:var(--space-lg)}.song-section-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:var(--space-sm)}.owner-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-md)}.owner-panel-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:var(--space-md)}.regen-panel{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-md);margin-top:var(--space-sm)}.regen-presets{display:flex;gap:var(--space-sm);flex-wrap:wrap;margin:var(--space-sm) 0}.regen-preset-btn{flex:1 1;min-width:80px;padding:.5rem var(--space-sm);border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--muted);font-size:.8rem;font-family:var(--font);cursor:pointer;transition:border-color .15s,color .15s,background .15s;text-align:center}.regen-preset-btn.active{border-color:var(--primary);background:rgba(139,92,246,.15);color:var(--primary);font-weight:600}.detail-section{margin-bottom:var(--space-lg)}.detail-label{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--space-sm)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-lg) var(--space-md);background:var(--bg)}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:calc(var(--radius) * 1.5);padding:2.5rem var(--space-lg);width:100%;max-width:380px}.auth-title{font-size:1.5rem;font-weight:700;letter-spacing:.08em;color:var(--primary);text-align:center;margin-bottom:.25rem}.auth-subtitle{font-size:.85rem;color:var(--muted);text-align:center;margin-bottom:2rem}.auth-form{margin-bottom:var(--space-lg)}.auth-footer{text-align:center;font-size:.85rem;color:var(--muted)}.like-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .9rem;border-radius:var(--radius);border:1px solid var(--border);font-size:1rem;cursor:pointer;transition:color .15s,background .15s,border-color .15s;font-family:var(--font);line-height:1;min-height:40px}.like-btn:hover{opacity:.8}.like-btn:disabled{opacity:.5;cursor:not-allowed}.like-count{font-size:.8rem}.publish-toggle{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem;color:var(--text)}.publish-toggle input[type=checkbox]{width:1rem;height:1rem;accent-color:var(--primary);cursor:pointer}.creator-avatar{width:56px;height:56px;border-radius:50%;background:rgba(139,92,246,.15);border:1px solid rgba(139,92,246,.3);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:var(--primary);margin-bottom:.75rem}.creator-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));grid-gap:var(--space-md);gap:var(--space-md)}.creator-card{padding:var(--space-lg);text-align:center}.creator-card .creator-avatar{margin:0 auto .75rem}.tag-cloud{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin:var(--space-md) 0}.divider{border:none;border-top:1px solid var(--border);margin:var(--space-lg) 0}.discover-section{margin-bottom:var(--space-xl)}.discover-section-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:var(--space-md)}.discover-section-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}.discover-see-all{font-size:.78rem;color:var(--primary);background:none;border:none;cursor:pointer;font-family:var(--font);padding:0}.discover-see-all:hover{text-decoration:underline}.discover-row{display:flex;gap:var(--space-sm);overflow-x:auto;padding-bottom:var(--space-sm);scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}.discover-row::-webkit-scrollbar{display:none}.discover-row-item{flex:0 0 150px;scroll-snap-align:start}@media (min-width:480px){.discover-row-item{flex:0 0 170px}}@media (min-width:640px){.discover-row-item{flex:0 0 190px}.discover-row{flex-wrap:wrap;overflow-x:visible;padding-bottom:0}}.mini-card{position:relative;height:100%}.mini-card,.mini-card-link{display:flex;flex-direction:column}.mini-card-link{flex:1 1;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);background:var(--card);transition:border-color .15s;text-decoration:none}.mini-card-link:hover{border-color:rgba(139,92,246,.5)}.mini-card-cover{position:relative;aspect-ratio:1;background:var(--surface);overflow:hidden}.mini-card-cover img{width:100%;height:100%;object-fit:cover;display:block}.mini-card-placeholder{height:100%;font-size:2rem;color:var(--border)}.mini-card-placeholder,.mini-card-play-overlay{width:100%;display:flex;align-items:center;justify-content:center}.mini-card-play-overlay{position:absolute;inset:0;background:rgba(0,0,0,.4);color:#fff;font-size:1.25rem;opacity:0;transition:opacity .15s;border:none;cursor:pointer}.mini-card-cover:hover .mini-card-play-overlay{opacity:1}.mini-card-body-link{display:block;text-decoration:none;color:inherit}@media (hover:none){.mini-card-play-overlay{opacity:1;background:rgba(0,0,0,.18);font-size:1rem}}.mini-card-body{padding:var(--space-sm);flex:1 1}.mini-card-title{font-size:.82rem;font-weight:600;line-height:1.3;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:2px}.mini-card-creator{font-size:.7rem;color:var(--primary);font-weight:500;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px}.mini-card-add-btn{position:absolute;top:var(--space-xs);right:var(--space-xs);width:26px;height:26px;border-radius:50%;background:rgba(0,0,0,.65);border:1px solid hsla(0,0%,100%,.15);color:#fff;font-size:.9rem;display:flex;align-items:center;justify-content:center;cursor:pointer;line-height:1;z-index:2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;transition:opacity .15s,background .15s}.mini-card:focus-within .mini-card-add-btn,.mini-card:hover .mini-card-add-btn{opacity:1}@media (hover:none){.mini-card-add-btn{opacity:1}}.mini-card-add-btn:hover{background:rgba(139,92,246,.8)}.creators-row{display:flex;gap:var(--space-sm);overflow-x:auto;padding-bottom:var(--space-sm);scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}.creators-row::-webkit-scrollbar{display:none}@media (min-width:640px){.creators-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));overflow-x:visible;padding-bottom:0}}.creator-card-new{flex:0 0 120px;scroll-snap-align:start;padding:var(--space-md) var(--space-sm);text-align:center;cursor:pointer;transition:border-color .15s}@media (min-width:640px){.creator-card-new{flex:unset}}.creator-initials{width:44px;height:44px;border-radius:50%;background:rgba(139,92,246,.15);border:1px solid rgba(139,92,246,.3);display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;color:var(--primary);margin:0 auto var(--space-sm)}.creator-name{font-size:.85rem;font-weight:600;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px}.creator-count{font-size:.72rem;color:var(--muted)}.skeleton-card{pointer-events:none}.skeleton-cover{aspect-ratio:16/9}.skeleton-cover,.skeleton-line{background:var(--surface);animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-line{height:12px;border-radius:4px}@keyframes skeleton-pulse{0%,to{opacity:.5}50%{opacity:1}}.page-header,.profile-stats{margin-bottom:var(--space-lg)}.profile-stats{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:var(--space-md);gap:var(--space-md)}.profile-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-md);text-align:center}.profile-stat-value{display:block;font-size:1.4rem;font-weight:600;color:var(--text)}.profile-stat-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.profile-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-lg);margin-bottom:var(--space-lg)}.form-group{margin-bottom:var(--space-md)}.form-group label{font-size:.75rem;margin-bottom:var(--space-xs);letter-spacing:.04em}.profile-actions{display:flex;align-items:center;gap:var(--space-md)}.status-success{font-size:.8rem;color:var(--success)}.input{width:100%;height:48px;padding:0 14px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font);font-size:.95rem;transition:border .15s ease,box-shadow .15s ease,background .15s ease}.input::placeholder{color:var(--muted)}.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px rgba(139,92,246,.15)}.input:disabled{opacity:.6;cursor:not-allowed}.form-group label{display:block;font-size:.72rem;font-weight:500;color:var(--muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em}.form-group{margin-bottom:var(--space-lg)}@media (max-width:639px){.input{height:52px;font-size:1rem}}.global-player{position:fixed;bottom:0;left:0;right:0;height:var(--player-h);background:rgba(17,17,20,.98);border-top:1px solid var(--border);color:#fff;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;grid-gap:.75rem;gap:.75rem;padding:0 1.25rem;z-index:45;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);font-family:var(--font)}@media (max-width:639px){.global-player{bottom:var(--bottom-nav-h);height:64px;padding:0 .75rem;grid-template-columns:1fr auto auto;gap:.5rem}}.gp-progress-track{position:absolute;top:0;left:0;right:0;height:3px;background:hsla(0,0%,100%,.08);cursor:pointer;transition:height .15s}.gp-progress-track:hover{height:5px}.gp-progress-fill{height:100%;background:var(--primary);transition:width .1s linear;border-radius:0 2px 2px 0}.gp-main{gap:.65rem;cursor:pointer;min-width:0}.gp-cover,.gp-main{display:flex;align-items:center;overflow:hidden}.gp-cover{width:46px;height:46px;border-radius:8px;background:var(--card);justify-content:center;flex-shrink:0;font-size:1.1rem;color:var(--muted);border:1px solid var(--border)}.gp-cover img{width:100%;height:100%;object-fit:cover;display:block}@media (max-width:639px){.gp-cover{width:40px;height:40px;border-radius:6px}}.gp-info{display:flex;flex-direction:column;overflow:hidden;min-width:0}.gp-title{font-weight:600;font-size:.88rem;line-height:1.3;color:#fff}.gp-creator,.gp-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gp-creator{font-size:.72rem;color:hsla(0,0%,100%,.5);margin-top:1px}.gp-index{font-size:.68rem;color:hsla(0,0%,100%,.35);margin-top:1px}.gp-controls{gap:.25rem;justify-content:center}.gp-actions,.gp-controls{display:flex;align-items:center}.gp-actions{gap:.2rem;justify-content:flex-end}@media (max-width:639px){.gp-actions{gap:.1rem}}.gp-btn-circle{width:36px;height:36px;border-radius:50%;border:none;background:transparent;color:hsla(0,0%,100%,.7);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s ease,color .15s ease,transform .1s ease;flex-shrink:0}.gp-btn-circle:hover{background:hsla(0,0%,100%,.1);color:#fff}.gp-btn-circle:disabled{opacity:.3;cursor:default}.gp-btn-circle:disabled:hover{background:transparent;transform:none}.gp-btn-play{width:44px;height:44px;background:#fff;color:#000;box-shadow:0 2px 12px rgba(0,0,0,.4);flex-shrink:0}.gp-btn-play:hover{background:#e4e4e7;transform:scale(1.06)}.gp-btn-circle.active{color:var(--primary)}.gp-btn-circle.gp-btn-stop{color:hsla(0,91%,71%,.7)}.gp-btn-circle.gp-btn-stop:hover{color:#f87171;background:hsla(0,91%,71%,.1)}@media (max-width:639px){.gp-btn-hide-mobile{display:none}}.modal-loop-active{color:var(--primary)!important}.player-modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.75);display:flex;justify-content:center;align-items:center;z-index:9999;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.player-modal{background:#18181b;border:1px solid var(--border);padding:1.5rem;border-radius:20px;width:92%;max-width:400px;color:#fff;display:flex;flex-direction:column;gap:1.25rem;font-family:var(--font);box-shadow:0 24px 64px rgba(0,0,0,.6)}@media (max-width:639px){.player-modal-backdrop{align-items:flex-end;padding-bottom:calc(var(--bottom-nav-h) + var(--player-h))}.player-modal{width:100%;max-width:100%;border-radius:20px 20px 0 0;padding:1.25rem 1.25rem 1.5rem}}.modal-header{display:flex;align-items:center;justify-content:space-between}.modal-header-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}.modal-close-btn{width:32px;height:32px;border-radius:50%;background:hsla(0,0%,100%,.08);border:none;color:var(--muted);font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.modal-close-btn:hover{background:hsla(0,0%,100%,.15);color:#fff}.modal-cover{position:relative;width:100%;aspect-ratio:1;border-radius:12px;overflow:hidden;background:var(--surface);border:1px solid var(--border);cursor:pointer}.modal-cover img{width:100%;height:100%;object-fit:cover;display:block}.modal-cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3.5rem;color:var(--border)}.modal-title-row{display:flex;align-items:center;gap:.75rem}.modal-info{flex:1 1;min-width:0;cursor:pointer}.modal-info h2{margin:0;font-size:1.1rem;font-weight:700}.modal-info h2,.modal-info p{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal-info p{font-size:.8rem;color:hsla(0,0%,100%,.5);margin:2px 0 0}.modal-slider{width:100%;height:4px;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:hsla(0,0%,100%,.15);border-radius:2px;outline:none;cursor:pointer}.modal-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:#fff;cursor:pointer}.modal-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:#fff;cursor:pointer;border:none}.modal-controls{gap:.5rem}.modal-btn-circle,.modal-controls{display:flex;align-items:center;justify-content:center}.modal-btn-circle{width:40px;height:40px;border-radius:50%;background:transparent;border:none;color:hsla(0,0%,100%,.7);cursor:pointer;transition:background .15s,color .15s,transform .1s;font-size:1.1rem}.modal-btn-circle:hover{background:hsla(0,0%,100%,.1);color:#fff}.modal-btn-circle:disabled{opacity:.3;cursor:default}.modal-play-btn{width:56px!important;height:56px!important;background:#fff!important;color:#000!important;font-size:1.2rem;box-shadow:0 4px 16px rgba(0,0,0,.4)}.modal-play-btn:hover{background:#e4e4e7!important;transform:scale(1.05)}.library-page{padding:var(--container-pad);padding-bottom:calc(var(--space-xl) + var(--bottom-nav-h) + 64px);max-width:900px;margin:0 auto}@media (min-width:640px){.library-page{padding-bottom:calc(var(--space-xl) + var(--player-h))}}.library-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md);padding-top:var(--space-md)}.library-title{font-size:1.6rem;font-weight:700;letter-spacing:-.02em}.library-count{font-weight:400;color:var(--muted);margin-left:var(--space-sm);font-size:1.2rem}.big-play-btn{background:var(--primary);color:#fff;border:none;border-radius:999px;font-size:.8rem;font-weight:600;letter-spacing:.02em}.big-play-btn:hover{background:var(--primary-hover)}.btn-primary{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--primary);color:#fff;font-weight:500;border-radius:var(--radius);text-decoration:none;transition:background .2s}.btn-primary:hover{background:var(--primary-hover)}.icon{width:1.2em;height:1.2em}.library-search{width:100%;padding:var(--space-sm);margin-bottom:var(--space-sm);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text)}.library-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.library-sort{padding:var(--space-xs) var(--space-sm);border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text)}.library-view-toggle{display:flex}.toggle-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-xs);margin-left:var(--space-sm);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .2s,border-color .2s}.toggle-btn.active,.toggle-btn:hover{background:var(--primary);border-color:var(--primary-hover);color:#fff}.library-groups{display:flex;flex-direction:column;gap:var(--space-lg)}.artist-group .artist-name{font-weight:600;margin-bottom:var(--space-sm)}.song-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));grid-gap:var(--space-md);gap:var(--space-md)}.library-list{gap:var(--space-sm)}.library-list-item{display:flex;justify-content:space-between;padding:var(--space-sm);background:var(--surface);border-radius:var(--radius);transition:background .2s}.library-list-item:hover{background:#222}.song-title{font-weight:500}.song-meta{color:var(--muted);font-size:.875rem}.song-view-link{color:var(--primary);text-decoration:none}.song-view-link:hover{text-decoration:underline}@keyframes swipeInFromRight{0%{transform:translateX(40px);opacity:0}to{transform:translateX(0);opacity:1}}@keyframes swipeInFromLeft{0%{transform:translateX(-40px);opacity:0}to{transform:translateX(0);opacity:1}}main.swipe-in-right{animation:swipeInFromRight .22s ease}main.swipe-in-left{animation:swipeInFromLeft .22s ease}.modal-time-row{padding:0 2px;margin-top:-2px;margin-bottom:.25rem;font-size:.68rem;color:hsla(0,0%,100%,.38);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;letter-spacing:.01em}.modal-secondary-row,.modal-time-row{display:flex;justify-content:space-between}.modal-secondary-row{align-items:center;margin-top:.25rem}.modal-track-count{font-size:.72rem;color:hsla(0,0%,100%,.4)}.modal-btn-circle.modal-active{color:var(--primary);background:rgba(167,139,250,.15)}.modal-queue{margin-top:1.25rem;border-top:1px solid hsla(0,0%,100%,.07);padding-top:.875rem}.modal-queue-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:hsla(0,0%,100%,.35);margin-bottom:.5rem}.modal-queue-list{max-height:220px;overflow-y:auto;display:flex;flex-direction:column;gap:1px;scrollbar-width:thin;scrollbar-color:hsla(0,0%,100%,.12) transparent}.modal-queue-list::-webkit-scrollbar{width:3px}.modal-queue-list::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.12);border-radius:2px}.modal-queue-item{display:flex;align-items:center;gap:.6rem;padding:.45rem .5rem;border-radius:6px;background:none;border:none;cursor:pointer;text-align:left;width:100%;transition:background .12s;color:inherit}.modal-queue-item:hover{background:hsla(0,0%,100%,.06)}.modal-queue-item.active{background:rgba(167,139,250,.12)}.modal-queue-num{font-size:.72rem;color:hsla(0,0%,100%,.3);width:1.4rem;text-align:center;flex-shrink:0;display:flex;align-items:center;justify-content:center}.modal-queue-item.active .modal-queue-num{color:var(--primary)}.modal-queue-info{flex:1 1;min-width:0;display:flex;flex-direction:column;gap:1px}.modal-queue-title{font-size:.82rem;font-weight:500;color:hsla(0,0%,100%,.82);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-queue-item.active .modal-queue-title{color:var(--primary)}.modal-queue-artist{font-size:.68rem;color:hsla(0,0%,100%,.38);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-lyrics-section{margin-top:1.25rem;border-top:1px solid hsla(0,0%,100%,.07);padding-top:.875rem}.modal-lyrics-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;padding:0;cursor:pointer;color:hsla(0,0%,100%,.5);font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-family:var(--font);transition:color .15s}.modal-lyrics-toggle:hover{color:hsla(0,0%,100%,.8)}.modal-lyrics-body{margin-top:.875rem;max-height:280px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:hsla(0,0%,100%,.1) transparent}.modal-lyrics-body::-webkit-scrollbar{width:3px}.modal-lyrics-body::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.1);border-radius:2px}.modal-lyrics-text{font-family:Georgia,Times New Roman,serif;font-size:.875rem;line-height:2;color:hsla(0,0%,100%,.82);white-space:pre-wrap;word-break:break-word}.modal-lyrics-placeholder{font-size:.82rem;color:hsla(0,0%,100%,.3);font-style:italic;text-align:center;padding:.5rem 0}.player-modal{max-height:calc(100vh - 3rem);overflow-y:auto;scrollbar-width:thin;scrollbar-color:hsla(0,0%,100%,.1) transparent}.player-modal::-webkit-scrollbar{width:3px}.player-modal::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.1);border-radius:2px}@media (max-width:639px){.player-modal{max-height:calc(100svh - var(--bottom-nav-h) - var(--player-h) - .5rem)}}.library-list{list-style:none;display:flex;flex-direction:column;gap:2px}.library-list-item{display:grid;grid-template-columns:44px 1fr auto;align-items:center;grid-gap:.75rem;gap:.75rem;padding:.4rem .5rem;border-radius:8px;background:transparent;border:none;transition:background .12s}.library-list-item:hover{background:hsla(0,0%,100%,.04)}.library-list-item.is-playing{background:rgba(167,139,250,.07)}.library-list-thumb{width:44px;height:44px;border-radius:5px;overflow:hidden;flex-shrink:0;background:var(--card);display:flex;align-items:center;justify-content:center;text-decoration:none}.library-list-thumb img{width:100%;height:100%;object-fit:cover;display:block}.library-list-placeholder{font-size:1.1rem;color:var(--muted)}.library-list-info{min-width:0;display:flex;flex-direction:column;gap:2px;text-decoration:none;color:inherit}.library-list-title{font-size:.875rem;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.library-list-title.active{color:var(--primary)}.library-list-meta{font-size:.72rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.library-list-tags{display:flex;gap:.2rem;flex-wrap:wrap;margin-top:2px}.library-list-actions{display:flex;align-items:center;gap:.1rem;flex-shrink:0}.library-list-add,.library-list-play{width:30px;height:30px;border-radius:50%;background:none;border:none;cursor:pointer;color:var(--muted);display:flex;align-items:center;justify-content:center;transition:color .12s,background .12s;flex-shrink:0}.library-list-add:hover,.library-list-play:hover{color:var(--text);background:hsla(0,0%,100%,.07)}.library-list-add:hover,.library-list-play.active{color:var(--primary)}.song-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:.25rem}.song-card-date{font-size:.68rem;color:var(--muted)}.song-card-add-btn{width:22px;height:22px;border-radius:50%;background:transparent;border:1px solid hsla(0,0%,100%,.14);color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .15s,color .15s,background .15s}.song-card-add-btn:hover{border-color:var(--primary);color:var(--primary);background:rgba(167,139,250,.12)}.song-row{display:flex;align-items:center;gap:var(--space-sm);padding:.45rem 0;border-bottom:1px solid var(--border)}.song-row:last-child{border-bottom:none}.song-row.is-active .song-row-title{color:var(--primary)}.song-row-play{background:none;border:none;cursor:pointer;padding:0;flex-shrink:0}.song-row-thumb{width:44px;height:44px;border-radius:6px;overflow:hidden;background:var(--surface);position:relative;display:flex;align-items:center;justify-content:center}.song-row-thumb img{width:100%;height:100%;object-fit:cover;display:block}.song-row-thumb-placeholder{font-size:1.1rem;color:var(--border)}.song-row-play-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.55);opacity:0;transition:opacity .15s;color:#fff}.song-row.is-active .song-row-play-icon,.song-row:hover .song-row-play-icon{opacity:1}.song-row-info{flex:1 1;min-width:0;display:flex;flex-direction:column;gap:2px;text-decoration:none;color:inherit}.song-row-title{font-size:.875rem;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-row-title.active{color:var(--primary)}.song-row-meta{font-size:.72rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-row-tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:2px}.activity-feed{display:flex;flex-direction:column}.activity-item{display:flex;align-items:center;gap:var(--space-sm);padding:.6rem 0;border-bottom:1px solid var(--border);text-decoration:none;color:var(--text);transition:opacity .15s}.activity-item:last-child{border-bottom:none}.activity-item:hover{opacity:.75}.activity-body{flex:1 1;min-width:0;display:flex;flex-direction:column;gap:2px}.activity-text{font-size:.83rem;line-height:1.4;color:var(--text)}.activity-title{color:var(--primary)}.activity-time{font-size:.71rem;color:var(--muted)}.activity-cover{width:36px;height:36px;border-radius:5px;object-fit:cover;flex-shrink:0}.peer-row{display:flex;align-items:center;gap:var(--space-sm);padding:.65rem 0;border-bottom:1px solid var(--border)}.peer-row:last-child{border-bottom:none}.peer-row-info{flex:1 1;min-width:0}.peer-row-name{font-size:.875rem;font-weight:500;color:var(--text)}.peer-row-sub{font-size:.72rem;color:var(--muted)}.section-label{font-size:.7rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin-bottom:var(--space-sm)}.filter-pills{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:var(--space-md)}.filter-pill{padding:.3rem .75rem;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--muted);font-size:.78rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s,border-color .15s;white-space:nowrap;font-family:var(--font)}.filter-pill:hover{border-color:var(--primary);color:var(--text)}.filter-pill.active{background:var(--primary);border-color:var(--primary);color:#fff}.filter-pill--liked.active{background:#f87171;border-color:#f87171;color:#fff}.global-player--idle{pointer-events:none}.gp-idle-info{cursor:default}.gp-idle-text{font-size:.85rem;font-weight:500;color:hsla(0,0%,100%,.45)}.landing{min-height:100vh;display:flex;flex-direction:column;background:var(--bg);color:var(--text);overflow-x:hidden}.landing-nav{position:-webkit-sticky;position:sticky;top:0;z-index:80;display:flex;align-items:center;justify-content:space-between;padding:1rem var(--container-pad);background:hsla(0,0%,4%,.88);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}.landing-logo{font-size:1.25rem;font-weight:800;letter-spacing:.1em;color:var(--primary)}.landing-nav-actions{display:flex;align-items:center;gap:1rem}.landing-nav-link{font-size:.88rem;color:var(--muted);transition:color .15s}.landing-nav-link:hover{color:var(--text)}.landing-nav-cta{font-size:.85rem;padding:.45rem 1rem}.landing-hero{position:relative;display:flex;flex-direction:column;align-items:center;padding:5rem var(--container-pad) 6rem;text-align:center;overflow:hidden}.landing-hero-inner{position:relative;z-index:1;max-width:680px;margin:0 auto}.landing-eyebrow{font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--primary);margin-bottom:1.25rem}.landing-headline{font-size:clamp(2.2rem,8vw,4rem);font-weight:800;line-height:1.12;letter-spacing:-.03em;margin-bottom:1.5rem}.landing-headline-accent{color:var(--primary)}.landing-sub{font-size:1.05rem;color:var(--muted);line-height:1.7;max-width:520px;margin:0 auto 2.5rem}.landing-hero-ctas{display:flex;flex-direction:column;align-items:center;gap:1rem}@media (min-width:480px){.landing-hero-ctas{flex-direction:row;justify-content:center}}.landing-cta-primary{padding:.75rem 1.75rem;font-size:.95rem;font-weight:600;border-radius:999px}.landing-cta-secondary{font-size:.88rem;color:var(--muted);transition:color .15s}.landing-cta-secondary:hover{color:var(--text)}.landing-glow{position:absolute;top:10%;left:50%;transform:translateX(-50%);width:min(600px,90vw);height:400px;background:radial-gradient(ellipse at center,rgba(167,139,250,.14) 0,transparent 70%);pointer-events:none;z-index:0}.landing-section-inner{max-width:900px;margin:0 auto;padding:0 var(--container-pad)}.landing-section-label{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--primary);margin-bottom:.75rem}.landing-section-title{font-size:clamp(1.5rem,4vw,2.2rem);font-weight:700;letter-spacing:-.02em;margin-bottom:3rem}.landing-features{padding:5rem 0;border-top:1px solid var(--border)}.landing-feature-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));grid-gap:1.5rem;gap:1.5rem}.landing-feature-card{background:var(--surface);border:1px solid var(--border);border-radius:calc(var(--radius) * 1.5);padding:1.75rem}.landing-feature-card h3{font-size:1rem;font-weight:600;margin-bottom:.6rem}.landing-feature-card p{font-size:.88rem;color:var(--muted);line-height:1.65}.landing-feature-icon{font-size:1.75rem;margin-bottom:1rem}.landing-steps{padding:5rem 0;border-top:1px solid var(--border)}.landing-step-list{display:flex;flex-direction:column;gap:2rem}@media (min-width:640px){.landing-step-list{flex-direction:row;gap:3rem}}.landing-step{display:flex;gap:1rem;align-items:flex-start;flex:1 1}.landing-step-num{font-size:2rem;font-weight:800;color:var(--border);line-height:1;flex-shrink:0;letter-spacing:-.04em}.landing-step h3{font-size:1rem;font-weight:600;margin-bottom:.4rem}.landing-step p{font-size:.88rem;color:var(--muted);line-height:1.6}.landing-cta-section{padding:6rem 0;border-top:1px solid var(--border);background:var(--surface)}.landing-cta-title{font-size:clamp(1.4rem,4vw,2rem);font-weight:700;letter-spacing:-.02em;margin-bottom:.75rem}.landing-cta-sub{font-size:1rem;color:var(--muted);margin-bottom:2rem}.landing-footer{padding:2rem var(--container-pad);border-top:1px solid var(--border);display:flex;align-items:center;gap:1rem;font-size:.8rem;color:var(--muted)}