:root{--night: #17111c;--cherry: #8e1c2e;--cherry2: #5f1120;--chrome: #e8e9ee;--chrome2: #9aa0ac;--cream: #fff4dc;--teal: #35e0d0;--coral: #ff3b5c;--lift-ms: 1.1s;--load-ms: 1.1s}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--night);background-image:radial-gradient(ellipse 120% 60% at 50% -10%,#2a1f33 0%,transparent 60%),repeating-conic-gradient(#1b141f,#1b141f 25%,#140f18 0%,#140f18 50%);background-size:auto,90px 90px;color:var(--cream);font-family:Barlow Semi Condensed,system-ui,sans-serif;overscroll-behavior:none;-webkit-tap-highlight-color:transparent}button{font-family:inherit;cursor:pointer}button:disabled{opacity:.45;cursor:default}:focus-visible{outline:3px solid var(--teal);outline-offset:2px}.jukebox{max-width:560px;min-height:100dvh;margin:0 auto;display:flex;flex-direction:column;background:linear-gradient(180deg,#a02236 0%,var(--cherry) 30%,var(--cherry2) 100%);border-left:6px solid var(--chrome2);border-right:6px solid var(--chrome2);box-shadow:0 0 60px #000c,inset 0 0 0 2px #ffffff14;padding-bottom:env(safe-area-inset-bottom)}.marquee{position:relative;padding:calc(14px + env(safe-area-inset-top)) 16px 10px;text-align:center;border-radius:0 0 50% 50%/0 0 18% 18%;background:linear-gradient(180deg,#26102b,#1c0c20);border-bottom:4px solid var(--chrome2);box-shadow:inset 0 -14px 24px #00000080}.neon-title{margin:0;font-family:Yellowtail,cursive;font-weight:400;font-size:clamp(2.2rem,9vw,3.2rem);color:#fff;letter-spacing:1px;text-shadow:0 0 6px var(--teal),0 0 16px var(--teal),0 0 40px rgba(53,224,208,.7);animation:neon-flicker 7s infinite}@keyframes neon-flicker{0%,18%,22%,to{opacity:1}19%,21%{opacity:.55}63%{opacity:.92}}.bubbler{position:absolute;top:8px;bottom:8px;width:14px;border-radius:8px;background:radial-gradient(circle 3px at 50% 90%,rgba(255,255,255,.9) 40%,transparent 41%),radial-gradient(circle 2px at 40% 55%,rgba(255,255,255,.8) 40%,transparent 41%),radial-gradient(circle 2.5px at 60% 25%,rgba(255,255,255,.85) 40%,transparent 41%),linear-gradient(180deg,var(--coral),#b3123a);background-size:100% 220%;box-shadow:0 0 12px #ff3b5ccc,inset 0 0 4px #ffffff80;animation:bubbles 3.2s linear infinite}.bubbler.left{left:10px}.bubbler.right{right:10px;animation-duration:4.1s;background-image:radial-gradient(circle 3px at 50% 90%,rgba(255,255,255,.9) 40%,transparent 41%),radial-gradient(circle 2px at 40% 55%,rgba(255,255,255,.8) 40%,transparent 41%),radial-gradient(circle 2.5px at 60% 25%,rgba(255,255,255,.85) 40%,transparent 41%),linear-gradient(180deg,var(--teal),#0f8f85);box-shadow:0 0 12px #35e0d0cc,inset 0 0 4px #ffffff80}@keyframes bubbles{0%{background-position:0 120%,0 120%,0 120%,0 0}to{background-position:0 -120%,0 -140%,0 -160%,0 0}}.chrome-btn.corner{position:absolute;right:34px;top:calc(12px + env(safe-area-inset-top));width:34px;height:34px;font-size:.9rem}.deck{padding:14px 18px 6px}.glass{position:relative;height:clamp(180px,34vw,230px);border-radius:140px 140px 14px 14px;background:linear-gradient(160deg,rgba(255,255,255,.16) 0%,rgba(255,255,255,.02) 35%,transparent 60%),radial-gradient(ellipse at 50% 120%,#33222c,#100a12 70%);border:5px solid var(--chrome);border-bottom-color:var(--chrome2);box-shadow:inset 0 0 30px #000c,0 0 0 3px var(--cherry2),0 0 22px #35e0d040;overflow:hidden}.platter{position:absolute;left:50%;bottom:10px;width:clamp(140px,30vw,180px);height:clamp(140px,30vw,180px);transform:translate(-50%);border-radius:50%;background:radial-gradient(circle,#3a3a3f,#232327 70%);box-shadow:0 6px 14px #000000b3,inset 0 0 8px #000c}.platter-felt{position:absolute;top:10%;right:10%;bottom:10%;left:10%;border-radius:50%;background:repeating-radial-gradient(circle,#40252c 0,#40252c 3px,#35202a 3px,#35202a 6px)}.vinyl{position:absolute;top:4%;right:4%;bottom:4%;left:4%;border-radius:50%;background:radial-gradient(circle,#0c0c0c 30%,#151515 60%,#0a0a0a);box-shadow:0 4px 10px #000c}.grooves{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:repeating-radial-gradient(circle,transparent 0 3px,rgba(255,255,255,.045) 3px 4px)}.vinyl .label{position:absolute;top:31%;right:31%;bottom:31%;left:31%;border-radius:50%;overflow:hidden;background:var(--coral);display:grid;place-items:center;border:2px solid rgba(0,0,0,.6)}.vinyl .label img{width:100%;height:100%;object-fit:cover}.vinyl .label span{font-family:Alfa Slab One,serif;color:var(--cream);font-size:1.1rem}.spindle{position:absolute;left:50%;top:50%;width:8px;height:8px;transform:translate(-50%,-50%);border-radius:50%;background:var(--chrome);box-shadow:0 0 3px #000;z-index:2}.phase-playing .vinyl{animation:spin 1.8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.phase-loading .vinyl{animation:vinyl-load var(--load-ms) cubic-bezier(.25,1,.4,1) both}@keyframes vinyl-load{0%{transform:translateY(-140%) scale(.55) rotate(-90deg);opacity:0}60%{transform:translateY(4%) scale(1.02) rotate(10deg);opacity:1}to{transform:translateY(0) scale(1) rotate(0)}}.phase-lifting .vinyl{animation:vinyl-lift var(--lift-ms) cubic-bezier(.6,0,.8,.4) both}@keyframes vinyl-lift{0%{transform:translateY(0) scale(1);opacity:1}45%{transform:translateY(-70%) scale(.85) rotate(15deg);opacity:1}to{transform:translateY(60%) scale(.35) rotate(60deg);opacity:0}}.tonearm{position:absolute;right:10%;top:8%;width:34%;height:60%;transform-origin:92% 8%;transform:rotate(-24deg);transition:transform .7s cubic-bezier(.4,0,.2,1);pointer-events:none}.phase-playing .tonearm,.phase-paused .tonearm{transform:rotate(4deg)}.phase-lifting .tonearm{transform:rotate(-30deg);transition-duration:.5s}.tonearm .arm{position:absolute;right:6%;top:6%;width:6px;height:88%;background:linear-gradient(90deg,var(--chrome),var(--chrome2));border-radius:4px;transform:rotate(14deg);transform-origin:top;box-shadow:0 2px 6px #0009}.tonearm .head{position:absolute;left:22%;bottom:0;width:16px;height:26px;background:linear-gradient(180deg,var(--chrome),var(--chrome2));border-radius:3px 3px 6px 6px;box-shadow:0 3px 6px #000000b3}.deck-plate{margin:10px auto 0;max-width:92%;padding:8px 14px 10px;background:linear-gradient(180deg,var(--cream),#efdfba);color:#3a2323;border-radius:10px;border:3px solid var(--chrome2);box-shadow:inset 0 2px #ffffffb3,0 4px 8px #0006;text-align:center}.now-title{font-family:Alfa Slab One,serif;font-size:clamp(.95rem,4vw,1.15rem);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.now-title.idle{opacity:.6;font-size:.95rem}.now-artist{font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;opacity:.75}.progress{margin-top:6px;height:5px;border-radius:3px;background:#00000026;overflow:hidden}.progress span{display:block;height:100%;background:linear-gradient(90deg,var(--coral),var(--teal));transition:width .3s linear}.finder{padding:12px 18px 4px}.search{width:100%;padding:10px 14px;border-radius:22px;border:3px solid var(--chrome2);background:var(--cream);color:#3a2323;font-size:1rem;font-family:inherit}.search::placeholder{color:#8d7a66}.chips{display:flex;gap:8px;overflow-x:auto;padding:10px 2px 4px;scrollbar-width:none}.chips::-webkit-scrollbar{display:none}.chip{flex:0 0 auto;padding:6px 12px;border-radius:16px;border:2px solid var(--chrome2);background:#00000059;color:var(--cream);font-size:.85rem;transition:box-shadow .2s,background .2s}.chip.genre{border-color:var(--teal)}.chip.on{background:var(--teal);color:#06302b;border-color:var(--teal);box-shadow:0 0 12px #35e0d0cc}.chip.genre.on{background:var(--teal)}.chip.clear{border-color:var(--coral);color:var(--coral)}.chip .count{opacity:.6;font-size:.75em}.library{flex:1;min-height:0;padding:8px 0 6px}.library.empty{display:grid;place-items:center;text-align:center;padding:24px;opacity:.8}.rail{display:flex;gap:14px;overflow-x:auto;padding:10px 18px 14px;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}.sleeve{flex:0 0 clamp(128px,34vw,168px);scroll-snap-align:center;background:linear-gradient(180deg,#2a1a22,#201219);border:2px solid var(--chrome2);border-radius:12px;padding:8px;transition:transform .25s,box-shadow .25s}.sleeve.playing{border-color:var(--teal);box-shadow:0 0 16px #35e0d099;transform:translateY(-4px)}.art{position:relative;display:block;width:100%;aspect-ratio:1;border:none;border-radius:8px;overflow:hidden;background:radial-gradient(circle,#444,#222);padding:0}.art img{width:100%;height:100%;object-fit:cover;display:block}.art-fallback{display:grid;place-items:center;width:100%;height:100%;font-family:Alfa Slab One,serif;font-size:2rem;color:var(--chrome2)}.on-air{position:absolute;top:6px;left:6px;padding:2px 6px;border-radius:4px;background:var(--coral);color:#fff;font-size:.6rem;font-weight:700;letter-spacing:.1em;animation:neon-flicker 4s infinite}.sleeve-meta{padding:6px 2px 4px;line-height:1.2}.sleeve-meta strong{display:block;font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sleeve-meta span{display:block;font-size:.75rem;opacity:.7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sleeve-actions{display:flex;gap:6px;padding-top:4px}.mini{min-width:34px;height:34px;border-radius:50%;border:2px solid var(--chrome2);background:linear-gradient(180deg,var(--chrome),var(--chrome2));color:#2a1a22;font-size:.85rem;display:grid;place-items:center}.mini.play{background:linear-gradient(180deg,#ff6b84,var(--coral));color:#fff;border-color:var(--coral)}.mini.ghost{background:transparent;color:var(--chrome2)}.mini-vinyl{width:18px;height:18px;border-radius:50%;background:radial-gradient(circle,var(--coral) 0 3px,#111 4px 100%);box-shadow:inset 0 0 0 1px #fff3}.controls{position:sticky;bottom:0;display:flex;justify-content:center;align-items:center;gap:18px;padding:12px 16px calc(12px + env(safe-area-inset-bottom));background:linear-gradient(180deg,var(--chrome),var(--chrome2));border-top:3px solid #fff;box-shadow:0 -6px 16px #00000080}.chrome-btn{position:relative;width:48px;height:48px;border-radius:50%;border:3px solid #fff;background:radial-gradient(circle at 35% 30%,#fff 0%,var(--chrome) 40%,var(--chrome2) 100%);color:#4a2a33;font-size:1.1rem;box-shadow:0 4px 8px #0006,inset 0 -3px 5px #0003;transition:transform .12s}.chrome-btn:active{transform:scale(.92)}.chrome-btn.big{width:64px;height:64px;font-size:1.4rem;color:var(--cherry)}.chrome-btn.lit{box-shadow:0 0 14px var(--teal),inset 0 -3px 5px #0003}.chrome-btn.wide{width:auto;border-radius:26px;padding:0 22px;height:46px;font-size:1rem}.badge{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;border-radius:10px;background:var(--coral);color:#fff;font-size:.7rem;font-weight:700;display:grid;place-items:center;padding:0 4px}.queue-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;background:#0009;display:flex;align-items:flex-end;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.queue-panel,.modal{width:100%;max-width:560px;max-height:80dvh;overflow-y:auto;background:linear-gradient(180deg,#2a1a22,#1d1017);border:3px solid var(--chrome2);border-bottom:none;border-radius:18px 18px 0 0;padding:16px 18px calc(20px + env(safe-area-inset-bottom));animation:rise .3s cubic-bezier(.25,1,.4,1)}@keyframes rise{0%{transform:translateY(30%);opacity:0}}.queue-panel header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.queue-panel h2,.modal h2{margin:0;font-family:Alfa Slab One,serif;font-size:1.2rem;color:var(--cream)}.text-btn{background:none;border:none;color:var(--teal);font-size:.95rem;padding:6px 8px}.queue-row{display:flex;align-items:center;gap:10px;padding:8px 4px;border-bottom:1px solid rgba(255,255,255,.08)}.queue-row.now{border-bottom:2px solid var(--teal)}.queue-row .pos{width:22px;text-align:center;opacity:.7}.queue-row img{width:40px;height:40px;border-radius:6px;object-fit:cover}.q-meta{flex:1;min-width:0}.q-meta strong,.q-meta span{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.q-meta span{font-size:.8rem;opacity:.7}.queue-row em{font-size:.75rem;color:var(--teal);font-style:normal}.queue-empty{opacity:.7;text-align:center;padding:18px 8px}.modal label{display:block;margin:10px 0 0;font-size:.85rem;letter-spacing:.04em;color:var(--chrome)}.modal input{display:block;width:100%;margin-top:4px;padding:9px 12px;border-radius:8px;border:2px solid var(--chrome2);background:var(--cream);color:#3a2323;font-size:.95rem;font-family:inherit}.modal input[type=file]{background:transparent;color:var(--cream);border-style:dashed}.modal small{display:block;margin-top:4px;opacity:.6;font-size:.75rem}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:0 12px}.form-error{color:var(--coral);font-size:.9rem}.modal-actions{display:flex;justify-content:flex-end;align-items:center;gap:10px;margin-top:16px}.popup{position:fixed;z-index:30;left:50%;top:20%;transform:translate(-50%);display:flex;gap:12px;align-items:center;max-width:min(420px,90vw);padding:12px 16px;background:linear-gradient(180deg,var(--cream),#efdfba);color:#3a2323;border:3px solid var(--chrome2);border-radius:14px;box-shadow:0 10px 30px #0009,0 0 18px #35e0d066;animation:pop .26s cubic-bezier(.25,1.4,.5,1)}@keyframes pop{0%{transform:translate(-50%) scale(.8);opacity:0}}.popup img{width:64px;height:64px;border-radius:8px;object-fit:cover}.popup div{min-width:0}.popup strong{display:block;font-family:Alfa Slab One,serif;font-size:1rem}.popup span,.popup em,.popup small{display:block;font-size:.85rem}.popup em{color:var(--cherry);font-style:normal}.popup small{opacity:.7}.toast{position:fixed;z-index:40;left:50%;bottom:calc(96px + env(safe-area-inset-bottom));transform:translate(-50%);padding:10px 18px;border-radius:20px;background:#000000d9;color:var(--cream);border:1px solid var(--teal);font-size:.9rem;max-width:90vw;text-align:center;animation:pop .2s ease-out}@media (min-width: 700px){.jukebox{max-width:640px;border-width:10px;margin-top:16px;margin-bottom:16px;min-height:calc(100dvh - 32px);border-radius:34px 34px 10px 10px}.rail{padding-bottom:20px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
