.rank-complete{flex:1;min-height:0;display:flex;flex-direction:column;gap:0}.rank-complete__header{flex-shrink:0;padding-bottom:.75rem}.rank-complete__header h2{margin:0 0 .25rem;font-size:1.5rem}.rank-complete__subtitle{margin:0;opacity:.75;font-size:.95rem}.rank-complete__scroll{flex:1;min-height:0;overflow-y:auto;overscroll-behavior:contain;padding-right:.15rem}.rank-complete__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.rank-complete__row{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;border-radius:8px;background:#ffffff0f}.rank-complete__rank{flex:0 0 1.75rem;font-weight:600;opacity:.6;text-align:right}.rank-complete__art{flex-shrink:0;border-radius:4px;object-fit:cover}.rank-complete__art--placeholder{display:block;width:48px;height:48px;background:#ffffff1f}.rank-complete__meta{display:flex;flex-direction:column;gap:.15rem;min-width:0}.rank-complete__name{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rank-complete__subtitle-row{font-size:.85rem;opacity:.7;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rank-complete__footer{flex-shrink:0;display:flex;flex-direction:column;gap:.65rem;padding-top:.85rem;border-top:1px solid var(--border)}.rank-complete__dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:flex;align-items:center;justify-content:center;padding:1rem;background:#0009}.rank-complete__dialog{width:min(24rem,100%);padding:1.1rem 1.15rem 1rem;border-radius:12px;border:1px solid var(--border);background:var(--surface);box-shadow:0 12px 40px #00000073}.rank-complete__dialog-title{margin:0 0 .35rem;font-size:1.1rem}.rank-complete__dialog-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:.5rem;margin-top:1rem}.rank-complete__dialog .rank-complete__playlist-hint{margin-bottom:.75rem}.rank-complete__dialog .rank-complete__status{margin-top:.65rem;text-align:left}.rank-complete__playlist-label{font-size:.85rem;font-weight:600;color:var(--text)}.rank-complete__playlist-input{width:100%;padding:.55rem .75rem;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:.95rem;box-sizing:border-box}.rank-complete__playlist-input:focus{outline:2px solid color-mix(in srgb,var(--accent) 55%,transparent);outline-offset:1px;border-color:var(--accent)}.rank-complete__playlist-input:disabled{opacity:.6}.rank-complete__playlist-hint{margin:0;font-size:.8rem;color:var(--muted);line-height:1.35}.rank-complete__playlist-link{display:inline-block;margin-top:.5rem;color:#1db954;font-weight:600;text-decoration:none}.rank-complete__playlist-link:hover{text-decoration:underline}.rank-complete__actions{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;justify-content:center}.rank-complete__cta{padding:.65rem 1.25rem;font-size:1rem;font-weight:600;border:none;border-radius:999px;background:#1db954;color:#000;cursor:pointer}.rank-complete__cta:disabled{opacity:.55;cursor:not-allowed}.rank-complete__secondary{padding:.5rem 1rem;border-radius:999px;border:1px solid rgba(255,255,255,.25);background:transparent;color:inherit;cursor:pointer}.rank-complete__status{margin:0;font-size:.95rem;text-align:center}.rank-complete__status--success{color:#1ed760}.rank-complete__status--warn{color:#f5a623}.rank-complete__status--error{color:#ff6b6b}.rank-complete__link{margin-top:.5rem;padding:0;border:none;background:none;color:#1db954;text-decoration:underline;cursor:pointer;font-size:inherit}@media(min-width:801px){.rank-complete__header{text-align:center}.rank-complete__row{padding:.6rem 1rem}.rank-complete__rank{flex-basis:2.25rem;font-size:1.05rem}}.binary-placement{display:flex;flex-direction:column;gap:1.25rem}.binary-placement__header{text-align:center}.binary-placement__progress{margin:0 0 .35rem;color:var(--muted);font-size:.9rem}.binary-placement__prompt{margin:0;font-size:1.35rem;font-weight:700;letter-spacing:-.02em}.binary-placement__hint{margin:.35rem 0 0;color:var(--muted);font-size:.9rem}.binary-placement__cards{display:grid;grid-template-columns:1fr auto 1fr;gap:1rem;align-items:stretch}.binary-placement__vs{align-self:center;font-size:.85rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}@media(max-width:720px){.binary-placement__cards{grid-template-columns:1fr;gap:.75rem}.binary-placement__vs{justify-self:center;padding:.15rem 0}}.song-compare-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:.85rem;width:100%;padding:1.1rem 1rem 1.25rem;border:1px solid var(--border);border-radius:16px;background:linear-gradient(180deg,#1e1e28,#14141c);color:inherit;cursor:pointer;text-align:center;transition:border-color .2s ease,box-shadow .2s ease,transform .15s ease}.song-compare-card:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:17px;background:radial-gradient(120% 80% at 50% 0%,rgba(29,185,84,.22),transparent 55%);opacity:0;pointer-events:none;transition:opacity .2s ease}.song-compare-card:hover,.song-compare-card:focus-visible{border-color:#1db9548c;transform:translateY(-2px);box-shadow:0 12px 40px #00000073,0 0 0 1px #1db95426;outline:none}.song-compare-card:hover:before,.song-compare-card:focus-visible:before{opacity:1}.song-compare-card--selected{border-color:var(--accent);box-shadow:0 0 0 2px #1db95459}.song-compare-card__badge{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--accent)}.song-compare-card__art-wrap{position:relative;width:min(100%,220px);aspect-ratio:1}.song-compare-card__art-wrap:after{content:"";position:absolute;top:8%;right:8%;bottom:8%;left:8%;border-radius:50%;background:radial-gradient(circle,rgba(29,185,84,.12),transparent 70%);filter:blur(12px);z-index:0;pointer-events:none}.song-compare-card__art{position:relative;z-index:1;width:100%;height:100%;min-width:200px;min-height:200px;object-fit:cover;border-radius:12px;box-shadow:0 16px 32px #00000080,0 4px 12px #00000059}.song-compare-card__art--placeholder{display:block}.song-compare-card__meta{width:100%;min-width:0}.song-compare-card__title{margin:0;font-size:1.05rem;font-weight:700;line-height:1.25;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.song-compare-card__artist{margin:.25rem 0 0;font-size:.9rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-compare-card__cta{font-size:.8rem;color:var(--muted);opacity:0;transition:opacity .2s ease}.song-compare-card:hover .song-compare-card__cta,.song-compare-card:focus-visible .song-compare-card__cta{opacity:1}.rank__panel--compare{grid-column:1 / -1;max-width:100%;margin:0 auto;width:100%}.rank--comparing .segment-placement{flex:1;min-height:0;gap:.25rem;overflow:hidden}.rank--comparing .segment-placement__progress{font-size:.75rem}.rank--comparing .segment-placement__candidate{flex-shrink:0;flex-direction:row;flex-wrap:wrap;align-items:center;justify-content:center;gap:.35rem .5rem;text-align:left}.rank--comparing .segment-placement__candidate-label{width:100%;margin:0;font-size:.8rem;text-align:center}.rank--comparing .segment-placement__candidate-card{flex-direction:row;align-items:center;gap:.5rem;padding:.35rem .5rem;max-width:none;border-width:1px}.rank--comparing .segment-placement__candidate-art,.rank--comparing .segment-placement__candidate-art--placeholder{width:40px;height:40px}.rank--comparing .segment-placement__candidate-name{font-size:.85rem}.rank--comparing .segment-placement__candidate-artist{font-size:.75rem}.rank--comparing .segment-placement__discard{margin:0;padding:.2rem .4rem;border:none;background:transparent;color:var(--muted);font-size:.7rem;text-decoration:underline;cursor:pointer}.rank--comparing .segment-placement__list{flex:1 1 0;min-height:0;max-width:none;margin:0;padding:.25rem .35rem;display:flex;flex-direction:column;gap:.2rem;overflow:hidden}.rank--comparing .segment-placement__list-edge{flex:0 0 auto;padding:.1rem .35rem;font-size:.6rem}.rank--comparing .segment-placement__block{display:contents}.rank--comparing .segment-placement__row{flex:1 1 0;min-height:2.75rem;padding:.35rem .55rem;gap:.55rem;align-items:center}.rank--comparing .segment-placement__row-art,.rank--comparing .segment-placement__row-art--placeholder{width:clamp(2rem,12vw,3.5rem);height:clamp(2rem,12vw,3.5rem)}.rank--comparing .segment-placement__row-name{font-size:clamp(.8rem,2.2vw,1rem)}.rank--comparing .segment-placement__row-artist{font-size:clamp(.7rem,1.8vw,.9rem)}.rank--comparing .segment-placement__row-pos{font-size:clamp(.75rem,2vw,.95rem)}.rank--comparing .segment-placement__here-row{flex:1 1 0;min-height:1.85rem;margin:0;padding:.35rem .5rem;display:flex;align-items:center;justify-content:center;font-size:clamp(.68rem,2vw,.85rem)}.segment-placement{display:flex;flex-direction:column;gap:1.25rem;height:100%}.segment-placement__header{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.35rem .75rem}.rank--comparing .segment-placement__header{flex-shrink:0}.segment-placement__undo{padding:.25rem .55rem;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--muted);font-size:.75rem;cursor:pointer}.segment-placement__undo:hover{border-color:var(--accent);color:var(--text)}.segment-placement__progress{margin:0;color:var(--muted);font-size:.9rem}.segment-placement__candidate{display:flex;flex-direction:column;align-items:center;text-align:center}.segment-placement__discard{margin-top:.85rem;font-size:.9rem;color:var(--muted)}.segment-placement__candidate-label{margin:0 0 .75rem;font-size:1.1rem;font-weight:600;color:var(--accent)}.segment-placement__candidate-card{display:inline-flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;border-radius:12px;background:var(--surface);border:2px solid var(--accent);max-width:280px}.segment-placement__candidate-art{width:120px;height:120px;border-radius:8px;object-fit:cover}.segment-placement__candidate-art--placeholder{display:block;width:120px;height:120px;border-radius:8px;background:linear-gradient(135deg,#333,#1a1a22)}.segment-placement__candidate-name{font-size:1.1rem;font-weight:700}.segment-placement__candidate-artist{font-size:.9rem;color:var(--muted)}.segment-placement__prompt{margin:0;text-align:center;color:var(--muted);font-size:.95rem}.segment-placement__list{display:flex;flex-direction:column;gap:.15rem;max-width:32rem;margin:0 auto;padding:.5rem;border-radius:12px;background:var(--surface);border:1px solid var(--border)}.segment-placement__list-edge{margin:0;padding:.35rem .5rem;font-size:.7rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.segment-placement__block{display:flex;flex-direction:column}.segment-placement__row{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;border-radius:8px;background:#252530;border:1px solid var(--border)}.segment-placement__row-art{flex-shrink:0;width:48px;height:48px;border-radius:6px;object-fit:cover}.segment-placement__row-art--placeholder{display:block;width:48px;height:48px;border-radius:6px;background:linear-gradient(135deg,#333,#1a1a22)}.segment-placement__row-meta{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}.segment-placement__row-name{font-size:.95rem;font-weight:600;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.segment-placement__row-artist{font-size:.85rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.segment-placement__row-pos{flex-shrink:0;font-size:.85rem;font-weight:600;color:var(--muted)}.segment-placement__here-row{display:block;width:100%;margin:0;padding:.55rem 1rem;border:1px dashed var(--accent);border-radius:8px;background:#1a2e22;color:var(--accent);font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;text-align:center}.segment-placement__here-row:hover{background:var(--accent);color:#0f0f12}:root{--bg: #0f0f12;--surface: #1a1a22;--border: #2e2e3a;--text: #f4f4f8;--muted: #9a9aad;--accent: #1db954;--accent-dim: #169c46;--warn-bg: #3a2f14;--warn-border: #c9a227;font-family:Segoe UI,system-ui,sans-serif;line-height:1.5;color:var(--text);background:var(--bg)}*{box-sizing:border-box}html{height:100%}body{margin:0;min-height:100%}#root{min-height:100%}.app-shell{min-height:100dvh;display:flex;flex-direction:column}html:has(.app-shell--rank),html:has(.app-shell--rank) body,html:has(.app-shell--rank) #root{height:100dvh;max-height:100dvh;overflow:hidden;overscroll-behavior:none}html:has(.app-shell--rank) #root{display:flex;flex-direction:column;min-height:0}.app-shell--rank{flex:1;min-height:0;height:auto;max-height:none;overflow:hidden}.app-shell__main{flex:1;min-height:0;display:flex;flex-direction:column}.app-shell--rank .app-shell__main{overflow:hidden}a{color:var(--accent)}.app-header{display:grid;grid-template-columns:minmax(0,auto) 1fr minmax(0,auto);align-items:center;gap:.5rem .75rem;flex-shrink:0;max-width:1100px;width:100%;margin:0 auto;padding:.55rem 1rem .6rem;box-sizing:border-box;border-bottom:1px solid var(--border);background:var(--bg)}.app-header__left,.app-header__right{display:flex;align-items:center;min-width:0}.app-header__right{justify-content:flex-end}.app-header__center{min-width:0;text-align:center;padding:0 .15rem}.app-header__brand{font-size:1.2rem;font-weight:700;color:var(--text);letter-spacing:-.02em;white-space:nowrap}.app-header__home{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .9rem;font-size:.9rem;font-weight:600;color:var(--text);text-decoration:none;white-space:nowrap}.app-header__home:hover{color:var(--text);text-decoration:none;background:var(--surface);border-color:color-mix(in srgb,var(--border) 70%,var(--muted))}.app-header__home-icon{display:inline-flex;flex-shrink:0;line-height:0;opacity:.9}.app-header__title{margin:0;font-size:.95rem;font-weight:600;line-height:1.25;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(min-width:640px){.app-header{padding:.65rem 1.25rem .7rem;gap:.75rem 1rem}.app-header__brand{font-size:1.35rem}.app-header__home{padding:.5rem 1rem;font-size:.95rem}.app-header__title{font-size:1.1rem;font-weight:700}}.language-selector{display:inline-flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--muted)}.language-selector--compact{gap:0}.language-selector__select{padding:.45rem 2.1rem .45rem .75rem;min-height:2.25rem;border-radius:999px;border:1px solid var(--border);background-color:var(--surface);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%239a9aad'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .55rem center;background-size:1.1rem;color:var(--text);font-size:.875rem;font-weight:500;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none}.language-selector--compact .language-selector__select{padding:.45rem 2.15rem .45rem .85rem;min-width:5.5rem}.app-header .language-selector__select:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.page{max-width:1100px;margin:0 auto;padding:1rem 1.25rem 2rem}.lead{font-size:1.125rem;color:var(--muted);max-width:42rem}.home__features{color:var(--muted)}.home__actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:2rem}.btn{display:inline-flex;align-items:center;padding:.6rem 1.1rem;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text);text-decoration:none;font-size:.95rem;cursor:pointer}.btn--primary{background:var(--accent);border-color:var(--accent);color:#000;font-weight:600}.btn--primary:hover{background:var(--accent-dim)}.btn--ghost{background:transparent}.btn:disabled{opacity:.45;cursor:not-allowed}.banner{padding:.75rem 1rem;border-radius:8px;margin-bottom:1.25rem}.banner--ok{background:color-mix(in srgb,var(--accent) 18%,transparent);border-color:color-mix(in srgb,var(--accent) 40%,transparent);color:var(--text)}.banner--warn{background:var(--warn-bg);border:1px solid var(--warn-border);color:#f5e6b8}.banner--info{background:color-mix(in srgb,var(--accent) 12%,var(--surface));border:1px solid color-mix(in srgb,var(--accent) 35%,transparent);color:var(--text)}.banner__detail{margin:.35rem 0 0;font-size:.95rem}.rank__subtitle{color:var(--muted);margin:0 0 1.25rem}.page.rank--select,.page.rank--comparing,.page.rank--sort{padding:.35rem .75rem;margin-bottom:0;box-sizing:border-box}.rank--select,.rank--comparing,.rank--sort{flex:1;min-height:0;width:100%;max-width:1100px;margin:0 auto;display:flex;flex-direction:column;overflow:hidden}.rank--select .rank__subtitle{flex-shrink:0;margin:0 0 .35rem;font-size:.9rem;line-height:1.35}.rank--select .rank__banner{flex-shrink:0;margin:0 0 .35rem;padding:.45rem .65rem;font-size:.85rem}.rank--select .rank__layout--select{flex:1;min-height:0;display:grid;grid-template-columns:1fr 1fr;gap:.75rem;align-items:stretch;overflow:hidden}.rank--select .rank__layout--select>*{min-height:0;display:flex;flex-direction:column;overflow:hidden}.rank--select .rank__layout--select .rank__panel{flex:1;min-height:0;display:flex;flex-direction:column;padding:.65rem .75rem;overflow:hidden}.rank--select .rank__panel h2{flex-shrink:0;margin:0 0 .35rem;font-size:1rem}.rank--select .rank__panel-meta{flex-shrink:0;margin:0 0 .35rem;font-size:.85rem;color:var(--muted)}.rank--select .rank__panel-body{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}.rank--select .rank__panel-footer{flex-shrink:0;padding-top:.5rem}.rank--select .search-panel{flex:1;min-height:0;height:100%;display:flex;flex-direction:column;overflow:hidden}.rank--select .search-panel .spotify-user-badge,.rank--select .search-panel__label,.rank--select .search-panel__input,.rank--select .search-panel__hint,.rank--select .search-panel__tabs,.rank--select .search-panel__status{flex-shrink:0}.rank--select .search-panel .spotify-user-badge,.rank--select .search-panel__input,.rank--select .search-panel__tabs{margin-bottom:.35rem}.rank--select .search-results{flex:1 1 auto;min-height:0;max-height:none;overflow-y:auto;margin:0;-webkit-overflow-scrolling:touch}.rank--select .track-list{flex:1;min-height:0;max-height:none;overflow-y:auto;margin:0}.rank--select .selected-tracks{flex:1;min-height:0;max-height:none;overflow:hidden;display:flex;flex-direction:column}.rank--select .rank__panel-footer .btn--primary{width:100%}.rank--select .selected-tracks__toolbar,.rank--select .selected-tracks__album-actions{flex-shrink:0}.rank--select .selected-tracks__body{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.rank--select .selected-tracks__list,.rank--select .selected-tracks__albums{flex:1;min-height:0;max-height:none;overflow-y:auto;margin-bottom:0}.rank--sort .rank__layout--done{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}.rank--sort .rank__panel--done{flex:1;min-height:0;width:100%;max-width:40rem;margin:0 auto;display:flex;flex-direction:column;overflow:hidden;padding:.35rem .5rem .5rem;box-sizing:border-box}.rank-done__footer{flex-shrink:0;padding-top:.5rem}.rank__done-actions{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin:0}@media(min-width:801px){.rank--sort .rank__panel--done{max-width:min(52rem,100%);padding:.5rem 1rem .75rem}.rank-complete__footer{padding-top:1rem}.rank-done__footer{padding-top:.75rem}}.rank__ranking-sheet-actions{display:flex;align-items:center;gap:.35rem}.rank__sheet-undo{padding:.35rem .6rem;font-size:.8rem}.selected-tracks__body{flex:1;min-height:0;overflow-y:auto}.selected-tracks__toolbar,.selected-tracks__album-actions{flex-shrink:0}@media(max-width:800px){.page.rank--select{padding:.25rem .5rem}.rank--select-mobile .rank__layout--select{grid-template-columns:1fr;grid-template-rows:1fr;flex:1;min-height:0;overflow:hidden}.rank--select-mobile .rank__select-step{flex:1;min-height:0;display:flex;flex-direction:column;gap:.4rem;overflow:hidden}.rank--select-mobile .rank__select-step .rank__panel{flex:1;min-height:0}.rank--select-mobile .rank__panel--search,.rank--select-mobile .rank__panel--selected{flex:1;min-height:0;max-height:none;padding-bottom:.5rem}.rank--select-mobile .rank__panel-footer{flex-shrink:0;margin:0;padding:.5rem 0 0;padding-bottom:max(.85rem,calc(.5rem + env(safe-area-inset-bottom)))}.rank--select-mobile .rank__continue-btn,.rank--select-mobile .rank__panel-footer .btn--primary{width:100%;padding:.55rem .85rem;font-size:.875rem;font-weight:600}.rank--select-mobile .rank__panel-top-actions{flex-shrink:0;margin-bottom:.25rem}.rank--select-mobile .rank__back-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .75rem .45rem .35rem;font-size:.9rem;font-weight:600}.rank--select-mobile .rank__back-btn-icon{flex-shrink:0;line-height:0;opacity:.9}.rank--select-mobile .search-panel__hint{margin-bottom:.35rem}}.rank--comparing .rank__layout--compare{flex:1;min-height:0;display:flex;flex-direction:column;gap:0;overflow:hidden}.rank--comparing .rank__panel--compare{flex:1;min-height:0;display:flex;flex-direction:column;padding:.4rem .6rem;overflow:hidden;margin:0}.ranking-time-info{position:fixed;top:.65rem;right:.65rem;z-index:40}@media(max-width:420px){.ranking-time-info__hint{display:none}}.ranking-time-info__trigger{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .55rem;border-radius:999px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface) 92%,transparent);color:var(--muted);font-size:.75rem;cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.ranking-time-info__trigger:hover{border-color:var(--accent);color:var(--text)}.ranking-time-info__icon{display:inline-flex;align-items:center;justify-content:center;width:1.1rem;height:1.1rem;border-radius:50%;border:1px solid currentColor;font-size:.65rem;font-weight:700;font-style:italic;line-height:1}.ranking-time-info__hint{font-weight:600;color:var(--text)}.ranking-time-info__popover{position:absolute;top:calc(100% + .35rem);right:0;width:min(16rem,calc(100vw - 1.5rem));padding:.65rem .75rem;border-radius:10px;border:1px solid var(--border);background:var(--surface);box-shadow:0 8px 24px #00000073}.ranking-time-info__line{margin:0;font-size:.8rem;line-height:1.4}.ranking-time-info__line+.ranking-time-info__line{margin-top:.4rem}.ranking-time-info__line--warn{color:#e8d49a}.ranking-time-info__line--muted{color:var(--muted);font-size:.75rem}.rank__show-ranking,.rank__ranking-overlay{display:none}@media(max-width:800px){.rank--comparing .rank__panel--compare{padding-bottom:2.75rem}.rank--comparing .rank__show-ranking{display:inline-flex;position:fixed;bottom:max(.5rem,env(safe-area-inset-bottom));left:50%;z-index:35;transform:translate(-50%);margin:0;padding:.45rem .9rem;border:1px solid var(--border);border-radius:999px;background:color-mix(in srgb,var(--surface) 94%,transparent);color:var(--muted);font-size:.8rem;cursor:pointer;box-shadow:0 4px 16px #00000073;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.rank--comparing .rank__ranking-overlay{display:flex;position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;align-items:flex-end;justify-content:center;padding:.5rem;background:#0000008c}.rank__ranking-sheet{width:100%;max-height:min(70dvh,28rem);overflow:auto;padding:.75rem 1rem 1rem;border-radius:12px 12px 0 0;background:var(--surface);border:1px solid var(--border)}.rank__ranking-sheet-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem}.rank__ranking-sheet-header h2{margin:0;font-size:1rem}.rank__ranking-sheet-close{padding:.15rem .45rem;border:none;background:transparent;color:var(--muted);font-size:1.35rem;line-height:1;cursor:pointer}}.rank__layout{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start}@media(max-width:800px){.rank__layout{grid-template-columns:1fr}}.rank__panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.25rem}.rank__panel h2{margin-top:0;font-size:1.1rem}.track-list{list-style:none;padding:0;margin:0 0 1rem;max-height:360px;overflow-y:auto}.track-row{width:100%;text-align:left;padding:.65rem .75rem;border:1px solid transparent;border-radius:8px;background:transparent;color:inherit;cursor:pointer;display:flex;flex-direction:column;gap:.15rem}.track-row:hover{background:#252530}.track-row--selected{border-color:var(--accent);background:#1a2e22}.track-name{font-weight:600}.track-artist{font-size:.85rem;color:var(--muted)}.selected-tracks__toolbar{display:flex;gap:.5rem;margin-bottom:.75rem}.selected-tracks__view-btn{flex:1;padding:.45rem .65rem;border:1px solid var(--border);border-radius:8px;background:transparent;color:var(--muted);cursor:pointer;font-size:.85rem}.selected-tracks__view-btn--active{border-color:var(--accent);color:var(--accent);background:#1a2e22}.selected-tracks__row{display:flex;align-items:center;gap:.5rem;padding:.35rem 0;border-bottom:1px solid var(--border)}.selected-tracks__row--nested{padding-left:.5rem}.selected-tracks__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.1rem}.selected-tracks__album-label{font-size:.75rem;color:var(--muted)}.selected-tracks__remove,.selected-tracks__remove-album{flex-shrink:0;padding:.35rem .6rem;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--muted);cursor:pointer;font-size:.75rem}.selected-tracks__remove:hover,.selected-tracks__remove-album:hover{border-color:#e55353;color:#ff8a8a}.selected-tracks__remove-album{font-size:.8rem}.selected-tracks__albums{list-style:none;padding:0;margin:0}.selected-tracks__album-group{margin-bottom:.75rem;border:1px solid var(--border);border-radius:8px;overflow:hidden}.selected-tracks__album-actions{display:flex;gap:.5rem;margin-bottom:.5rem}.selected-tracks__bulk-btn{flex:1;padding:.35rem .5rem;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--muted);cursor:pointer;font-size:.75rem}.selected-tracks__bulk-btn:hover{color:inherit;border-color:var(--accent)}.selected-tracks__album-header{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#252530}.selected-tracks__album-toggle{flex:1;display:flex;align-items:center;gap:.5rem;min-width:0;padding:0;border:none;background:transparent;color:inherit;cursor:pointer;text-align:left}.selected-tracks__chevron{flex-shrink:0;width:.5rem;height:.5rem;border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);transform:rotate(45deg);transition:transform .15s ease;margin-left:.15rem}.selected-tracks__album-group--collapsed .selected-tracks__chevron{transform:rotate(-45deg)}.selected-tracks__album-art{width:40px;height:40px;border-radius:4px;object-fit:cover}.selected-tracks__album-art--placeholder{display:block;background:linear-gradient(135deg,#333,#1a1a22)}.selected-tracks__album-meta{flex:1;min-width:0;display:flex;flex-direction:column;gap:.1rem}.selected-tracks__album-name{font-weight:600;font-size:.9rem}.selected-tracks__album-count{font-size:.75rem;color:var(--muted)}.selected-tracks__album-tracks{list-style:none;padding:0 .75rem;margin:0}.selected-tracks__list{margin-bottom:1rem}.rank__panel--sidebar{max-height:420px;overflow-y:auto}.sorted-rank{list-style:none;padding:0;margin:0}.sorted-rank li{display:grid;grid-template-columns:2rem 1fr;grid-template-rows:auto auto;column-gap:.5rem;padding:.5rem 0;border-bottom:1px solid var(--border)}.sorted-rank__num{grid-row:span 2;color:var(--muted);font-variant-numeric:tabular-nums}.sorted-rank__pending{opacity:.7;font-style:italic}.rank__empty,.rank__queue{color:var(--muted);font-size:.9rem}.rank__auth-prompt{color:var(--muted);max-width:32rem}.spotify-user-badge{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem;margin:1.25rem 0 .5rem;padding:.65rem .85rem;border-radius:10px;border:1px solid var(--border);background:var(--surface);font-size:.95rem}.spotify-user-badge--ok{border-color:#1a4d2e;color:var(--accent)}.spotify-user-badge--expired{border-color:#5a3030;color:#f5a8a8}.spotify-user-badge--loading{color:var(--muted)}.spotify-user-badge--anonymous{flex-direction:column;align-items:flex-start}.spotify-user-badge__text{margin:0;color:var(--muted)}.spotify-user-badge__icon{display:inline-flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;border-radius:999px;font-size:.75rem;font-weight:700}.spotify-user-badge__icon--ok{background:var(--accent);color:#000}.spotify-user-badge__icon--warn{background:#5a3030;color:#fff}.spotify-user-badge__avatar{border-radius:999px;object-fit:cover}.spotify-user-badge__action{padding:.35rem .75rem;font-size:.85rem}.spinner{display:inline-block;width:1rem;height:1rem;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.spinner--sm{width:.85rem;height:.85rem}@keyframes spin{to{transform:rotate(360deg)}}.search-panel .spotify-user-badge{margin-top:0;margin-bottom:1rem}.search-panel__hint{margin:-.35rem 0 .75rem;font-size:.85rem;color:var(--muted)}.search-panel__label{display:block;font-size:.9rem;color:var(--muted);margin-bottom:.35rem}.search-panel__input{width:100%;padding:.65rem .85rem;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:1rem;margin-bottom:.75rem}.search-panel__tabs{display:flex;gap:.35rem;margin-bottom:.75rem}.search-panel__tab{padding:.35rem .75rem;border-radius:999px;border:1px solid var(--border);background:transparent;color:var(--muted);font-size:.85rem;cursor:pointer}.search-panel__tab--active{border-color:var(--accent);color:var(--text);background:#1a2e22}.search-panel__status{color:var(--muted);font-size:.9rem;margin:0 0 .75rem}.search-panel__status--error{color:#f5a8a8}.search-panel__status--loading{display:flex;align-items:center;gap:.5rem}.search-panel__reconnect{padding:0;border:none;background:none;color:var(--accent);text-decoration:underline;cursor:pointer;font:inherit}.search-panel__input:disabled{opacity:.55;cursor:not-allowed}.search-results{list-style:none;padding:0;margin:0;max-height:360px;overflow-y:auto}.search-result{width:100%;display:grid;grid-template-columns:40px 1fr auto;gap:.65rem;align-items:center;padding:.5rem .35rem;border:none;border-radius:8px;background:transparent;color:inherit;text-align:left;cursor:pointer}.search-result:hover:not(:disabled){background:#252530}.search-result:disabled{opacity:.6;cursor:wait}.search-result__art{border-radius:4px;object-fit:cover}.search-result__art--placeholder{display:block;width:40px;height:40px;background:linear-gradient(135deg,#2e2e3a,#1a1a22);border-radius:4px}.search-result__meta{display:flex;flex-direction:column;gap:.1rem;min-width:0}.search-result__name{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-result__subtitle,.search-result__type{font-size:.8rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-result__action{font-size:.8rem;color:var(--accent);white-space:nowrap}
