:root{--bg: #0b0b0f;--bg-elev: #15151c;--bg-elev-2: #1e1e28;--text: #e9e9f0;--muted: #9a9aac;--accent: #e5a00d;--accent-2: #cc7b19;--danger: #e2554e;--border: #2c2c38;--sidebar-width: 280px;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}:root,html[data-ui-scale=medium]{--ui-font: 18px;--touch: 56px;--bar-height: 120px;--icon-size: 1.7rem;--icon-play-size: 2.4rem;--icon-play-dim: 68px;--icon-play-size-big: 3rem;--icon-play-dim-big: 84px;--hero-art-size: min(70vw, 340px)}html[data-ui-scale=small]{--ui-font: 16px;--touch: 44px;--bar-height: 100px;--icon-size: 1.45rem;--icon-play-size: 2rem;--icon-play-dim: 56px;--icon-play-size-big: 2.4rem;--icon-play-dim-big: 68px;--hero-art-size: min(65vw, 260px)}html[data-ui-scale=large]{--ui-font: 20px;--touch: 68px;--bar-height: 140px;--icon-size: 2rem;--icon-play-size: 2.8rem;--icon-play-dim: 80px;--icon-play-size-big: 3.5rem;--icon-play-dim-big: 96px;--hero-art-size: min(80vw, 480px)}html[data-ui-scale=extra-large]{--ui-font: 22px;--touch: 80px;--bar-height: 150px;--icon-size: 2.3rem;--icon-play-size: 3.2rem;--icon-play-dim: 92px;--icon-play-size-big: 4rem;--icon-play-dim-big: 112px;--hero-art-size: min( calc(100vw - 2rem) , calc(100dvh - var(--bar-height) - 14rem))}html[data-ui-scale=full]{--ui-font: 22px;--touch: 80px;--bar-height: 150px;--icon-size: 2.3rem;--icon-play-size: 3.2rem;--icon-play-dim: 92px;--icon-play-size-big: 4rem;--icon-play-dim-big: 112px;--hero-art-size: 0}html{font-size:var(--ui-font)}*{box-sizing:border-box}html,body,#root{margin:0;height:100%;background:var(--bg);color:var(--text)}button{font:inherit;color:inherit;cursor:pointer}a{color:inherit;text-decoration:none}:focus-visible{outline:3px solid var(--accent);outline-offset:2px}.muted{color:var(--muted)}.small{font-size:.9rem}.error{color:var(--danger);font-weight:600}.btn-primary,.btn-secondary,.btn-danger{border:none;border-radius:999px;padding:.85rem 1.6rem;font-weight:700;font-size:1.05rem;min-height:var(--touch);display:inline-flex;align-items:center;justify-content:center;gap:.45rem}.btn-primary{background:var(--accent);color:#1a1205}.btn-primary:disabled{opacity:.5;cursor:default}.btn-secondary{background:var(--bg-elev-2);color:var(--text)}.btn-secondary.full{width:100%}.btn-danger{background:transparent;border:2px solid var(--danger);color:var(--danger)}.link{background:none;border:none;color:var(--accent);padding:.3rem;font-size:1rem}.big-link{font-size:1.15rem;padding:.6rem}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:10px;border-radius:999px;background:var(--bg-elev-2);accent-color:var(--accent)}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:28px;height:28px;border-radius:50%;background:var(--accent);border:3px solid var(--bg);cursor:pointer}input[type=range]::-moz-range-thumb{width:28px;height:28px;border-radius:50%;background:var(--accent);border:3px solid var(--bg);cursor:pointer}.centered-screen{display:flex;align-items:center;justify-content:center;height:100%;padding:1rem}.login-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:16px;padding:3rem;max-width:480px;width:100%;text-align:center}.brand{font-size:2.4rem;margin:0 0 .5rem;color:var(--accent)}.server-list{list-style:none;padding:0;margin:1.5rem 0 0;display:flex;flex-direction:column;gap:.75rem}.server-item{width:100%;display:flex;justify-content:space-between;align-items:center;background:var(--bg-elev-2);border:1px solid var(--border);border-radius:12px;padding:1.1rem 1.25rem;font-size:1.1rem;min-height:var(--touch)}.app-shell{display:flex;flex-direction:column;height:100%}.app-body{flex:1;display:flex;min-height:0}.sidebar{width:var(--sidebar-width);background:var(--bg-elev);border-right:1px solid var(--border);padding:1.25rem;display:flex;flex-direction:column}.brand-small{font-weight:700;font-size:1.2rem;color:var(--accent);margin-bottom:1.5rem}.nav{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem}.nav-link{display:block;padding:.9rem 1rem;border-radius:10px;color:var(--muted);font-size:1.15rem;font-weight:600}.nav-link:hover,.nav-link.active{background:var(--bg-elev-2);color:var(--text)}.sidebar-footer{margin-top:auto;display:flex;flex-direction:column;gap:.75rem}.server-line{text-align:center}.content{flex:1;overflow-y:auto;min-width:0}.page{padding:1.75rem 2.25rem 2.5rem}.page h1{font-size:2rem}.page h2{margin:1.75rem 0 1rem;font-size:1.5rem}.section-tabs{display:flex;gap:.5rem;flex-wrap:wrap}.tab{background:none;border:none;color:var(--muted);padding:.6rem .5rem;font-size:1.1rem;border-bottom:3px solid transparent;min-height:var(--touch)}.tab.active{color:var(--text);border-color:var(--accent)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:1.5rem}.card{display:block;padding:.4rem;border-radius:10px}.card:hover,.card:focus-visible{background:var(--bg-elev)}.card:hover .artwork{outline:3px solid var(--accent)}.card-title{margin-top:.6rem;font-weight:600;font-size:1.05rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card-sub{font-size:.95rem}.artists-page{padding-right:1.25rem}.artists-layout{display:flex;align-items:flex-start;gap:.5rem}.artists-main{flex:1;min-width:0}.artist-letter-section{scroll-margin-top:1rem}.artist-letter-heading{margin:1.5rem 0 .75rem;font-size:1.25rem;font-weight:700;color:var(--accent);letter-spacing:.04em}.artist-letter-section:first-of-type .artist-letter-heading{margin-top:.5rem}.alpha-index{position:sticky;top:1rem;flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:.05rem;padding:.35rem .2rem;user-select:none;-webkit-user-select:none}.alpha-letter{background:none;border:none;color:var(--accent);font-size:.8rem;font-weight:700;line-height:1;padding:.15rem .4rem;min-width:32px;min-height:28px;border-radius:4px}.alpha-letter:not(.disabled):hover,.alpha-letter:not(.disabled):focus-visible{background:var(--bg-elev-2)}.alpha-letter.disabled{color:var(--muted);opacity:.3;cursor:default}.artwork{position:relative;width:100%;aspect-ratio:1 / 1;background:var(--bg-elev-2);border-radius:10px;overflow:hidden}.artwork img{width:100%;height:100%;object-fit:cover;display:block}.artwork-placeholder{display:flex;align-items:center;justify-content:center;height:100%;font-size:2.5rem;color:var(--muted)}.artwork.round{border-radius:50%}.artwork.small{width:72px;height:72px;flex:0 0 72px}.artwork.large{width:260px;flex:0 0 260px}.artwork.hero{width:var(--hero-art-size);box-shadow:0 12px 48px #00000080}.now-playing-screen.extra-large{align-items:stretch}.now-playing-screen.extra-large .np-screen-content{flex:1;width:100%;max-width:100vw;height:calc(100dvh - 1rem);justify-content:space-between;padding:1rem 1.5rem 1.5rem;gap:.75rem}.now-playing-screen.extra-large .artwork.hero{flex:1 1 auto;width:auto;height:auto;max-width:min(calc(100vw - 2rem),calc(100dvh - var(--bar-height) - 12rem));max-height:min(calc(100vw - 2rem),calc(100dvh - var(--bar-height) - 12rem));align-self:center}.album-header{display:flex;gap:1.75rem;align-items:flex-end;flex-wrap:wrap}.album-meta h1{margin:0 0 .35rem}.button-row{display:flex;gap:1rem;margin-top:1.25rem;align-items:center;flex-wrap:wrap}.track-list{list-style:none;padding:0;margin:1.5rem 0 0}.track-row{display:flex;align-items:center;gap:1rem;padding:.6rem;border-radius:10px;min-height:64px}.track-row:hover{background:var(--bg-elev)}.track-row.active .track-title{color:var(--accent)}.track-play,.track-index{background:none;border:none;min-width:var(--touch);min-height:var(--touch);display:inline-flex;align-items:center;justify-content:center;text-align:center;color:var(--muted);font-size:1.1rem;border-radius:8px}.track-play .play-glyph,.track-index .play-glyph{display:none}@media(hover:hover)and (pointer:fine){.track-row:hover .track-play .num,.track-row:hover .track-index .num,.track-play:focus-visible .num,.track-index:focus-visible .num{display:none}.track-row:hover .track-play .play-glyph,.track-row:hover .track-index .play-glyph,.track-play:focus-visible .play-glyph,.track-index:focus-visible .play-glyph{display:inline-flex;color:var(--text)}}@media(hover:none),(pointer:coarse){.track-play .num,.track-index .num{display:none}.track-play .play-glyph,.track-index .play-glyph{display:inline-flex;color:var(--text)}}.track-main{flex:1;min-width:0;cursor:pointer}.track-title{font-size:1.1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.track-sub{font-size:.95rem}.track-add{background:var(--bg-elev-2);border:none;color:var(--text);min-width:var(--touch);min-height:var(--touch);border-radius:50%;font-size:1.4rem;display:inline-flex;align-items:center;justify-content:center}.track-duration{font-variant-numeric:tabular-nums;font-size:1rem}.drag-handle{color:var(--muted);cursor:grab;font-size:1.4rem;padding:0 .25rem;display:inline-flex;align-items:center}.glyph{display:inline-block;flex-shrink:0;vertical-align:middle}.glyph-play{width:0;height:0;border-style:solid;border-width:.38em 0 .38em .62em;border-color:transparent transparent transparent currentColor}.glyph-close{position:relative;width:1em;height:1em}.glyph-close:before,.glyph-close:after{content:"";position:absolute;left:50%;top:50%;width:.72em;height:2px;background:currentColor;border-radius:1px}.glyph-close:before{transform:translate(-50%,-50%) rotate(45deg)}.glyph-close:after{transform:translate(-50%,-50%) rotate(-45deg)}.glyph-grip{width:.85em;height:2px;background:currentColor;border-radius:1px;box-shadow:0 .34em currentColor,0 .68em currentColor}.glyph-plus{position:relative;width:1em;height:1em}.glyph-plus:before,.glyph-plus:after{content:"";position:absolute;left:50%;top:50%;background:currentColor;border-radius:1px;transform:translate(-50%,-50%)}.glyph-plus:before{width:.72em;height:2px}.glyph-plus:after{width:2px;height:.72em}.search-input{width:100%;max-width:600px;padding:1rem 1.3rem;font-size:1.2rem;border-radius:999px;border:2px solid var(--border);background:var(--bg-elev);color:var(--text)}.now-playing-bar{height:var(--bar-height);background:var(--bg-elev);border-top:1px solid var(--border);display:grid;grid-template-columns:1fr 2fr 1fr;align-items:center;padding:0 1.5rem;gap:1.5rem}.np-track{display:flex;align-items:center;gap:1rem;min-width:0;cursor:pointer}.np-text{min-width:0}.np-title{font-weight:700;font-size:1.15rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.np-artist{font-size:1rem}.np-controls{display:flex;flex-direction:column;gap:.5rem}.transport{display:flex;align-items:center;justify-content:center;gap:1rem}.transport.big{gap:2rem}.icon{background:none;border:none;color:var(--text);font-size:var(--icon-size);line-height:1;min-width:var(--touch);min-height:var(--touch);border-radius:50%;display:inline-flex;align-items:center;justify-content:center}.icon:hover{background:var(--bg-elev-2)}.icon.on{color:var(--accent);background:color-mix(in srgb,var(--accent) 28%,transparent);box-shadow:0 0 0 2px var(--accent)}.icon.on:hover{background:color-mix(in srgb,var(--accent) 38%,transparent)}.icon.play{font-size:var(--icon-play-size);min-width:var(--icon-play-dim);min-height:var(--icon-play-dim);background:var(--accent);color:#1a1205}.transport.big .icon.play{font-size:var(--icon-play-size-big);min-width:var(--icon-play-dim-big);min-height:var(--icon-play-dim-big)}.np-extra{display:flex;align-items:center;justify-content:flex-end;gap:.75rem}.volume{width:120px}.seek-bar{display:flex;align-items:center;gap:.75rem}.seek-bar input[type=range]{flex:1}.time{font-variant-numeric:tabular-nums;font-size:.95rem;width:52px;text-align:center}.queue-panel{width:380px;flex:0 0 380px;background:var(--bg-elev);border-left:1px solid var(--border);overflow-y:auto;padding:1.25rem}.queue-header{display:flex;justify-content:space-between;align-items:center}.queue-header h3{font-size:1.3rem;margin:0}.queue-list{list-style:none;padding:0;margin:1rem 0 0}.queue-item{display:flex;align-items:center;gap:.6rem;padding:.6rem .3rem;border-radius:8px;min-height:var(--touch)}.queue-item:hover{background:var(--bg-elev-2)}.queue-item.active .queue-title{color:var(--accent)}.queue-text{flex:1;min-width:0;cursor:pointer}.queue-title{font-size:1.05rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.queue-sub{font-size:.9rem}.add-to-playlist{position:relative}.dropdown{position:absolute;z-index:20;top:110%;left:0;min-width:260px;background:var(--bg-elev-2);border:1px solid var(--border);border-radius:12px;padding:.5rem;max-height:340px;overflow-y:auto;box-shadow:0 12px 32px #0006}.dropdown-item{display:block;width:100%;text-align:left;background:none;border:none;padding:.8rem;border-radius:8px;font-size:1.05rem;min-height:var(--touch)}.dropdown-item:hover{background:var(--bg-elev)}.dropdown-divider{height:1px;background:var(--border);margin:.4rem 0}.now-playing-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:radial-gradient(circle at 50% 30%,#1a1a26,var(--bg));display:flex;align-items:center;justify-content:center;overflow:hidden}.np-close{position:absolute;top:1.25rem;left:1.25rem;font-size:1.8rem;z-index:2}.visualizer{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:.35}.np-screen-content{position:relative;z-index:1;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem;max-width:90vw}.np-screen-content h1{margin:.5rem 0 0;font-size:2rem}.np-format{margin:.25rem 0 0;font-size:1.1rem;font-weight:500;color:var(--accent)}.np-screen-content>.muted{margin:0}.np-screen-content p{font-size:1.2rem}.np-screen-content .seek-bar{width:min(70vw,360px)}.now-playing-screen.full{align-items:stretch;background:var(--bg)}.now-playing-screen.full .np-full-bg{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;background-repeat:no-repeat;transform:scale(.94);transform-origin:center center;z-index:0}.now-playing-screen.full:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:linear-gradient(to bottom,#0b0b0fa6,#0b0b0f33 42%,#0b0b0fe0)}.now-playing-screen.full .np-screen-content{flex:1;width:100%;max-width:100vw;height:100dvh;justify-content:flex-end;padding:1.5rem 1.5rem 2.5rem;gap:.85rem;text-shadow:0 1px 12px rgba(0,0,0,.85)}.now-playing-screen.full .np-screen-content h1{font-size:clamp(1.75rem,5vw,2.5rem)}.now-playing-screen.full .np-screen-content .seek-bar{width:min(90vw,480px)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:#000000b3;display:flex;align-items:center;justify-content:center;padding:1.5rem}.modal{position:relative;background:var(--bg-elev);border:1px solid var(--border);border-radius:20px;padding:2.5rem;width:100%;max-width:620px;max-height:90vh;overflow-y:auto}.modal h2{margin:0 0 1.5rem;font-size:1.8rem;text-align:center}.modal-close{position:absolute;top:1rem;right:1rem;font-size:1.5rem}.user-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1.25rem}.user-tile{position:relative;display:flex;flex-direction:column;align-items:center;gap:.75rem;background:var(--bg-elev-2);border:2px solid transparent;border-radius:16px;padding:1.5rem 1rem;min-height:160px}.user-tile:hover,.user-tile.current{border-color:var(--accent)}.user-avatar{width:88px;height:88px;border-radius:50%;overflow:hidden;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:2.4rem;font-weight:700;color:var(--accent)}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-avatar.small{width:52px;height:52px;flex:0 0 52px;font-size:1.4rem}.user-name{font-size:1.2rem;font-weight:600}.user-lock{position:absolute;top:.75rem;right:.75rem;font-size:1.1rem}.user-badge{font-size:.85rem;color:var(--accent);font-weight:700}.user-button{display:flex;align-items:center;gap:.75rem;width:100%;background:var(--bg-elev-2);border:1px solid var(--border);border-radius:14px;padding:.75rem;text-align:left;min-height:var(--touch)}.user-button:hover{border-color:var(--accent)}.user-button-text{display:flex;flex-direction:column;min-width:0}.user-button-name{font-size:1.1rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pin-pad{text-align:center}.pin-display{display:flex;justify-content:center;gap:1rem;margin:1rem 0 2rem}.pin-dot{width:22px;height:22px;border-radius:50%;border:2px solid var(--muted)}.pin-dot.filled{background:var(--accent);border-color:var(--accent)}.keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;max-width:340px;margin:0 auto}.key{background:var(--bg-elev-2);border:none;border-radius:14px;font-size:1.8rem;font-weight:600;padding:1.1rem 0;min-height:76px}.key:hover{background:var(--border)}.key-go{background:var(--accent);color:#1a1205}.key:disabled{opacity:.5}
