:root{--bg0: #07070c;--bg1: #0e0e16;--card: rgba(20, 20, 32, .78);--card2: rgba(14, 14, 22, .92);--border: rgba(255, 255, 255, .09);--border-strong: rgba(255, 255, 255, .14);--text: #f7f7fb;--muted: #9a9aaf;--accent: #8b74ff;--accent-dim: rgba(139, 116, 255, .22);--accent2: #45dfff;--danger: #ff7a9a;--success: #5fe1b3;--radius: 20px;--font: "DM Sans", system-ui, sans-serif;--display: "Outfit", var(--font);--shadow: 0 28px 100px rgba(0, 0, 0, .55)}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font);color:var(--text);background:var(--bg0);line-height:1.55;-webkit-font-smoothing:antialiased;padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px)}@media(max-width:959px){body{overscroll-behavior-y:none}}.page{min-height:100%;position:relative;overflow-x:hidden;padding:clamp(1.1rem,3.2vw,2.25rem);padding-top:max(clamp(1.1rem,3.2vw,2.25rem),env(safe-area-inset-top,0px));padding-bottom:clamp(2rem,5vw,3rem)}.page--prod{padding:clamp(.85rem,2.8vw,1.75rem);padding-top:max(clamp(.85rem,2.8vw,1.75rem),env(safe-area-inset-top,0px));padding-bottom:clamp(1.5rem,4.5vw,2.5rem)}.page-grid{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:48px 48px;-webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 0%,#000 50%,transparent 100%);mask-image:radial-gradient(ellipse 80% 70% at 50% 0%,#000 50%,transparent 100%);opacity:.55}.glow{position:fixed;width:44rem;height:44rem;border-radius:50%;filter:blur(100px);opacity:.38;pointer-events:none;z-index:0}.glow-a{top:-14rem;right:-10rem;background:radial-gradient(circle,var(--accent) 0%,transparent 68%)}.glow-b{bottom:-16rem;left:-12rem;background:radial-gradient(circle,var(--accent2) 0%,transparent 70%)}.header,.main,.footer{position:relative;z-index:1}.brand{display:flex;flex-wrap:wrap;align-items:flex-start;gap:1rem 1.25rem;max-width:72rem;margin:0 auto 1.75rem}.brand-mark{width:50px;height:50px;border-radius:16px;background:linear-gradient(145deg,#8b74ff59,#45dfff33);border:1px solid var(--border-strong);box-shadow:0 14px 50px #8b74ff47,inset 0 1px #ffffff1f;flex-shrink:0;display:grid;place-items:center;color:#eef4ff}.brand-copy{flex:1;min-width:min(100%,280px)}.brand-row{display:flex;flex-wrap:wrap;align-items:center;gap:.55rem .75rem;margin-bottom:.2rem}.badge{font-size:.68rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;padding:.28rem .55rem;border-radius:999px;border:1px solid var(--border-strong);background:#5fe1b314;color:#b9f3dc}.brand-title{font-family:var(--display);font-weight:700;font-size:clamp(1.25rem,2.8vw,1.55rem);margin:0;letter-spacing:-.03em}.brand-sub{margin:0;color:var(--muted);font-size:.92rem;max-width:44rem}.brand-sub code{font-size:.86em;padding:.12em .45em;border-radius:8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.06);color:#e2e2f0}.brand--minimal{margin-bottom:1rem;gap:.75rem 1rem;align-items:center}.brand--minimal .brand-mark{width:44px;height:44px;border-radius:14px}.header-actions{margin-left:auto;display:flex;align-items:center;gap:.5rem}.btn-ghost{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .85rem;border-radius:12px;border:1px solid var(--border);background:#ffffff08;color:var(--text);font:inherit;font-size:.88rem;font-weight:500;cursor:pointer;transition:background .18s,border-color .18s,transform .18s}.btn-ghost:hover:not(:disabled){background:#ffffff12;border-color:var(--border-strong);transform:translateY(-1px)}.btn-ghost:disabled{opacity:.45;cursor:not-allowed}.btn-ghost--icon{gap:0;padding:.45rem;justify-content:center;min-width:2.5rem}.main{max-width:72rem;margin:0 auto}.panel{border-radius:var(--radius);border:1px solid var(--border);background:var(--card);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);padding:1.5rem 1.35rem;max-width:32rem;margin:0 auto;text-align:center;box-shadow:var(--shadow)}.panel-error{border-color:#ff7a9a59;background:linear-gradient(160deg,#201018d9,#141420cc)}.panel-title{margin:0 0 .35rem;font-family:var(--display);font-weight:600;font-size:1.1rem}.panel-body{margin:0 0 1rem;color:var(--muted);font-size:.95rem}.btn-primary{display:inline-flex;align-items:center;justify-content:center;padding:.55rem 1.15rem;border-radius:12px;border:none;cursor:pointer;font:inherit;font-weight:600;font-size:.92rem;color:#0b0b10;background:linear-gradient(135deg,#ebe4ff,#b5f3ff);box-shadow:0 14px 36px #8b74ff4d;transition:transform .15s}.btn-primary:hover{transform:translateY(-1px)}.empty{text-align:center;padding:clamp(2rem,5vw,3rem) 1.35rem;border-radius:calc(var(--radius) + 4px);border:1px solid var(--border);background:linear-gradient(165deg,var(--card),var(--card2));-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);max-width:42rem;margin:0 auto;box-shadow:var(--shadow)}.empty-title{margin:0 0 .6rem;font-family:var(--display);font-weight:700;font-size:1.35rem}.empty-icon{width:4.5rem;height:4.5rem;margin:0 auto 1.25rem;border-radius:1.25rem;background:radial-gradient(circle at 30% 25%,rgba(139,116,255,.45),transparent 55%),radial-gradient(circle at 75% 80%,rgba(69,223,255,.35),transparent 45%),#ffffff0a;border:1px solid var(--border-strong);position:relative}.empty-icon span{position:absolute;top:28%;right:28%;bottom:28%;left:28%;border-radius:.75rem;border:2px dashed rgba(255,255,255,.2)}.empty p{margin:0}.empty-hint{margin-top:.85rem;color:var(--muted);font-size:.94rem;line-height:1.65}.linkish{padding:0;border:none;background:none;color:#c9c2ff;font:inherit;font-weight:600;cursor:pointer;text-decoration:underline;text-underline-offset:3px}.linkish:hover{color:#e2deff}.layout{display:grid;gap:1.35rem;grid-template-columns:1fr}@media(min-width:960px){.layout{grid-template-columns:minmax(0,1fr) minmax(280px,360px);align-items:start;gap:1.5rem}}.layout--stack{display:flex;flex-direction:column;gap:1.15rem}@media(min-width:960px){.layout--stack{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,360px);align-items:start;gap:1.5rem}}.drawer-backdrop{display:none}@media(max-width:959px){.drawer-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:35;background:#04040a8c;opacity:0;pointer-events:none;visibility:hidden;transition:opacity .22s ease,visibility .22s ease;-webkit-tap-highlight-color:transparent}.drawer-backdrop--open{opacity:1;pointer-events:auto;visibility:visible}}.queue-fab{display:none}@media(max-width:959px){.queue-fab{display:inline-flex;align-items:center;gap:.5rem;position:fixed;bottom:calc(1rem + env(safe-area-inset-bottom,0px));left:50%;transform:translate(-50%);z-index:38;padding:.75rem 1.15rem;min-height:48px;border-radius:999px;border:1px solid rgba(139,116,255,.45);background:linear-gradient(145deg,#3c306ef2,#141424f5);color:var(--text);font:inherit;font-size:.92rem;font-weight:600;cursor:pointer;box-shadow:0 16px 40px #00000073,0 0 0 1px #ffffff0f;-webkit-tap-highlight-color:transparent}.queue-fab:active{transform:translate(-50%) scale(.97)}.queue-fab-count{font-variant-numeric:tabular-nums;padding:.15rem .55rem;border-radius:999px;background:#8b74ff40;font-size:.82rem}}@media(max-width:959px){.layout--stack .playlist--sheet{position:fixed;left:0;right:0;bottom:0;z-index:40;width:100%;max-width:none;max-height:min(85dvh,720px);margin:0;border-radius:22px 22px 0 0;padding:1rem .85rem;padding-bottom:calc(1rem + env(safe-area-inset-bottom,0px));transform:translateY(calc(100% + 24px));visibility:hidden;transition:transform .32s cubic-bezier(.22,1,.36,1),visibility .32s;box-shadow:0 -20px 60px #00000080}.layout--stack .playlist--sheet-open{transform:translateY(0);visibility:visible}}.playlist-head-actions{display:inline-flex;align-items:center;gap:.45rem}.playlist-close{width:40px;height:40px;border-radius:12px;border:1px solid var(--border);background:#ffffff0d;color:var(--text);font-size:1.45rem;line-height:1;cursor:pointer;display:grid;place-items:center;flex-shrink:0;-webkit-tap-highlight-color:transparent}.playlist-close:hover{background:#ffffff17}.footer-hint-mobile{display:none}.footer--fab{padding-bottom:calc(2.5rem + env(safe-area-inset-bottom,0px))}@media(max-width:959px){.footer-hint-desktop{display:none}.footer-hint-mobile{display:block;margin:0}.brand-sub{font-size:.85rem}.btn-round{width:52px;height:52px;min-width:52px;min-height:52px}.btn-play{width:80px;height:80px;min-width:80px;min-height:80px}.scrub-wrap{min-height:44px;padding:.45rem 0;touch-action:none}.volume{min-height:28px}}.layout--loading{opacity:.95}.shimmer{position:relative;overflow:hidden}.shimmer:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;transform:translate(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.07),transparent);animation:shimmer 1.35s ease-in-out infinite}@keyframes shimmer{to{transform:translate(100%)}}.player-card--skeleton{grid-template-columns:1fr}@media(min-width:640px){.player-card--skeleton{grid-template-columns:minmax(220px,min(32vw,300px)) minmax(0,1fr);align-items:center}}@media(min-width:960px){.player-card--skeleton{grid-template-columns:minmax(260px,340px) minmax(0,1fr)}}.skeleton-block{display:flex;flex-direction:column;gap:.75rem;min-width:0}.skeleton{display:block;border-radius:10px;background:#ffffff0f}.skeleton-cover{width:100%;max-width:min(280px,100%);aspect-ratio:1;border-radius:22px;justify-self:center}.skeleton-line{height:12px}.skeleton-line.lg{height:22px;border-radius:8px}.skeleton-line.md{height:14px}.skeleton-line.sm{height:11px}.skeleton-line.w-30{width:30%}.skeleton-line.w-40{width:40%}.skeleton-line.w-50{width:50%}.skeleton-line.w-80{width:80%}.skeleton-line.w-90{width:90%}.skeleton-line.w-full{width:100%}.skeleton-scrub{height:10px;border-radius:999px;margin-top:.35rem}.skeleton-controls{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:.75rem}.skeleton-btn{width:48px;height:48px;border-radius:50%}.skeleton-btn-play{width:72px;height:72px;border-radius:50%}.playlist--skeleton{pointer-events:none}.skeleton-row{display:grid;grid-template-columns:28px 48px 1fr;align-items:center;gap:.65rem;padding:.55rem;border-radius:14px;background:#ffffff05}.skeleton-dot{width:22px;height:10px;border-radius:6px;background:#ffffff12}.skeleton-thumb{width:48px;height:48px;border-radius:12px;background:#ffffff12}.skeleton-col{display:flex;flex-direction:column;gap:.4rem}.player-card{position:relative;display:grid;gap:1.5rem;padding:clamp(1.15rem,2.8vw,1.85rem);border-radius:calc(var(--radius) + 8px);border:1px solid var(--border);background:linear-gradient(150deg,var(--card),rgba(12,12,20,.65));-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);box-shadow:var(--shadow)}.player-card .player-audio{position:absolute;width:1px;height:1px;margin:0;padding:0;border:0;left:0;top:0;opacity:0;pointer-events:none;overflow:hidden}@media(min-width:640px){.player-card{grid-template-columns:minmax(220px,min(32vw,300px)) minmax(0,1fr);align-items:center;gap:clamp(1.25rem,2.8vw,2rem)}.player-body{padding-left:clamp(.35rem,1.5vw,1rem);border-left:1px solid rgba(255,255,255,.065);min-height:min(280px,50vh)}}@media(min-width:960px){.player-card{grid-template-columns:minmax(260px,340px) minmax(0,1fr)}}.player-visual{position:relative;justify-self:center;width:100%;max-width:min(280px,100%);aspect-ratio:1}.player-visual.is-playing .cover{transform:scale(1.02)}.cover{position:relative;z-index:1;width:100%;height:100%;border-radius:22px;background:linear-gradient(145deg,#35305a,#12121f);background-size:cover;background-position:center;display:grid;place-items:center;overflow:hidden;box-shadow:0 22px 60px #0000008c,inset 0 0 0 1px #ffffff12;transition:transform .45s cubic-bezier(.22,1,.36,1)}.cover.has-image{background-color:#0c0c12}.cover-shine{position:absolute;top:-40%;right:-40%;bottom:-40%;left:-40%;background:conic-gradient(from 120deg,transparent,rgba(255,255,255,.09),transparent 55%);animation:shine 5s linear infinite;pointer-events:none}@keyframes shine{to{transform:rotate(360deg)}}.cover-fallback{font-size:clamp(3rem,10vw,4rem);opacity:.35}.vinyl-ring{position:absolute;top:-9%;right:-9%;bottom:-9%;left:-9%;border-radius:50%;border:2px dashed rgba(255,255,255,.11);z-index:0;opacity:.85}.vinyl-ring.is-spinning{animation:spin 22s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.player-body{min-width:0;display:flex;flex-direction:column;justify-content:center}.player-eyebrow{margin:0 0 .35rem;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}.player-title{margin:0 0 .2rem;font-family:var(--display);font-size:clamp(1.55rem,4vw,2.25rem);font-weight:700;letter-spacing:-.035em;line-height:1.1}.player-artist{margin:0 0 1.15rem;color:var(--muted);font-size:1.04rem}.scrub-wrap{padding:.45rem 0;margin:0 -.1rem .15rem;cursor:pointer;touch-action:none;outline:none;border-radius:10px}.scrub-wrap:focus-visible{box-shadow:0 0 0 3px var(--accent-dim)}.scrub{height:7px;border-radius:999px;background:#ffffff14;position:relative}.scrub-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--accent),var(--accent2));pointer-events:none;position:relative;transition:width .08s linear}.scrub-knob{position:absolute;right:-6px;top:50%;width:14px;height:14px;border-radius:50%;background:#fff;border:2px solid rgba(12,12,18,.85);transform:translate(50%,-50%);box-shadow:0 4px 16px #00000059}.times{display:flex;justify-content:space-between;font-variant-numeric:tabular-nums;font-size:.78rem;color:var(--muted);margin-bottom:1.1rem}.controls{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}.controls--wrap{max-width:26rem;margin-left:auto;margin-right:auto}.library-bar{max-width:72rem;margin:0 auto 1.25rem;padding:1rem 1.15rem;display:flex;flex-wrap:wrap;align-items:flex-end;gap:.85rem 1.25rem;border-radius:var(--radius);border:1px solid var(--border);background:linear-gradient(165deg,var(--card),rgba(14,14,22,.88))}.library-bar--compact{padding:.75rem .95rem;gap:.65rem .95rem;margin-bottom:.9rem;align-items:center}.library-field{display:flex;flex-direction:column;gap:.35rem;flex:1;min-width:min(100%,240px)}.library-label{font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.library-select{width:100%;max-width:420px;padding:.55rem .75rem;border-radius:12px;border:1px solid var(--border);background:#00000047;color:var(--text);font:inherit;font-size:.95rem;cursor:pointer;outline:none}.library-select:focus{border-color:#8b74ff8c;box-shadow:0 0 0 3px var(--accent-dim)}.library-desc{margin:.45rem 0 0;font-size:.86rem;line-height:1.5;color:var(--muted);max-width:42rem}.panel-muted{border-color:#ffffff1f;background:#1414208c}.panel-muted .panel-title{font-size:1rem}.btn-round{width:50px;height:50px;border-radius:50%;border:1px solid var(--border);background:#ffffff0a;color:var(--text);display:grid;place-items:center;cursor:pointer;transition:background .18s,transform .18s,opacity .18s,border-color .18s}.btn-round:hover:not(:disabled){background:#ffffff17;border-color:var(--border-strong);transform:translateY(-1px)}.btn-round:disabled{opacity:.35;cursor:not-allowed}.btn-play{width:76px;height:76px;border-radius:50%;border:none;cursor:pointer;color:#0b0b10;background:linear-gradient(145deg,#f1ecff,#b8f4ff);box-shadow:0 18px 46px #8b74ff61,inset 0 1px #ffffffa6;display:grid;place-items:center;transition:transform .18s}.btn-play:hover{transform:scale(1.05)}.volume-row{margin-top:1.15rem;display:flex;align-items:center;gap:.65rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.06)}.volume-label{color:var(--muted);display:grid;place-items:center}.volume{flex:1;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:999px;background:#ffffff1a}.volume::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:#fff;box-shadow:0 2px 10px #00000059;border:2px solid rgba(10,10,16,.7);cursor:pointer}.volume::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:#fff;border:2px solid rgba(10,10,16,.7);cursor:pointer}.playlist{border-radius:calc(var(--radius) + 2px);border:1px solid var(--border);background:linear-gradient(175deg,var(--card),rgba(12,12,20,.88));-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);padding:1rem .85rem .85rem;max-height:min(72vh,560px);overflow:auto;box-shadow:0 22px 60px #00000059;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent}.playlist::-webkit-scrollbar{width:8px}.playlist::-webkit-scrollbar-thumb{background:#ffffff24;border-radius:99px}.playlist-head{display:flex;align-items:center;justify-content:space-between;padding:0 .35rem .65rem;margin-bottom:.15rem;border-bottom:1px solid rgba(255,255,255,.06)}.playlist-title{margin:0;font-family:var(--display);font-size:1.02rem;font-weight:600}.playlist-count{font-size:.78rem;font-weight:600;color:var(--muted);padding:.2rem .55rem;border-radius:999px;border:1px solid var(--border);background:#ffffff08}.playlist-list{list-style:none;margin:.35rem 0 0;padding:0;display:flex;flex-direction:column;gap:.28rem}.playlist-item{width:100%;display:grid;grid-template-columns:30px 50px 1fr;align-items:center;gap:.65rem;padding:.5rem;border-radius:14px;border:1px solid transparent;background:#ffffff04;color:inherit;font:inherit;text-align:left;cursor:pointer;transition:background .18s,border-color .18s,transform .18s}.playlist-item:hover{background:#ffffff0f;transform:translateY(-1px)}.playlist-item.is-active{background:var(--accent-dim);border-color:#8b74ff66}.playlist-index{font-size:.74rem;color:var(--muted);font-variant-numeric:tabular-nums;text-align:center}.playlist-thumb{width:50px;height:50px;border-radius:12px;background:linear-gradient(145deg,#423a68,#171625);background-size:cover;background-position:center;flex-shrink:0;box-shadow:inset 0 0 0 1px #ffffff0f}.playlist-meta{min-width:0;display:flex;flex-direction:column;gap:.12rem}.playlist-track-row{display:flex;align-items:center;gap:.45rem;min-width:0}.playlist-track{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.now-playing{display:inline-flex;align-items:flex-end;gap:2px;height:14px;flex-shrink:0}.now-playing .bar{width:3px;background:linear-gradient(180deg,var(--accent2),var(--accent));border-radius:99px;animation:eq .9s ease-in-out infinite alternate}.now-playing .bar:nth-child(2){animation-delay:.15s}.now-playing .bar:nth-child(3){animation-delay:.3s}@keyframes eq{0%{height:35%;opacity:.55}to{height:100%;opacity:1}}.playlist-artist{font-size:.82rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.footer{max-width:72rem;margin:2.25rem auto 0;text-align:center;font-size:.78rem;color:var(--muted);line-height:1.65}.footer p{margin:0}.footer--prod{margin-top:1.25rem;line-height:1.4}@media(max-width:639px){.player-visual,.skeleton-cover{width:min(176px,56vw);max-width:none}.vinyl-ring{top:-6%;right:-6%;bottom:-6%;left:-6%}.player-card{padding:clamp(.9rem,3vw,1.35rem);gap:1rem}.player-artist{margin-bottom:.85rem}.player-title{font-size:clamp(1.35rem,5.2vw,1.85rem)}}kbd{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.74em;padding:.1em .4em;border-radius:6px;border:1px solid rgba(255,255,255,.14);background:#ffffff0d;color:#e4e4f2}@media(prefers-reduced-motion:reduce){.vinyl-ring.is-spinning,.cover-shine,.now-playing .bar,.shimmer:after{animation:none!important}.cover-shine{opacity:0}.player-visual.is-playing .cover{transform:none}}
