.like-button{display:grid;place-items:center;width:36px;height:36px;padding:0;border:0;border-radius:var(--radius-pill);background:var(--color-chip-overlay);color:var(--color-text-primary);cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.like-button svg{width:20px;height:20px}.like-button--active{color:var(--color-like)}.like-button:hover{background:var(--color-surface)}.like-button:focus-visible{outline:var(--outline-width-focus) solid var(--color-text-primary);outline-offset:var(--outline-offset-focus)}.follow-button{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-pill);padding:0}.follow-button__label{font-size:.875rem;font-weight:600;line-height:1}.playback-spinner{display:inline-block;flex-shrink:0;border-radius:50%;border:2px solid color-mix(in srgb,currentColor 30%,transparent);border-top-color:currentColor;animation:playback-spin .7s linear infinite}.playback-spinner--sm{width:16px;height:16px}.playback-spinner--md{width:18px;height:18px}.playback-spinner--lg{width:22px;height:22px}@keyframes playback-spin{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){.playback-spinner{animation-duration:1.4s}}.bottom-player{position:fixed;left:var(--size-sidebar-width);right:var(--size-right-panel-width);bottom:0;z-index:70;display:flex;flex-direction:column;gap:10px;padding:10px 20px 12px;border-top:1px solid var(--color-border);background:var(--color-page);font-family:var(--font-family-base);box-sizing:border-box}.bottom-player__main{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:16px;min-width:0}.bottom-player__info{display:flex;align-items:center;gap:12px;min-width:0;grid-column:1;grid-row:1}.bottom-player__art-link,.bottom-player__title-link,.bottom-player__artist-link{color:inherit;text-decoration:none;min-width:0}.bottom-player__artist-link:hover{text-decoration:underline}.bottom-player__art{width:48px;height:48px;flex-shrink:0;object-fit:cover;border-radius:var(--radius-art-sm);background:var(--color-art-placeholder)}.bottom-player__art--placeholder{background:var(--color-art-placeholder)}.bottom-player__meta{min-width:0}.bottom-player__title,.bottom-player__artist{margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bottom-player__title{font-size:14px;font-weight:var(--font-weight-title)}.bottom-player__artist{color:var(--color-text-secondary);font-size:12px}.bottom-player__controls{display:flex;align-items:center;justify-content:center;gap:8px;grid-column:2;grid-row:1;justify-self:center}.bottom-player__control{width:36px;height:36px;display:grid;place-items:center;padding:0;border:0;border-radius:var(--radius-pill);background:transparent;color:var(--color-text-primary);cursor:pointer}.bottom-player__control svg{width:18px;height:18px}.bottom-player__control:disabled{opacity:.35;cursor:default}.bottom-player__control:not(:disabled):not(.bottom-player__control--primary):hover{background:var(--color-control)}.bottom-player__control--primary{width:40px;height:40px;background:var(--color-control-primary);color:var(--color-control-primary-text)}.bottom-player__control--primary svg{width:20px;height:20px}.bottom-player__control--primary:not(:disabled):hover{background:var(--color-control-primary);filter:brightness(1.08)}.bottom-player__control--primary:disabled{cursor:wait;opacity:.92}.bottom-player__control:focus-visible{outline:var(--outline-width-focus) solid var(--color-text-primary);outline-offset:var(--outline-offset-focus)}.bottom-player__actions{display:flex;align-items:center;justify-content:flex-end;gap:4px;grid-column:3;grid-row:1;justify-self:end}.bottom-player__actions .like-button{background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none}.bottom-player__actions .like-button:hover{background:var(--color-control)}.bottom-player__follow{height:36px;padding:0 12px;border-radius:var(--radius-pill)}.bottom-player__follow-label{font-size:12px;font-weight:600;white-space:nowrap}.bottom-player__queue{display:none;width:36px;height:36px;place-items:center;padding:0;border:0;border-radius:var(--radius-pill);background:transparent;color:var(--color-text-primary);cursor:pointer}.bottom-player__queue svg{width:20px;height:20px}.bottom-player__queue:hover{background:var(--color-control)}.bottom-player__queue--active{background:var(--color-control);color:var(--color-accent)}.bottom-player__queue:focus-visible{outline:var(--outline-width-focus) solid var(--color-text-primary);outline-offset:var(--outline-offset-focus)}.bottom-player__error{margin:0;color:var(--color-danger);font-size:12px;line-height:1.35}.bottom-player__progress{display:flex;align-items:center;gap:10px;min-width:0}.bottom-player__time{flex-shrink:0;width:36px;color:var(--color-text-secondary);font-size:11px;font-variant-numeric:tabular-nums}.bottom-player__time:last-child{text-align:right}.bottom-player__track{flex:1;min-width:0;height:var(--size-track-height);padding:0;border:0;overflow:hidden;background:var(--color-track);border-radius:var(--radius-pill);cursor:pointer}.bottom-player__fill{width:var(--progress-fill-width);height:100%;background:var(--color-text-primary);border-radius:inherit;pointer-events:none}@media(max-width:1280px){.bottom-player{right:0}.bottom-player__queue{display:grid}}@media(max-width:768px){.bottom-player{left:0;bottom:calc(var(--size-mobile-nav-height) + env(safe-area-inset-bottom,0px));padding-inline:12px}}@media(max-width:720px){.bottom-player__main{grid-template-columns:1fr auto 1fr;grid-template-rows:auto auto;row-gap:8px;column-gap:8px}.bottom-player__info{grid-column:1 / -1;grid-row:1}.bottom-player__controls{grid-column:2;grid-row:2;justify-self:center}.bottom-player__actions{grid-column:3;grid-row:2;justify-self:end;align-self:center}}@media(max-width:640px){.bottom-player{padding-inline:12px 16px}.bottom-player__art{width:40px;height:40px}.bottom-player__time{width:32px;font-size:10px}}@media(max-width:400px){.bottom-player__artist{display:none}}.action-menu{position:relative;flex-shrink:0}.action-menu__trigger{display:inline-flex;align-items:center;justify-content:center;padding:0;margin:0;border:0;border-radius:var(--radius-pill);background:transparent;color:var(--color-text-secondary);cursor:pointer}.action-menu__trigger svg{width:20px;height:20px}.action-menu__trigger:focus-visible{outline:var(--outline-width-focus) solid var(--color-text-primary);outline-offset:var(--outline-offset-focus)}.action-menu__list,.action-menu__list--portal{min-width:168px;margin:0;padding:4px;list-style:none;border:1px solid var(--color-border-strong);border-radius:var(--radius-card);background:var(--color-surface);box-shadow:var(--shadow-menu);box-sizing:border-box}.action-menu__list--portal{position:fixed;top:auto;right:auto;bottom:auto;z-index:200}.action-menu__item{display:block;width:100%;padding:9px 12px;border:0;border-radius:var(--radius-art-sm);background:transparent;color:var(--color-text-primary);font-family:var(--font-family-base);font-size:13px;font-weight:500;text-align:left;cursor:pointer}.action-menu__item:hover{background:var(--color-control)}.action-menu__item--danger{color:var(--color-danger)}.action-menu__item--danger:hover{background:var(--color-danger-bg)}.action-menu__item:focus-visible{outline:var(--outline-width-focus) solid var(--color-text-primary);outline-offset:var(--outline-offset-focus)}.right-panel{--queue-art-size: 52px;--queue-inline-gap: 8px;--queue-divider-offset: var(--queue-art-size);position:fixed;top:0;right:0;z-index:55;display:flex;flex-direction:column;gap:0;width:var(--size-right-panel-width);height:100vh;padding:0;border-left:1px solid var(--color-border);background:var(--color-surface-muted);font-family:var(--font-family-base);box-sizing:border-box;overflow:hidden;min-height:0}.right-panel__heading{flex-shrink:0;display:flex;align-items:center;gap:8px;margin:0;padding:var(--shell-padding);padding-bottom:8px;font-size:13px;font-weight:700;letter-spacing:.02em;text-transform:uppercase;color:var(--color-text-secondary)}.right-panel__count{margin-left:auto;padding:2px 8px;border-radius:var(--radius-pill);background:var(--color-control);font-size:11px;font-weight:600;text-transform:none;letter-spacing:0;color:var(--color-text-primary)}.right-panel__empty{margin:0;padding:0 var(--shell-padding) var(--shell-padding);font-size:13px;line-height:1.45;color:var(--color-text-secondary)}.right-panel__queue{display:flex;flex-direction:column;gap:0;min-height:0;flex:1;padding:0 0 var(--shell-padding) var(--shell-padding);overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain;scrollbar-gutter:stable}.right-panel__track{position:relative;display:flex;align-items:center;gap:var(--queue-inline-gap);width:100%;min-width:0;padding-block:var(--queue-inline-gap);padding-right:var(--shell-padding);box-sizing:border-box;cursor:grab;transition:opacity .12s ease}.right-panel__track:active{cursor:grabbing}.right-panel__track--dragging{opacity:.45}.right-panel__track--drop-target:before{content:"";position:absolute;top:0;left:var(--queue-divider-offset);right:0;height:2px;background:var(--color-text-primary);transform:translateY(-50%);pointer-events:none;z-index:1}.right-panel__track-main{display:flex;align-items:center;gap:var(--queue-inline-gap);flex:1;min-width:0;padding:0;margin:0}.right-panel__art-wrap{position:relative;flex-shrink:0;width:var(--queue-art-size);height:var(--queue-art-size)}.right-panel__art-play{display:block;padding:0;margin:0;border:0;background:none;cursor:pointer;line-height:0}.right-panel__track button{cursor:pointer}.right-panel__art-play:focus-visible{outline:var(--outline-width-focus) solid var(--color-text-primary);outline-offset:var(--outline-offset-focus);border-radius:var(--radius-art-sm)}.right-panel__art-toggle{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:0;margin:0;border:0;border-radius:var(--radius-art-sm);background:transparent;color:var(--color-on-media);cursor:pointer;filter:drop-shadow(0 1px 3px rgba(0,0,0,.55))}.right-panel__art-toggle svg{width:22px;height:22px}.right-panel__art-toggle:focus-visible{outline:var(--outline-width-focus) solid var(--color-on-media);outline-offset:var(--outline-offset-focus)}.right-panel__track-art{display:block;width:var(--queue-art-size);height:var(--queue-art-size);object-fit:cover;border-radius:var(--radius-art-sm);background:var(--color-art-placeholder)}.right-panel__track-art--placeholder{background:var(--color-art-placeholder)}.right-panel__track-meta{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1;padding:0;margin:0;border:0;background:none;color:inherit;font:inherit;text-align:left;cursor:pointer}.right-panel__track-meta:focus-visible{outline:var(--outline-width-focus) solid var(--color-text-primary);outline-offset:var(--outline-offset-focus)}.right-panel__track-title,.right-panel__track-artist{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.right-panel__track-title{font-size:15px;font-weight:var(--font-weight-title);line-height:1.3}.right-panel__track-artist{font-size:13px;line-height:1.3;color:var(--color-text-secondary)}@media(max-width:1280px){.right-panel{z-index:90;box-shadow:var(--shadow-modal);transition:transform .25s ease;transform:translate(100%);visibility:hidden;pointer-events:none}.right-panel--open{transform:translate(0);visibility:visible;pointer-events:auto}}.sidebar{position:fixed;top:0;left:0;z-index:60;flex-shrink:0;width:var(--size-sidebar-width);height:100vh;display:flex;flex-direction:column;gap:0;padding:0 0 var(--shell-padding);border-right:1px solid var(--color-border);background:var(--color-surface-muted);font-family:var(--font-family-base);box-sizing:border-box;overflow:hidden}.sidebar__brand{display:flex;align-items:center;gap:12px;min-width:0;height:var(--size-app-header-height);padding:var(--app-main-padding-inline) var(--shell-padding);box-shadow:inset 0 -1px 0 var(--color-border);box-sizing:border-box;color:var(--color-text-primary);text-decoration:none}.sidebar__brand-logo{width:var(--size-app-header-toolbar);height:var(--size-app-header-toolbar);flex-shrink:0;border-radius:var(--radius-art-sm);object-fit:cover;display:block}.sidebar__brand-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:17px;font-weight:700}.sidebar__nav{display:flex;flex-direction:column;gap:1px;width:100%;min-width:0;padding:20px var(--shell-padding) 0;box-sizing:border-box}.sidebar__link{display:flex;align-items:center;gap:12px;width:100%;min-width:0;padding:12px 14px;border-radius:var(--radius-card);color:var(--color-text-secondary);text-decoration:none;box-sizing:border-box}.sidebar__link:hover,.sidebar__link--active{background:var(--color-control);color:var(--color-text-primary)}.sidebar__icon{width:22px;height:22px;flex-shrink:0}.sidebar__text{display:flex;flex-direction:column;gap:2px;min-width:0}.sidebar__label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:600}.sidebar__label--mobile{display:none}.sidebar__count{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text-secondary);font-size:12px;font-weight:500}.sidebar__link:focus-visible{outline:var(--outline-width-focus) solid var(--color-text-primary);outline-offset:var(--outline-offset-focus)}.sidebar__playlists{display:flex;flex-direction:column;gap:2px;margin:20px calc(-1 * var(--shell-padding)) 0;padding:20px var(--shell-padding) 20px;border-top:1px solid var(--color-border);max-height:200px;overflow-y:auto;box-sizing:border-box}.sidebar__playlist-link{display:block;padding:6px 12px;font-size:var(--font-size-time);color:var(--color-text-secondary);text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-radius:var(--radius-art-sm)}.sidebar__playlist-link:hover,.sidebar__playlist-link--active{color:var(--color-text-primary);background:var(--color-control)}@media(max-width:1024px)and (min-width:769px){.sidebar{align-items:center}.sidebar__brand{justify-content:center;gap:0;width:100%;padding-inline:var(--shell-padding)}.sidebar__brand-name,.sidebar__text{display:none}.sidebar__nav{align-items:center}.sidebar__link{justify-content:center;width:48px;padding:12px}}@media(max-width:768px){.sidebar{top:auto;bottom:0;left:0;right:0;width:100%;height:calc(var(--size-mobile-nav-height) + env(safe-area-inset-bottom,0px));flex-direction:row;align-items:stretch;gap:0;padding:0 8px env(safe-area-inset-bottom,0px);border-right:0;border-top:1px solid var(--color-border)}.sidebar__brand{display:none}.sidebar__nav{flex:1;flex-direction:row;align-items:center;justify-content:space-around;gap:0;padding:0}.sidebar__link{flex:1;flex-direction:column;gap:3px;max-width:none;justify-content:center;padding:6px 4px}.sidebar__icon{width:22px;height:22px}.sidebar__text{display:flex;flex-direction:column;align-items:center;gap:0;min-width:0}.sidebar__label--desktop,.sidebar__count{display:none}.sidebar__label--mobile{display:block;font-size:10px;font-weight:600;line-height:1.2;text-align:center}}.splash{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:var(--color-page);font-family:var(--font-family-base);padding:24px;padding-bottom:calc(24px + env(safe-area-inset-bottom,0px))}.splash__logo{width:96px;height:96px;object-fit:contain;border-radius:var(--radius-art-sm)}.splash__name{font-size:28px;font-weight:900;letter-spacing:-.02em;color:var(--color-text-primary)}.categories-page{width:100%;min-width:0;padding:0 0 8px;box-sizing:border-box;color:var(--color-text-primary);font-family:var(--font-family-base)}.categories-page__header{margin-inline:calc(-1 * var(--app-main-padding-inline));margin-bottom:32px;padding:var(--app-main-padding-inline);box-sizing:border-box}.categories-page__heading{display:flex;flex-direction:column;align-items:flex-start;gap:4px;min-width:0}.categories-page__title{margin:0;font-size:clamp(32px,5vw,48px);line-height:1.05}.categories-page__desc{margin:0;color:var(--color-text-secondary);font-size:15px;line-height:1.4}.categories-page__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}@media(max-width:768px){.categories-page__grid{grid-template-columns:repeat(auto-fill,minmax(min(160px,100%),1fr));gap:12px}.categories-page__header{margin-bottom:20px}}@media(max-width:480px){.categories-page__grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.categories-page__card{position:relative;display:flex;align-items:flex-end;aspect-ratio:1;padding:16px;border-radius:12px;color:var(--color-on-media);text-decoration:none;overflow:hidden;box-shadow:var(--shadow-category);transition:transform .2s ease,box-shadow .2s ease,filter .2s ease}.categories-page__card:before{content:"";position:absolute;top:-20%;right:-20%;width:70%;height:70%;border-radius:50%;background:#ffffff24;opacity:0;transform:scale(.85);transition:opacity .25s ease,transform .25s ease;pointer-events:none}.categories-page__card:hover:before,.categories-page__card:focus-visible:before{opacity:1;transform:scale(1)}.categories-page__card:hover{transform:translateY(-2px) scale(1.02);filter:brightness(1.05);box-shadow:var(--shadow-category-hover)}.categories-page__card:focus-visible{outline:var(--outline-width-focus) solid var(--color-text-primary);outline-offset:var(--outline-offset-focus)}.categories-page__card-icon-wrap{position:absolute;top:12px;right:12px;display:grid;place-items:center;width:76px;height:76px;pointer-events:none}.categories-page__card-icon{width:64px;height:64px;opacity:.42;transform:rotate(14deg) translateY(6px);filter:drop-shadow(0 4px 10px rgba(0,0,0,.22));transition:transform .25s cubic-bezier(.34,1.4,.64,1),opacity .2s ease}.categories-page__card:hover .categories-page__card-icon,.categories-page__card:focus-visible .categories-page__card-icon{opacity:.92;transform:rotate(0) scale(1.12) translateY(0)}.categories-page__card-label{position:relative;z-index:1;font-size:18px;font-weight:700;line-height:1.2;text-shadow:0 1px 3px rgba(0,0,0,.3)}.modal-shell{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:grid;place-items:center;padding:max(16px,env(safe-area-inset-top,0px)) 16px max(16px,env(safe-area-inset-bottom,0px));font-family:var(--font-family-base)}.modal-shell__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;margin:0;padding:0;border:0;background:var(--color-overlay);cursor:pointer}.modal-shell__close{position:absolute;top:16px;right:16px;z-index:1;width:36px;height:36px;display:grid;place-items:center;padding:0;border:0;border-radius:var(--radius-pill);background:transparent;color:var(--color-text-secondary);font-size:24px;line-height:1;cursor:pointer}.modal-shell__close:hover{background:var(--color-control);color:var(--color-text-primary)}.modal-shell__close:focus-visible{outline:var(--outline-width-focus) solid var(--color-text-primary);outline-offset:var(--outline-offset-focus)}.modal-shell__panel{position:relative;width:min(100%,420px);padding:28px;border-radius:20px;background:var(--color-surface);box-shadow:var(--shadow-modal)}.modal-shell__content{padding-right:28px}.modal-shell__title{margin:0;font-size:1.25rem;font-weight:700;color:var(--color-text-primary)}.modal-shell__subtitle{margin:8px 0 0;font-size:.9rem;color:var(--color-text-secondary)}.modal-shell__subtitle--error{color:var(--color-danger-strong)}.playlist-form-input{width:100%;padding:12px 14px;margin-top:var(--space-progress-gap);border:1px solid var(--color-border-strong);border-radius:var(--radius-card);background:var(--color-surface);color:var(--color-text-primary);font:inherit;box-sizing:border-box}.playlist-form-input--inline{width:auto;flex:1;margin-top:0}.playlist-form-submit{margin-top:16px}.playlist-detail__btn-icon{width:var(--size-control-icon);height:var(--size-control-icon);flex-shrink:0;stroke-width:var(--icon-stroke-cta)}.playlist-cover{display:grid;gap:2px;border-radius:var(--radius-md);overflow:hidden;background:var(--color-control);aspect-ratio:1}.playlist-cover--md{width:100%}.playlist-cover--lg{width:200px;flex-shrink:0}.playlist-cover--tiles-1{grid-template-columns:1fr}.playlist-cover--tiles-2{grid-template-columns:1fr 1fr}.playlist-cover--tiles-4{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.playlist-cover__tile{width:100%;height:100%;object-fit:cover}.playlist-cover__tile--single{grid-column:1 / -1;grid-row:1 / -1}.song-card__art-wrap .playlist-card__cover{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;border-radius:var(--radius-card)}.playlist-detail__hero{display:flex;align-items:flex-end;gap:24px;padding:0 var(--app-main-padding-inline) 24px;min-width:0}.playlist-detail__info{display:flex;flex-direction:column;gap:8px;min-width:0;flex:1}.playlist-detail__type{margin:0;font-size:var(--font-size-time);font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-secondary)}.playlist-detail__title{margin:0;font-size:clamp(1.5rem,4vw,2.25rem);font-weight:700;line-height:1.1}.playlist-detail__desc{margin:0;color:var(--color-text-secondary);font-size:var(--font-size-artist)}.playlist-detail__stats{margin:0;font-size:var(--font-size-artist);color:var(--color-text-secondary)}.playlist-detail__actions{display:flex;flex-wrap:wrap;align-items:center;gap:10px;padding:0 var(--app-main-padding-inline) 20px}.playlist-detail__btn{display:inline-flex;align-items:center;gap:var(--space-controls-gap);padding:10px 18px;border:none;border-radius:var(--radius-pill);background:var(--color-accent);color:var(--color-on-media);font:inherit;font-size:var(--font-size-artist);font-weight:600;letter-spacing:var(--letter-spacing-ui);cursor:pointer}.playlist-detail__btn--compact{flex-shrink:0;padding:10px 16px}.playlist-detail__btn--secondary{background:var(--color-control);color:var(--color-text-primary);border:1px solid var(--color-border)}.playlist-detail__btn:disabled{opacity:.5;cursor:not-allowed}.playlist-detail__share{display:flex;align-items:center;gap:8px;margin-left:auto;flex-wrap:wrap}.playlist-detail__share input{flex:1;min-width:200px;padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius-art-sm);background:var(--color-control);color:var(--color-text-primary);font:inherit;font-size:var(--font-size-artist)}.playlist-song-list{display:flex;flex-direction:column;gap:2px;padding:0 0 120px}.playlist-song-list__empty{padding:24px 0;color:var(--color-text-secondary)}.playlist-song{display:grid;grid-template-columns:32px 48px 1fr auto auto;align-items:center;gap:12px;padding:8px 12px;border-radius:var(--radius-art-sm);transition:background .15s ease}.playlist-song:hover,.playlist-song:focus-within,.playlist-song:has(.action-menu--open){background:var(--color-control)}.playlist-song--active{background:color-mix(in srgb,var(--color-accent) 12%,transparent)}.playlist-song--active:hover,.playlist-song--active:focus-within,.playlist-song--active:has(.action-menu--open){background:color-mix(in srgb,var(--color-accent) 18%,transparent)}.playlist-song--dragging{opacity:.45}.playlist-song--drop-target{outline:2px dashed var(--color-accent);outline-offset:-2px}.playlist-song__index-cell{position:relative;display:grid;place-items:center;width:32px;height:32px}.playlist-song__index{font-size:var(--font-size-artist);color:var(--color-text-secondary);text-align:center;transition:opacity .15s ease}.playlist-song__now-playing{display:inline-flex;align-items:flex-end;justify-content:center;gap:3px;width:20px;height:20px;color:var(--color-accent);transition:opacity .15s ease}.playlist-song__now-playing span{width:3px;border-radius:1px;background:currentColor;transform-origin:bottom;animation:playlist-song-eq .85s ease-in-out infinite}.playlist-song__now-playing span:nth-child(1){height:9px;animation-delay:0s}.playlist-song__now-playing span:nth-child(2){height:16px;animation-delay:.2s}.playlist-song__now-playing span:nth-child(3){height:11px;animation-delay:.4s}@keyframes playlist-song-eq{0%,to{transform:scaleY(.4)}50%{transform:scaleY(1)}}.playlist-song__play{position:absolute;top:0;right:0;bottom:0;left:0;display:inline-flex;align-items:center;justify-content:center;padding:0;border:0;border-radius:50%;background:transparent;color:var(--color-text-primary);cursor:pointer;opacity:0;pointer-events:none;transition:opacity .15s ease,color .15s ease,background .15s ease}.playlist-song__play-icon{width:18px;height:18px}.playlist-song:hover .playlist-song__index,.playlist-song:hover .playlist-song__now-playing,.playlist-song:focus-within .playlist-song__index,.playlist-song:focus-within .playlist-song__now-playing,.playlist-song:has(.action-menu--open) .playlist-song__index,.playlist-song:has(.action-menu--open) .playlist-song__now-playing{opacity:0;pointer-events:none}.playlist-song:hover .playlist-song__play,.playlist-song:focus-within .playlist-song__play,.playlist-song:has(.action-menu--open) .playlist-song__play{opacity:1;pointer-events:auto}.playlist-song--playing:hover .playlist-song__now-playing,.playlist-song--playing:focus-within .playlist-song__now-playing,.playlist-song--playing:has(.action-menu--open) .playlist-song__now-playing{opacity:1;pointer-events:auto}.playlist-song--playing:hover .playlist-song__index,.playlist-song--playing:focus-within .playlist-song__index,.playlist-song--playing:has(.action-menu--open) .playlist-song__index{opacity:0}.playlist-song__play:hover{color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 14%,transparent)}.playlist-song__play:focus-visible{opacity:1;pointer-events:auto;outline:var(--outline-width-focus) solid var(--color-accent);outline-offset:var(--outline-offset-focus)}.playlist-song--active .playlist-song__title{color:var(--color-accent)}.playlist-song__art-wrap{width:48px;height:48px;border-radius:var(--radius-art-sm);overflow:hidden}.playlist-song__art{width:100%;height:100%;border-radius:var(--radius-art-sm)}.playlist-song__meta{min-width:0}.playlist-song__title{display:block;margin:0;font-weight:600;font-size:var(--font-size-artist);color:inherit;text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .15s ease}.playlist-song:hover .playlist-song__title,.playlist-song:focus-within .playlist-song__title{color:var(--color-text-primary)}.playlist-song--active:hover .playlist-song__title,.playlist-song--active:focus-within .playlist-song__title{color:var(--color-accent)}.playlist-song__title:hover{text-decoration:underline}.playlist-song__artist{display:block;margin:var(--space-meta-gap) 0 0;font-size:var(--font-size-artist);color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-song__artist-link:hover{color:var(--color-text-primary)}.playlist-song__duration{font-size:var(--font-size-time);color:var(--color-text-secondary);font-variant-numeric:tabular-nums;transition:opacity .15s ease}.playlist-song:hover .playlist-song__duration,.playlist-song:focus-within .playlist-song__duration{opacity:.55}.playlist-song__menu{flex-shrink:0}.playlist-song__menu .action-menu__trigger{display:grid;place-items:center;width:36px;height:36px;border-radius:50%;color:var(--color-text-secondary);opacity:0;transition:opacity .15s ease,background .15s ease,color .15s ease}.playlist-song:hover .playlist-song__menu .action-menu__trigger,.playlist-song:focus-within .playlist-song__menu .action-menu__trigger,.playlist-song:has(.action-menu--open) .playlist-song__menu .action-menu__trigger,.playlist-song--active .playlist-song__menu .action-menu__trigger{opacity:1}.playlist-song__menu .action-menu__trigger:hover{background:color-mix(in srgb,var(--color-text-primary) 10%,transparent);color:var(--color-text-primary)}@media(hover:none){.playlist-song__menu .action-menu__trigger{opacity:1}.playlist-song__index{display:none}.playlist-song:not(.playlist-song--playing) .playlist-song__play{opacity:1;pointer-events:auto}}@media(prefers-reduced-motion:reduce){.playlist-song,.playlist-song__art,.playlist-song__index,.playlist-song__now-playing,.playlist-song__play,.playlist-song__title,.playlist-song__duration,.playlist-song__menu .action-menu__trigger{transition:none}.playlist-song__now-playing span{animation:none;transform:scaleY(.75)}}.playlist-song__menu .action-menu__trigger svg{width:var(--size-control-icon);height:var(--size-control-icon)}.add-to-playlist__list{display:flex;flex-direction:column;gap:4px;max-height:280px;overflow-y:auto;margin:16px 0}.add-to-playlist__cover{width:40px;height:40px;flex-shrink:0}.add-to-playlist__item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;border:none;border-radius:var(--radius-art-sm);background:transparent;color:inherit;font:inherit;text-align:left;cursor:pointer}.add-to-playlist__item:hover{background:var(--color-control)}.add-to-playlist__item--active{background:color-mix(in srgb,var(--color-accent) 10%,transparent)}.add-to-playlist__check{width:var(--size-control-icon);height:var(--size-control-icon);flex-shrink:0;display:grid;place-items:center;border:2px solid var(--color-border-strong);border-radius:var(--radius-art-sm)}.add-to-playlist__check-icon{width:100%;height:100%;padding:2px;box-sizing:border-box;color:var(--color-on-media)}.add-to-playlist__item--active .add-to-playlist__check{border-color:var(--color-accent);background:var(--color-accent)}.add-to-playlist__create{display:flex;gap:var(--space-progress-gap);margin-top:12px;align-items:stretch}.playlist-detail-header{position:relative;margin:0 0 56px;border-radius:var(--radius-card);color:var(--color-text-primary);isolation:isolate}.playlist-detail-header__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;border-radius:inherit;overflow:hidden;background:var(--color-control)}.playlist-detail-header--themed .playlist-detail-header__backdrop{background:linear-gradient(155deg,var(--playlist-bg-primary, var(--color-control)) 0%,var(--playlist-bg-secondary, var(--color-surface-muted)) 60%,color-mix(in srgb,var(--color-page) 70%,transparent) 100%)}.playlist-detail-header__backdrop-art{position:absolute;top:0;right:0;bottom:0;left:0;background-image:var(--playlist-art-url);background-size:cover;background-position:center;filter:blur(48px) saturate(1.5);transform:scale(1.4);opacity:.45}.playlist-detail-header__backdrop-blobs{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.playlist-detail-header__backdrop-blob{position:absolute;border-radius:50%;filter:blur(70px);opacity:.5}.playlist-detail-header__backdrop-blob--1{width:320px;height:320px;top:-110px;left:-50px;background:var(--playlist-bg-primary, var(--color-accent))}.playlist-detail-header__backdrop-blob--2{width:300px;height:300px;right:-70px;bottom:-120px;background:var(--playlist-bg-secondary, var(--color-accent))}.playlist-detail-header__backdrop-fade{position:absolute;left:0;right:0;bottom:0;height:55%;background:linear-gradient(to bottom,transparent,color-mix(in srgb,var(--color-page) 75%,transparent))}.playlist-detail-header__inner{position:relative;display:flex;flex-direction:column;gap:22px;padding:32px 32px 44px}.playlist-detail-header__main{display:flex;align-items:flex-end;gap:24px;min-width:0}.playlist-detail-header__cover{width:208px;flex-shrink:0;border-radius:var(--radius-card);overflow:hidden;box-shadow:var(--shadow-category)}.playlist-detail-header__info{display:flex;flex-direction:column;gap:10px;min-width:0}.playlist-detail-header__type{margin:0;font-size:var(--font-size-time);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary)}.playlist-detail-header__title{margin:0;font-size:clamp(1.75rem,5vw,3rem);font-weight:800;line-height:1.05;letter-spacing:-.02em;overflow-wrap:anywhere}.playlist-detail-header__desc,.playlist-detail-header__stats{margin:0;font-size:var(--font-size-artist);color:var(--color-text-secondary)}.playlist-detail-header__actions{position:absolute;left:32px;bottom:0;z-index:3;display:flex;flex-direction:row;align-items:center;gap:10px;transform:translateY(50%)}.playlist-detail-header__toolbar{display:flex;flex-wrap:nowrap;align-items:center;gap:10px}.playlist-detail-header__chip{flex-shrink:0;display:inline-flex;align-items:center;gap:8px;height:48px;padding:0 16px;border:1px solid var(--color-border-strong);border-radius:var(--radius-pill);background:var(--color-page);color:var(--color-text-primary);font:inherit;font-size:var(--font-size-artist);font-weight:600;letter-spacing:var(--letter-spacing-ui);cursor:pointer;box-shadow:var(--shadow-play);transition:transform .15s ease}.playlist-detail-header__chip:hover:not(:disabled){transform:scale(1.07)}.playlist-detail-header__chip:disabled{opacity:.5;cursor:not-allowed}.playlist-detail-header__chip--danger{color:var(--color-danger)}.playlist-detail-header__chip--toggle{cursor:pointer}.playlist-detail-header__chip--toggle input{accent-color:var(--color-accent)}.playlist-detail-header__menu{flex-shrink:0}.playlist-detail-header__menu .action-menu__trigger{display:inline-flex;align-items:center;gap:8px;height:48px;padding:0 16px;border:1px solid var(--color-border-strong);border-radius:var(--radius-pill);background:var(--color-page);color:var(--color-text-primary);font:inherit;font-size:var(--font-size-artist);font-weight:600;letter-spacing:var(--letter-spacing-ui);box-shadow:var(--shadow-play);transition:transform .15s ease}.playlist-detail-header__menu .action-menu__trigger:hover{transform:scale(1.07)}.playlist-detail-header__menu .action-menu__trigger-label{line-height:1}.playlist-detail-header__menu .action-menu__trigger svg{width:20px;height:20px}.playlist-detail-header__chip-icon{width:var(--size-control-icon);height:var(--size-control-icon);flex-shrink:0}.playlist-detail-header__play{flex-shrink:0;display:grid;place-items:center;width:64px;height:64px;padding:0;border:none;border-radius:50%;background:var(--color-accent);color:var(--color-on-media);cursor:pointer;box-shadow:var(--shadow-play);transition:transform .15s ease}.playlist-detail-header__play:hover:not(:disabled){transform:scale(1.07)}.playlist-detail-header__play:disabled{opacity:.5;cursor:not-allowed}.playlist-detail-header__play-icon{width:30px;height:30px;margin-left:var(--size-play-icon-offset)}.playlist-detail-header--dark{color:#fff}.playlist-detail-header--dark .playlist-detail-header__type,.playlist-detail-header--dark .playlist-detail-header__desc,.playlist-detail-header--dark .playlist-detail-header__stats{color:#ffffffc7}.playlist-detail-header--dark .playlist-detail-header__chip--danger{color:var(--color-danger)}@media(max-width:640px){.playlist-detail-header{margin:0 0 52px}.playlist-detail-header__inner{padding:24px 20px 40px}.playlist-detail-header__main{flex-direction:column;align-items:center;text-align:center}.playlist-detail-header__cover{width:168px}.playlist-detail-header__info{align-items:center}.playlist-detail-header__actions{left:20px}}.song-artist-link{margin:0;padding:0;border:0;background:none;font:inherit;color:inherit;cursor:pointer;text-align:inherit;text-decoration:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-artist-link:disabled{cursor:wait;opacity:.85}.song-artist-link:hover{text-decoration:underline}.song-card{display:grid;gap:8px;width:100%;min-width:0}.song-card__art-wrap{position:relative;aspect-ratio:1;container-type:inline-size;--song-card-inset: min(5.33cqw, 8px);--song-card-gap: min(5.33cqw, 8px);--song-card-btn: min(24cqw, 40px);--song-card-btn-pad-x: min(8cqw, 12px);--song-card-btn-pad-left: min(6.67cqw, 10px);--song-card-btn-gap: min(4cqw, 6px);--song-card-icon: min(12cqw, 18px);--song-card-label: min(8cqw, 13px);--song-card-menu-icon: min(13.33cqw, 20px);border-radius:var(--radius-card);background:var(--color-art-placeholder)}@container (max-width: 170px){.song-card__art-wrap{--song-card-btn-pad-x: min(5.5cqw, 8px);--song-card-btn-pad-left: min(4.5cqw, 7px);--song-card-btn-gap: min(3cqw, 5px);--song-card-label: min(7cqw, 11px)}}.song-card__art-link{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;display:block;color:inherit;text-decoration:none}.song-card__art{width:100%;height:100%;object-fit:cover;display:block;border-radius:var(--radius-card)}.song-card__art--placeholder{background:var(--color-art-placeholder)}.song-card__actions{position:absolute;right:var(--song-card-inset);bottom:var(--song-card-inset);left:var(--song-card-inset);z-index:2;display:flex;flex-wrap:nowrap;align-items:center;justify-content:flex-end;gap:var(--song-card-gap);visibility:hidden;pointer-events:none}.song-card:hover .song-card__actions,.song-card:focus-within .song-card__actions,.song-card--playing .song-card__actions,.song-card:has(.action-menu--open) .song-card__actions{visibility:visible;pointer-events:auto}.song-card__play{display:inline-flex;align-items:center;justify-content:center;gap:var(--song-card-btn-gap);height:var(--song-card-btn);max-width:calc(100% - var(--song-card-btn) - var(--song-card-gap));padding:0 var(--song-card-btn-pad-x) 0 var(--song-card-btn-pad-left);border:0;border-radius:var(--radius-pill);background:var(--color-accent);color:var(--color-on-media);font-family:var(--font-family-base);cursor:pointer;flex:0 0 auto}.song-card__play:disabled{cursor:wait;opacity:.92}.song-card__play-icon{width:var(--song-card-icon);height:var(--song-card-icon);flex-shrink:0}.song-card__play .playback-spinner.song-card__play-spinner{width:var(--song-card-icon);height:var(--song-card-icon);border-width:max(1px,.12cqw)}.song-card__now-playing{display:inline-flex;align-items:flex-end;justify-content:center;gap:min(2cqw,3px);width:var(--song-card-icon);height:var(--song-card-icon);flex-shrink:0}.song-card__now-playing span{width:min(2cqw,3px);border-radius:1px;background:currentColor;transform-origin:bottom;animation:song-card-eq .85s ease-in-out infinite}.song-card__now-playing span:nth-child(1){height:50%;animation-delay:0s}.song-card__now-playing span:nth-child(2){height:88%;animation-delay:.2s}.song-card__now-playing span:nth-child(3){height:62%;animation-delay:.4s}@keyframes song-card-eq{0%,to{transform:scaleY(.4)}50%{transform:scaleY(1)}}.song-card__play-label{font-size:var(--song-card-label);font-weight:600;line-height:1;white-space:nowrap;flex-shrink:0}.song-card__play:focus-visible{outline:var(--outline-width-focus) solid var(--color-text-primary);outline-offset:var(--outline-offset-focus)}.song-card__menu{flex:0 0 auto}.song-card__menu .action-menu__trigger{display:grid;place-items:center;width:var(--song-card-btn);height:var(--song-card-btn);border-radius:var(--radius-pill);background:var(--color-surface);color:var(--color-text-primary);box-shadow:none}.song-card__menu .action-menu__trigger svg{width:var(--song-card-menu-icon);height:var(--song-card-menu-icon)}.song-card__menu .action-menu__trigger:hover{background:var(--color-surface);color:var(--color-text-primary)}.song-card__meta{display:grid;gap:2px;min-width:0}.song-card__title-link,.song-card__artist-link{color:inherit;text-decoration:none;min-width:0}.song-card__artist-link:hover{text-decoration:underline}.song-card__title,.song-card__artist{margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-card__title{font-size:13px;font-weight:var(--font-weight-title);line-height:1.3;color:var(--color-text-primary)}.song-card__artist{font-size:12px;color:var(--color-text-secondary)}.song-card--playing .song-card__title{color:var(--color-accent)}@media(hover:none){.song-card__actions{visibility:visible;pointer-events:auto}}@media(prefers-reduced-motion:reduce){.song-card__now-playing span{animation:none;transform:scaleY(.75)}}.skeleton{background:linear-gradient(90deg,var(--skeleton-base) 0%,var(--skeleton-highlight) 50%,var(--skeleton-base) 100%);background-size:200% 100%;animation:skeleton-shimmer 1.4s ease-in-out infinite;border-radius:6px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.song-card-skeleton{display:grid;gap:8px;width:100%;min-width:0}.song-card-skeleton__art{aspect-ratio:1;border-radius:var(--radius-card)}.song-card-skeleton__meta{display:grid;gap:6px;min-width:0}.song-card-skeleton__title{height:14px;width:88%}.song-card-skeleton__artist{height:12px;width:62%}.browse-page{width:100%;min-width:0;padding:calc(var(--size-app-header-height) + var(--app-main-padding-inline)) 0 var(--app-main-padding-inline);box-sizing:border-box;color:var(--color-text-primary);font-family:var(--font-family-base)}.browse-page--playlist-detail{padding-top:var(--app-main-padding-inline)}.browse-page__header{position:fixed;top:0;left:var(--size-sidebar-width);right:var(--size-right-panel-width);z-index:10;min-width:0;background:var(--color-page);box-sizing:border-box}.browse-page__header:after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--color-border);pointer-events:none}.browse-page__toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px 24px;height:var(--size-app-header-height);padding:var(--app-main-padding-inline);box-sizing:border-box;overflow:hidden}.browse-page__heading{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:4px;min-width:0;min-height:0;flex:0 1 auto}.browse-page__toolbar .browse-page__title{line-height:1}.browse-page__actions{display:flex;align-items:center;justify-content:flex-end;gap:14px;flex:1 1 auto;min-width:0}.browse-page__search{flex:1 1 auto;width:auto;max-width:520px;min-width:0}.browse-page__avatar{width:50px;height:50px;flex-shrink:0;display:grid;place-items:center;padding:0;overflow:hidden;border:1px solid var(--color-border-strong);border-radius:50%;background:var(--color-control);color:var(--color-text-secondary);cursor:pointer}.browse-page__avatar svg{width:22px;height:22px}.browse-page__avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.browse-page__avatar:hover{color:var(--color-text-primary)}.browse-page__avatar:focus-visible{outline:var(--outline-width-focus) solid var(--color-text-primary);outline-offset:var(--outline-offset-focus)}.browse-page__desc{margin:0;color:var(--color-text-secondary);font-size:15px;font-weight:500;line-height:1.4}.browse-page__back{display:inline;color:inherit;font-size:inherit;text-decoration:none}.browse-page__back:hover{color:var(--color-text-primary)}.browse-page__title{margin:0;min-width:0;font-size:clamp(32px,5vw,48px);line-height:1.05}.browse-page__toolbar .browse-page__desc{display:none}.browse-page__status{margin:0 0 24px;color:var(--color-text-secondary);font-size:15px}.browse-page__status--error{color:var(--color-danger)}.browse-page__section{margin-bottom:32px}.browse-page__section-head{display:flex;align-items:baseline;gap:10px;margin-bottom:14px}.browse-page__section-title{margin:0;font-size:1.25rem;font-weight:700;line-height:1.2}.browse-page__section-count{color:var(--color-text-secondary);font-size:14px;font-weight:600}.browse-page__status--section{margin:0}.browse-page__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(var(--size-home-song-card-min),1fr));gap:var(--size-home-grid-gap)}.browse-page__grid--artists{grid-template-columns:repeat(auto-fill,minmax(var(--size-home-artist-card-min),1fr));gap:var(--size-home-artist-grid-gap)}.browse-page__section--artists{margin-bottom:24px}.artist-search-row{display:flex;gap:var(--size-home-artist-grid-gap);overflow-x:auto;overscroll-behavior-x:contain;margin-inline:calc(-1 * var(--app-main-padding-inline));padding-block:4px 12px;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.artist-search-row:before,.artist-search-row:after{content:"";flex:0 0 var(--app-main-padding-inline)}.artist-search-row::-webkit-scrollbar{display:none;width:0;height:0}@media(max-width:640px){.browse-page:not(.browse-page--playlist-detail){padding-top:calc(var(--size-app-header-height) + 36px + 50px + var(--app-main-padding-inline))}.browse-page--playlist-detail{padding-top:var(--app-main-padding-inline)}.browse-page__toolbar{flex-direction:column;align-items:stretch;gap:12px;height:auto;min-height:var(--size-app-header-height);overflow:visible}.browse-page__toolbar .browse-page__desc{display:block}.browse-page__title{font-size:clamp(26px,8vw,36px)}.browse-page__actions{width:100%}.browse-page__search{max-width:none;flex:1 1 auto}}.auth-form__header{display:flex;flex-direction:column;align-items:flex-start;gap:6px;margin-bottom:20px}.auth-form__title{margin:0;font-size:28px;font-weight:800;color:var(--color-text-primary)}.auth-form__subtitle{margin:0;color:var(--color-text-secondary);font-size:14px;line-height:1.5}.auth-form__tabs{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-progress-gap);margin-bottom:20px;padding:4px;border-radius:14px;background:var(--color-control)}.auth-form__tab{border:0;border-radius:10px;padding:10px 12px;background:transparent;color:var(--color-text-secondary);font:inherit;font-size:14px;font-weight:600;cursor:pointer}.auth-form__tab--active{background:var(--color-surface);color:var(--color-text-primary);box-shadow:var(--shadow-tab)}.auth-form__form{display:flex;flex-direction:column;gap:16px}.auth-form__field{display:flex;flex-direction:column;gap:var(--space-progress-gap)}.auth-form__label{font-size:13px;font-weight:600;color:var(--color-text-primary)}.auth-form__input{width:100%;padding:12px 14px;border:1px solid var(--color-border-strong);border-radius:var(--radius-card);background:var(--color-surface);color:var(--color-text-primary);font:inherit;box-sizing:border-box}.auth-form__input:focus{outline:2px solid var(--color-text-primary);outline-offset:1px}.auth-form__error{margin:0;color:var(--color-danger-strong);font-size:13px}.auth-form__submit{margin-top:4px;border:0;border-radius:var(--radius-pill);padding:12px 16px;background:var(--color-control-primary);color:var(--color-control-primary-text);font:inherit;font-size:15px;font-weight:700;cursor:pointer}.auth-form__submit:disabled{opacity:.7;cursor:wait}.account-modal__profile{display:flex;align-items:center;gap:14px;margin-bottom:20px;padding:14px;border-radius:14px;background:var(--color-control)}.account-modal__avatar{width:48px;height:48px;flex-shrink:0;display:grid;place-items:center;border-radius:50%;background:var(--color-surface);color:var(--color-text-secondary)}.account-modal__avatar svg{width:24px;height:24px}.account-modal__avatar--button{position:relative;overflow:hidden;padding:0;border:0;cursor:pointer}.account-modal__avatar--button:disabled{cursor:wait}.account-modal__avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.account-modal__avatar-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#00000073;color:#fff;opacity:0;transition:opacity .15s ease}.account-modal__avatar-overlay svg{width:18px;height:18px}.account-modal__avatar--button:hover .account-modal__avatar-overlay,.account-modal__avatar--button:focus-visible .account-modal__avatar-overlay,.account-modal__avatar--button[aria-busy=true] .account-modal__avatar-overlay{opacity:1}.account-modal__avatar--button:focus-visible{outline:var(--outline-width-focus) solid var(--color-text-primary);outline-offset:var(--outline-offset-focus)}.account-modal__file-input{display:none}.account-modal__avatar-actions{display:flex;flex-wrap:wrap;gap:12px}.account-modal__avatar-action{border:0;background:none;padding:0;font:inherit;font-size:13px;font-weight:600;color:var(--color-text-primary);cursor:pointer}.account-modal__avatar-action:hover:not(:disabled){text-decoration:underline}.account-modal__avatar-action:disabled{opacity:.6;cursor:wait}.account-modal__avatar-action--danger{color:var(--color-danger-strong)}.account-modal__avatar-action:focus-visible{outline:var(--outline-width-focus) solid var(--color-text-primary);outline-offset:var(--outline-offset-focus);border-radius:4px}.account-modal__details{min-width:0}.account-modal__email{margin:0 0 4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:var(--font-weight-title);color:var(--color-text-primary)}.account-modal__hint{margin:0;color:var(--color-text-secondary);font-size:13px;line-height:1.4}.account-modal__logout{display:flex;align-items:center;justify-content:center;gap:var(--space-progress-gap);width:100%;margin-top:4px;border:0;border-radius:var(--radius-pill);padding:12px 16px;background:var(--color-control);color:var(--color-text-primary);font:inherit;font-size:15px;font-weight:600;cursor:pointer}.account-modal__logout svg{width:18px;height:18px}.account-modal__logout:hover:not(:disabled){background:var(--color-border-strong)}.account-modal__logout:disabled{opacity:.7;cursor:wait}.account-modal__logout:focus-visible{outline:var(--outline-width-focus) solid var(--color-text-primary);outline-offset:var(--outline-offset-focus)}.account-modal__header{display:flex;flex-direction:column;align-items:flex-start;gap:6px;margin-bottom:20px}.account-modal__title{margin:0;font-size:28px;font-weight:800;color:var(--color-text-primary)}.account-modal__subtitle{margin:0;color:var(--color-text-secondary);font-size:14px;line-height:1.5}.account-modal__error{margin:0;color:var(--color-danger-strong);font-size:13px}.search-bar{display:flex;align-items:center;gap:12px;width:100%;max-width:100%;height:50px;padding:0 18px;border:1px solid var(--color-border-strong);border-radius:var(--radius-pill);background:var(--color-surface);box-sizing:border-box}.search-bar__icon{width:20px;height:20px;flex-shrink:0;color:var(--color-text-secondary)}.search-bar__input{flex:1;min-width:0;width:100%;border:0;background:transparent;color:var(--color-text-primary);font:inherit;font-size:16px;outline:none}.search-bar__input::placeholder{color:var(--color-text-secondary)}.artist-card{display:grid;gap:10px;width:100%;min-width:0;justify-items:center}.artist-card--row{flex:0 0 var(--size-artist-search-card-width);width:var(--size-artist-search-card-width)}.artist-card__art-wrap{position:relative;width:100%;aspect-ratio:1;border-radius:50%;background:var(--color-art-placeholder);overflow:hidden}.artist-card__art-link{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;display:block;color:inherit;text-decoration:none}.artist-card__art{width:100%;height:100%;object-fit:cover;display:block;border-radius:50%}.artist-card__art--placeholder{border-radius:50%;background:var(--color-art-placeholder)}.artist-card__meta{display:grid;gap:2px;width:100%;min-width:0;color:inherit;text-decoration:none;text-align:center}.artist-card__name{margin:0;font-size:13px;font-weight:var(--font-weight-title, 600);line-height:1.3;color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.artist-card__genre{margin:0;font-size:12px;color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.artist-card__follow-pill{width:100%;padding:8px 12px;border-radius:var(--radius-pill);font-family:var(--font-family-base);font-size:13px;font-weight:600}.artist-card__follow-pill:focus-visible{outline:var(--outline-width-focus) solid var(--color-text-primary);outline-offset:var(--outline-offset-focus)}.artist-card-skeleton{display:grid;gap:10px;width:100%;min-width:0;justify-items:center}.artist-card-skeleton__art{width:100%;aspect-ratio:1;border-radius:50%}.artist-card-skeleton__meta{display:grid;gap:6px;width:100%;justify-items:center}.artist-card-skeleton__name{height:14px;width:78%}.artist-card-skeleton__genre{height:12px;width:55%}.artist-card-skeleton--row{flex:0 0 var(--size-artist-search-card-width);width:var(--size-artist-search-card-width)}.artist-page .browse-page__toolbar{flex-wrap:nowrap;overflow:hidden}.artist-page__profile{display:flex;align-items:center;gap:12px;min-width:0;flex:1 1 auto}.artist-page__art{width:56px;height:56px;border-radius:50%;object-fit:cover;flex-shrink:0}.artist-page__art--placeholder{border-radius:50%;background:var(--color-art-placeholder)}.artist-page__heading{display:flex;flex-direction:column;justify-content:center;gap:2px;min-width:0}.artist-page__title{margin:0;font-size:20px;font-weight:700;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.artist-page__genre{margin:0;font-size:13px;font-weight:500;line-height:1.25;color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.artist-page__actions{display:flex;align-items:center;flex-shrink:0}.artist-page__follow{display:inline-flex;align-items:center;justify-content:center;height:36px;padding:0 14px;border-radius:var(--radius-pill);font-family:var(--font-family-base);white-space:nowrap}.artist-page__follow-label{font-size:13px;font-weight:600;line-height:1}.artist-page__follow:focus-visible{outline:var(--outline-width-focus) solid var(--color-text-primary);outline-offset:var(--outline-offset-focus)}.artist-page__section-title{margin:24px 0 12px;font-size:1.125rem;font-weight:700}@media(max-width:640px){.artist-page.browse-page{padding-top:calc(var(--size-app-header-height) + var(--app-main-padding-inline))}.artist-page .browse-page__toolbar{flex-direction:row;align-items:center;height:var(--size-app-header-height);min-height:0;overflow:hidden}.artist-page__title{font-size:18px}.artist-page__art{width:48px;height:48px}.artist-page__follow{height:34px;padding:0 12px}}.lyrics-panel-stage{position:relative;display:flex;flex-direction:column;flex:1 1 auto;min-width:min(var(--size-lyrics-panel-min-width, 0px),100%);min-height:0;max-width:var(--size-lyrics-panel-max-width);width:100%;max-height:none;align-self:stretch;overflow:visible;--lyrics-enter-x: 28px;--lyrics-enter-y: 0;animation:lyrics-panel-stage-in .42s cubic-bezier(.22,1,.36,1) both}.lyrics-panel-stage:has(.lyrics-panel--rtl){--lyrics-enter-x: -28px}.lyrics-panel{position:relative;flex:1 1 auto;min-width:0;max-width:none;width:100%;box-sizing:border-box;max-height:none;height:100%;overflow-x:visible;overflow-y:auto;display:grid;gap:var(--space-lyrics-gap);align-content:start;align-self:stretch;min-height:0;padding:0;scroll-padding-block:env(safe-area-inset-top,0px) env(safe-area-inset-bottom,0px);color:var(--color-text-primary);font-family:var(--font-family-base);text-align:left;-ms-overflow-style:none;scrollbar-width:none;animation:lyrics-panel-content-in .38s cubic-bezier(.22,1,.36,1) both}.lyrics-panel::-webkit-scrollbar{display:none}.lyrics-panel--rtl{text-align:right}.lyrics-panel--synced{display:flex;flex-direction:column;gap:30px;scroll-behavior:smooth}.lyrics-panel--empty{display:flex;flex-direction:column;align-items:center;justify-content:center;align-self:center;min-height:min(320px,100%);gap:16px;text-align:center}.lyrics-panel__line{margin:0;overflow:visible;font-size:var(--font-size-lyrics);font-weight:var(--font-weight-lyrics);line-height:var(--line-height-lyrics);letter-spacing:var(--letter-spacing-lyrics);padding-block:0;padding-inline-start:var(--space-shell-split-pad);padding-inline-end:0;box-sizing:border-box;animation:lyrics-line-in .48s cubic-bezier(.22,1,.36,1) both;animation-delay:var(--line-delay, 0s)}@property --karaoke-fill{syntax: "<percentage>"; inherits: false; initial-value: 0%;}.lyrics-panel--synced .lyrics-panel__line{opacity:var(--lyrics-line-opacity, var(--opacity-lyrics-inactive));filter:blur(var(--lyrics-blur, 0px));transition:filter .4s ease,opacity .3s ease,color .25s ease}.lyrics-panel--synced .lyrics-panel__line--active,.lyrics-panel--synced .lyrics-panel__line--interlude-active{opacity:var(--opacity-lyrics-active);filter:none}.lyrics-panel__line--clickable{display:block;width:100%;border:0;background:none;color:inherit;font-family:inherit;text-align:left;cursor:pointer}.lyrics-panel--rtl .lyrics-panel__line--clickable{text-align:right}.lyrics-panel__line--clickable:hover{opacity:1}.lyrics-panel__line--clickable:focus-visible{outline:var(--outline-width-focus) solid var(--color-text-primary);outline-offset:var(--outline-offset-focus)}.lyrics-panel__line--active,.lyrics-panel__line--interlude-active{opacity:var(--opacity-lyrics-active);font-weight:900;line-height:1.25}.lyrics-panel__word{--karaoke-fill: 0%;--karaoke-sung: var(--color-text-primary);--karaoke-unsung: color-mix(in srgb, var(--color-text-primary) 38%, transparent);display:inline-block;overflow:visible;padding-block:0;padding-inline:.04em;background-image:linear-gradient(90deg,var(--karaoke-sung) var(--karaoke-fill),var(--karaoke-unsung) var(--karaoke-fill));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;-webkit-box-decoration-break:clone;box-decoration-break:clone}.lyrics-panel--rtl .lyrics-panel__word{background-image:linear-gradient(270deg,var(--karaoke-sung) var(--karaoke-fill),var(--karaoke-unsung) var(--karaoke-fill))}.lyrics-panel__word--filling{transition:--karaoke-fill .22s linear}@media(prefers-reduced-motion:reduce){.lyrics-panel__word--filling{transition:none}}.lyrics-panel__line--inactive{opacity:var(--lyrics-line-opacity, var(--opacity-lyrics-inactive))}.lyrics-panel__interlude{display:inline-flex;align-items:center;gap:12px}.lyrics-panel--rtl .lyrics-panel__interlude{flex-direction:row-reverse}.lyrics-panel__note{width:30px;height:30px;color:var(--color-text-primary);opacity:.32;transition:opacity .3s ease,transform .3s ease}.lyrics-panel__note--on{opacity:1}.lyrics-panel__status{margin:0;color:var(--color-text-secondary);font-size:18px;line-height:1.5}.lyrics-panel__status--loading{animation:lyrics-status-pulse 1.5s ease-in-out infinite}.lyrics-panel__status--error{color:var(--color-danger)}@keyframes lyrics-panel-stage-in{0%{opacity:0;transform:translate3d(var(--lyrics-enter-x),var(--lyrics-enter-y),0)}to{opacity:1;transform:translateZ(0)}}@keyframes lyrics-panel-content-in{0%{opacity:0}to{opacity:1}}@keyframes lyrics-line-in{0%{opacity:0;transform:translateY(14px)}}@keyframes lyrics-status-pulse{0%,to{opacity:.45}50%{opacity:1}}@media(max-width:1100px){.lyrics-panel-stage{--lyrics-enter-x: 0;--lyrics-enter-y: 20px}.song-player-shell--lyrics-open .lyrics-panel-stage{padding:0}}@media(prefers-reduced-motion:reduce){.lyrics-panel-stage,.lyrics-panel,.lyrics-panel__line{animation:none}.lyrics-panel--synced .lyrics-panel__line{filter:none}.lyrics-panel__status--loading{animation:none;opacity:.75}}.song-exit-bar-hit{position:relative;flex:0 0 28px;align-self:center;width:28px;height:28px;margin-bottom:14px}.song-exit-bar-hit__zone{position:absolute;top:50%;left:50%;width:96px;height:96px;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center}.song-exit-bar{position:relative;display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;background:transparent;color:var(--color-text-primary);cursor:pointer;transition:transform .35s cubic-bezier(.22,1,.36,1)}.song-exit-bar--following{transition:transform .14s ease-out}.song-exit-bar__bar{width:28px;height:var(--size-track-height);border-radius:var(--radius-pill);background:var(--color-track);opacity:1;transition:opacity .2s ease}.song-exit-bar__square{position:absolute;top:0;right:0;bottom:0;left:0;width:28px;height:28px;aspect-ratio:1;border-radius:var(--radius-art-sm);background:var(--color-track);opacity:0;transition:opacity .2s ease}.song-exit-bar__icon{position:absolute;z-index:1;width:14px;height:14px;opacity:0;transform:scale(.85);transition:opacity .2s ease,transform .2s ease}.song-exit-bar--active .song-exit-bar__bar,.song-exit-bar:hover .song-exit-bar__bar,.song-exit-bar:focus-visible .song-exit-bar__bar{opacity:0}.song-exit-bar--active .song-exit-bar__square,.song-exit-bar:hover .song-exit-bar__square,.song-exit-bar:focus-visible .song-exit-bar__square{opacity:1}.song-exit-bar--active .song-exit-bar__icon,.song-exit-bar:hover .song-exit-bar__icon,.song-exit-bar:focus-visible .song-exit-bar__icon{opacity:.88;transform:scale(1)}.song-exit-bar:focus-visible{outline:var(--outline-width-focus) solid var(--color-text-primary);outline-offset:var(--outline-offset-focus)}@media(hover:none){.song-exit-bar:active .song-exit-bar__bar{opacity:0}.song-exit-bar:active .song-exit-bar__square{opacity:1}.song-exit-bar:active .song-exit-bar__icon{opacity:.88;transform:scale(1)}}@media(prefers-reduced-motion:reduce){.song-exit-bar,.song-exit-bar__bar,.song-exit-bar__square,.song-exit-bar__icon{transition:none}}.song-player-shell{height:100%;min-height:0;display:flex;align-items:center;justify-content:center;gap:var(--space-shell-gap);max-width:100%;transition:gap .42s cubic-bezier(.22,1,.36,1),align-items .42s cubic-bezier(.22,1,.36,1)}.song-player-shell--lyrics-open{align-items:stretch;justify-content:center;gap:var(--space-shell-gap-lyrics);width:100%;height:100%;min-height:0}.song-player-shell--lyrics-open .song-player{align-self:center;margin-inline-end:var(--space-shell-split-pad)}.song-player-shell--lyrics-open .lyrics-panel-stage{min-height:0;height:100%}.song-player{flex-shrink:0;width:min(var(--size-player-max-width),100%);min-height:0;display:flex;flex-direction:column;justify-content:center;gap:var(--space-player-gap);color:var(--color-text-primary);font-family:var(--font-family-base)}.song-player__meta,.song-player__progress,.song-player__controls,.song-player__message{flex:0 0 auto}.song-player__art-wrap{flex:0 0 auto;width:100%;aspect-ratio:var(--size-art-aspect);overflow:hidden;border-radius:var(--radius-card);background:var(--color-art-placeholder)}.song-player__art{width:100%;height:100%;object-fit:cover;display:block}.song-player__art--placeholder{background:var(--color-art-placeholder)}.song-player__like{margin-top:10px;justify-self:center}.song-player__meta{display:grid;gap:var(--space-meta-gap);text-align:center}.song-player__title,.song-player__artist{margin:0}.song-player__title{font-size:var(--font-size-title);font-weight:var(--font-weight-title)}.song-player__artist{color:var(--color-text-secondary);font-size:var(--font-size-artist)}.song-player__artist-link{text-decoration:none}.song-player__artist-link:hover{text-decoration:underline}.song-player__details{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-top:4px;color:var(--color-text-secondary);font-size:12px}.song-player__details span:not(:last-child):after{content:"·";margin-left:8px}.song-player__message{width:100%;margin:0;color:var(--color-text-secondary);font-size:13px;text-align:center}.song-player__progress{width:100%;display:grid;gap:var(--space-progress-gap)}.song-player__track{width:100%;padding:0;border:0;height:var(--size-track-height);overflow:hidden;background:var(--color-track);border-radius:var(--radius-pill);cursor:pointer}.song-player__track:disabled{cursor:not-allowed;opacity:.6}.song-player__fill{width:var(--progress-fill-width);height:100%;background:var(--color-text-primary);border-radius:inherit;pointer-events:none}.song-player__time{display:flex;justify-content:space-between;color:var(--color-text-secondary);font-size:var(--font-size-time)}.song-player__controls{width:100%;display:flex;align-items:center;justify-content:space-between}.song-player__controls-spacer{width:var(--size-control)}.song-player__controls-main{display:flex;gap:var(--space-controls-gap);align-items:center}.song-player__button{width:var(--size-control);height:var(--size-control);display:grid;place-items:center;border:var(--border-width-none);border-radius:var(--radius-pill);background:var(--color-control);color:var(--color-text-primary);cursor:pointer}.song-player__button:disabled{opacity:.45;cursor:not-allowed}.song-player__button svg{width:var(--size-control-icon);height:var(--size-control-icon)}.song-player__button--active{background:var(--color-control-primary);color:var(--color-control-primary-text)}.song-player__button.like-button--active{color:var(--color-like)}.song-player__follow{width:auto;min-width:var(--size-control);height:var(--size-control);padding:0 14px;border-radius:var(--radius-pill)}.song-player__follow-label{font-size:13px;font-weight:600;white-space:nowrap}.song-player__button--primary{background:var(--color-control-primary);color:var(--color-control-primary-text)}.song-player__button--primary svg{width:var(--size-control-icon-primary);height:var(--size-control-icon-primary)}.song-player__button--show-play-icon svg{transform:translate(var(--size-play-icon-offset))}.song-player__playback-spinner{width:var(--size-control-icon-primary);height:var(--size-control-icon-primary)}@media(max-width:1100px){.song-player-shell{height:auto;min-height:100%;padding:16px var(--space-page-inline);overflow-y:auto;box-sizing:border-box}.song-player-shell--lyrics-open{flex:1 1 auto;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:0;height:100%;min-height:0;max-height:none;padding:max(10px,env(safe-area-inset-top,0px)) 0 max(16px,env(safe-area-inset-bottom,0px));overflow:hidden;box-sizing:border-box}.song-player-shell--lyrics-open .song-player{--song-player-compact-art: 44px;--song-player-compact-control: 40px;flex-shrink:0;display:grid;grid-template-columns:28px var(--song-player-compact-art) minmax(0,1fr) var(--song-player-compact-control);grid-template-rows:auto auto;gap:8px 10px;align-items:center;width:100%;max-width:none;margin:0;padding:0 var(--space-page-inline) 10px;box-sizing:border-box;background:transparent}.song-player-shell--lyrics-open .lyrics-panel-stage{width:100%;max-width:none;margin-inline:0}.song-player-shell--lyrics-open .song-exit-bar-hit{grid-column:1;grid-row:1;align-self:center;width:28px;height:28px;margin:0}.song-player-shell--lyrics-open .song-player__art-wrap{grid-column:2;grid-row:1;width:var(--song-player-compact-art);height:var(--song-player-compact-art);border-radius:var(--radius-art-sm)}.song-player-shell--lyrics-open .song-player__meta{grid-column:3;grid-row:1;min-width:0;gap:2px;text-align:left}.song-player-shell--lyrics-open .song-player__title,.song-player-shell--lyrics-open .song-player__artist{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-player-shell--lyrics-open .song-player__title{font-size:14px;font-weight:var(--font-weight-title)}.song-player-shell--lyrics-open .song-player__artist{font-size:12px}.song-player-shell--lyrics-open .song-player__progress{grid-column:1 / -1;grid-row:2;gap:0}.song-player-shell--lyrics-open .song-player__time{display:none}.song-player-shell--lyrics-open .song-player__controls{display:contents}.song-player-shell--lyrics-open .song-player__controls>.song-player__button:first-child,.song-player-shell--lyrics-open .song-player__controls-main .song-player__button:not(.song-player__button--primary),.song-player-shell--lyrics-open .song-player__controls>.song-player__button:last-child{display:none}.song-player-shell--lyrics-open .song-player__controls-main{display:contents}.song-player-shell--lyrics-open .song-player__button--primary{grid-column:4;grid-row:1;width:var(--song-player-compact-control);height:var(--song-player-compact-control);justify-self:end}.song-player-shell--lyrics-open .song-player__button--primary svg,.song-player-shell--lyrics-open .song-player__playback-spinner{width:20px;height:20px}.song-player-shell--lyrics-open .lyrics-panel-stage{flex:1 1 auto;min-height:0;overflow-x:visible;overflow-y:auto;-ms-overflow-style:none;scrollbar-width:none}.song-player-shell--lyrics-open .lyrics-panel-stage::-webkit-scrollbar{display:none}.song-player-shell--lyrics-open .lyrics-panel{height:auto;overflow-y:visible}.song-player{width:100%;max-width:var(--size-player-max-width);margin-inline:auto}}.song-player__button:focus-visible{outline:var(--outline-width-focus) solid var(--color-text-primary);outline-offset:var(--outline-offset-focus)}@media(prefers-reduced-motion:reduce){.song-player-shell{transition:none}}.song-page{position:relative;height:100vh;height:100dvh;overflow:hidden;box-sizing:border-box;width:100%;max-width:calc(var(--size-player-max-width) + var(--size-lyrics-panel-max-width) + 180px);margin:0 auto;padding:max(16px,env(safe-area-inset-top,0px)) max(0px,env(safe-area-inset-right,0px)) max(16px,env(safe-area-inset-bottom,0px)) max(0px,env(safe-area-inset-left,0px));display:flex;flex-direction:column;color:var(--color-text-primary);font-family:var(--font-family-base)}.song-page__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;overflow:hidden;opacity:0;pointer-events:none;background:var(--color-page, #0f0f0f)}.song-page--themed .song-page__backdrop,.song-page--art .song-page__backdrop{opacity:1}.song-page__backdrop-art{position:absolute;top:-30%;right:-30%;bottom:-30%;left:-30%;background-image:var(--song-art-url);background-size:cover;background-position:center;transform:scale(1.15);filter:blur(56px) saturate(1.35) brightness(.92);opacity:.72}.song-page__backdrop-blobs{position:absolute;top:-25%;right:-25%;bottom:-25%;left:-25%}.song-page__backdrop-blob{position:absolute;border-radius:50%;filter:blur(72px);opacity:.85;mix-blend-mode:screen}.song-page__backdrop-blob--1{top:8%;left:4%;width:min(58vw,520px);height:min(58vw,520px);background:var(--song-bg-primary, rgba(99, 102, 241, .55))}.song-page__backdrop-blob--2{right:0;bottom:6%;width:min(52vw,480px);height:min(52vw,480px);background:var(--song-bg-secondary, rgba(236, 72, 153, .5))}.song-page__backdrop-blob--3{top:38%;left:38%;width:min(44vw,400px);height:min(44vw,400px);background:color-mix(in srgb,var(--song-bg-primary, #6366f1) 45%,var(--song-bg-secondary, #ec4899) 55%)}.song-page__backdrop-grain{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:var(--texture-grain-svg);background-size:96px 96px;opacity:.62;mix-blend-mode:overlay}.song-page__backdrop-grain:before,.song-page__backdrop-grain:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:var(--texture-grain-svg);pointer-events:none}.song-page__backdrop-grain:before{background-size:64px 64px;opacity:.45;mix-blend-mode:soft-light;transform:scale(1.04)}.song-page__backdrop-grain:after{background-size:128px 128px;opacity:.38;mix-blend-mode:multiply;filter:contrast(1.35)}.song-page:has(.song-player-shell--lyrics-open) .song-page__backdrop-art{filter:blur(92px) saturate(1.5) brightness(.88);opacity:.8}.song-page:has(.song-player-shell--lyrics-open) .song-page__backdrop-blob{filter:blur(96px);opacity:.92}.song-page:has(.song-player-shell--lyrics-open) .song-page__backdrop-grain{opacity:.78}.song-page:has(.song-player-shell--lyrics-open) .song-page__backdrop-grain:before{opacity:.55}.song-page:has(.song-player-shell--lyrics-open) .song-page__backdrop-grain:after{opacity:.48}.song-page--dark{color:#f8fafc;--color-text-primary: #f8fafc;--color-text-secondary: rgba(248, 250, 252, .7);--color-track: rgba(255, 255, 255, .22);--color-control: rgba(255, 255, 255, .16);--color-control-primary: #ffffff;--color-control-primary-text: #111827;--color-art-placeholder: rgba(255, 255, 255, .16)}.song-page__content{flex:1;min-height:0;display:flex;align-items:center;justify-content:center;overflow:visible;padding-inline:var(--space-page-inline);box-sizing:border-box}.song-page:has(.song-player-shell--lyrics-open){padding-block:0}.song-page:has(.song-player-shell--lyrics-open) .song-page__content{align-items:stretch;align-self:stretch;width:100%;min-height:0;overflow:visible}.song-page__boot{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-player-gap)}.song-page__status{margin:0;color:var(--color-text-secondary);font-size:15px}.song-page__status--error{color:var(--color-danger)}@media(max-width:1100px){.song-page{max-width:100%;height:auto;min-height:100vh;min-height:100dvh;overflow-y:auto;padding-inline:0;display:flex;flex-direction:column}.song-page:has(.song-player-shell--lyrics-open){height:100dvh;min-height:100dvh;overflow:hidden;padding:0}.song-page__content{flex:1 0 auto;overflow:visible;align-items:center;justify-content:center;padding-inline:0;min-height:min(100dvh,100vh)}.song-page:has(.song-player-shell--lyrics-open) .song-page__content{flex:1 1 auto;min-height:0;overflow:hidden;align-items:stretch}.song-page__backdrop-art{filter:blur(48px) saturate(1.3) brightness(.94)}.song-page__backdrop-blob{filter:blur(56px)}}:root{color-scheme:light;--color-page: #ffffff;--color-text-primary: #111827;--color-text-secondary: #6b7280;--color-art-placeholder: #d1d5db;--color-track: #e5e7eb;--color-control: #f3f4f6;--color-control-primary: #111827;--color-control-primary-text: #ffffff;--color-surface-muted: #f9fafb;--color-surface: #ffffff;--color-border: #eef0f3;--color-border-strong: #e5e7eb;--color-danger: #b91c1c;--color-danger-strong: #dc2626;--color-danger-bg: #fef2f2;--color-accent: #ef4444;--color-on-media: #ffffff;--color-overlay: rgba(15, 23, 42, .55);--color-chip-overlay: rgba(255, 255, 255, .92);--color-like: #ef4444;--shadow-menu: 0 8px 24px rgba(0, 0, 0, .12);--shadow-modal: 0 24px 60px rgba(15, 23, 42, .18);--shadow-tab: 0 1px 2px rgba(15, 23, 42, .08);--shadow-category: 0 8px 24px rgba(0, 0, 0, .12);--shadow-category-hover: 0 12px 32px rgba(0, 0, 0, .18);--shadow-chip: 0 2px 8px rgba(0, 0, 0, .15);--shadow-play: 0 4px 12px rgba(0, 0, 0, .25);--skeleton-base: #eef0f3;--skeleton-highlight: #f8f9fa;--font-family-base: Satoshi, Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-title: 20px;--font-size-artist: 14px;--font-size-time: 12px;--font-size-lyrics: 52px;--font-weight-title: 650;--font-weight-lyrics: 800;--line-height-lyrics: 1.1;--letter-spacing-lyrics: -.03em;--letter-spacing-ui: .02em;--opacity-lyrics-active: 1;--opacity-lyrics-inactive: .38;--space-page-inline: 40px;--space-shell-gap: 40px;--space-shell-gap-lyrics: 112px;--space-shell-split-pad: 40px;--space-lyrics-gap: 40px;--space-player-gap: 18px;--space-meta-gap: 4px;--space-progress-gap: 8px;--space-controls-gap: 12px;--size-player-max-width: 460px;--size-art-aspect: 1;--size-track-height: 6px;--size-control: 44px;--size-control-icon: 20px;--size-control-icon-primary: 22px;--icon-stroke-cta: 2.5;--size-lyrics-panel-min-width: 420px;--size-lyrics-panel-max-width: 560px;--size-lyrics-panel-max-height: 100%;--size-play-icon-offset: 1px;--size-app-header-toolbar: 50px;--size-app-header-height: calc( 2 * var(--app-main-padding-inline) + var(--size-app-header-toolbar) );--size-sidebar-width: 280px;--size-right-panel-width: 300px;--size-mobile-nav-height: 0px;--size-bottom-player-height: 132px;--size-home-song-card-min: 150px;--size-home-artist-card-min: 128px;--size-artist-search-card-width: 148px;--size-home-grid-gap: 16px;--size-home-artist-grid-gap: 14px;--app-main-padding-inline: 28px;--app-main-padding-bottom: calc( var(--size-bottom-player-height) + var(--size-mobile-nav-height) + 28px + env(safe-area-inset-bottom, 0px) );--shell-padding: 16px;--radius-card: 12px;--radius-art-sm: 8px;--radius-pill: 999px;--texture-grain-svg: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='1.2' numOctaves='5' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");--border-width-none: 0;--outline-width-focus: 2px;--outline-offset-focus: 3px;--progress-fill-width: 37%}@media(prefers-color-scheme:dark){:root{color-scheme:dark;--color-page: #0a0a0a;--color-text-primary: #f5f5f5;--color-text-secondary: #a3a3a3;--color-art-placeholder: #404040;--color-track: #404040;--color-control: #242424;--color-control-primary: #f5f5f5;--color-control-primary-text: #0a0a0a;--color-surface-muted: #121212;--color-surface: #1c1c1c;--color-border: #262626;--color-border-strong: #3a3a3a;--color-danger: #f87171;--color-danger-strong: #fca5a5;--color-danger-bg: rgba(239, 68, 68, .14);--color-overlay: rgba(0, 0, 0, .65);--color-chip-overlay: rgba(28, 28, 28, .92);--shadow-menu: 0 8px 24px rgba(0, 0, 0, .45);--shadow-modal: 0 24px 60px rgba(0, 0, 0, .55);--shadow-tab: 0 1px 2px rgba(0, 0, 0, .35);--shadow-category: 0 8px 24px rgba(0, 0, 0, .35);--shadow-category-hover: 0 12px 32px rgba(0, 0, 0, .45);--shadow-chip: 0 2px 8px rgba(0, 0, 0, .35);--shadow-play: 0 4px 12px rgba(0, 0, 0, .45);--skeleton-base: #2a2a2a;--skeleton-highlight: #383838}}html,body{height:100%;overflow:hidden}body{margin:0;background:var(--color-page)}#root,.app-layout{height:100%;overflow:hidden}.app-main{min-width:0;height:100%;margin-left:var(--size-sidebar-width);margin-right:var(--size-right-panel-width);padding:0 var(--app-main-padding-inline);padding-bottom:var(--app-main-padding-bottom);box-sizing:border-box;overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain;scrollbar-gutter:stable;scroll-padding-bottom:var(--app-main-padding-bottom)}.app-main--bare{margin-left:0;margin-right:0;padding:0;overflow:hidden}@media(max-width:1280px){:root{--size-right-panel-width: 0px}.app-main:not(.app-main--bare){margin-right:0}}@media(max-width:1100px){:root{--size-lyrics-panel-min-width: 0px;--size-lyrics-panel-max-width: 100%;--space-shell-gap-lyrics: 32px;--space-shell-split-pad: 24px;--font-size-lyrics: clamp(28px, 6vw, 44px);--space-page-inline: 24px}}@media(max-width:1024px){:root{--size-sidebar-width: 72px;--shell-padding: 8px;--app-main-padding-inline: 20px;--space-shell-gap: 24px}}@media(max-width:900px){:root{--size-home-song-card-min: 136px;--size-home-artist-card-min: 120px;--size-artist-search-card-width: 132px;--size-home-grid-gap: 12px;--size-home-artist-grid-gap: 12px}}@media(max-width:768px){:root{--size-sidebar-width: 0px;--size-mobile-nav-height: 64px;--size-bottom-player-height: 118px;--app-main-padding-inline: 16px;--size-home-song-card-min: min(168px, calc((100vw - 44px)/2) )}}@media(max-width:640px){:root{--size-bottom-player-height: 108px;--font-size-title: 18px}}@media(max-width:480px){:root{--size-home-song-card-min: min(160px, calc((100vw - 44px)/2) );--size-bottom-player-height: 100px}}.queue-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:85;margin:0;padding:0;border:0;background:var(--color-overlay);cursor:pointer;animation:queue-backdrop-in .2s ease}@keyframes queue-backdrop-in{0%{opacity:0}to{opacity:1}}.player-yt{position:fixed;left:0;bottom:0;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}.app-loading{min-height:100vh;display:grid;place-items:center;color:var(--color-text-secondary);font-family:var(--font-family-base);font-size:15px}.follow-button,.artist-card__follow-pill,.artist-page__follow,.song-player__follow,.bottom-player__follow{cursor:pointer;border:1px solid var(--color-accent);background:var(--color-accent);color:var(--color-on-media)}.follow-button--active,.artist-card__follow-pill--active,.artist-page__follow--active,.song-player__follow--active,.bottom-player__follow--active{border-color:var(--color-border);background:var(--color-control);color:var(--color-text-primary)}
