:root{--bg-deep: #05080c;--bg-surface: #0c1117;--bg-card: rgba(12, 20, 30, .65);--bg-card-border: rgba(0, 229, 255, .08);--text-primary: #e8edf3;--text-secondary: #6b7a8d;--text-muted: #3d4a59;--cyan: #00e5ff;--cyan-dim: #007a8a;--cyan-glow: rgba(0, 229, 255, .35);--cyan-glow-strong: rgba(0, 229, 255, .6);--cyan-subtle: rgba(0, 229, 255, .06);--red: #ff3b5c;--red-glow: rgba(255, 59, 92, .3);--green: #00e676;--green-glow: rgba(0, 230, 118, .3);--amber: #ffab00;--amber-glow: rgba(255, 171, 0, .3);--yellow: #eab308;--spotify: #1DB954;--spotify-dim: #1a9e48;--spotify-glow: rgba(29, 185, 84, .35);--spotify-subtle: rgba(29, 185, 84, .06);--border-subtle: rgba(255, 255, 255, .05);--bg-subtle: rgba(255, 255, 255, .03);--bg-subtle-hover: rgba(255, 255, 255, .06);--bg-track: rgba(255, 255, 255, .06);--bg-track-inactive: rgba(255, 255, 255, .12);--font-display: "Syne", sans-serif;--font-body: "DM Sans", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2.5rem;--space-2xl: 4rem;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--radius-full: 9999px;--ease-out-expo: cubic-bezier(.16, 1, .3, 1)}[data-theme=light]{--bg-deep: #f0f2f5;--bg-surface: #ffffff;--bg-card: rgba(255, 255, 255, .8);--bg-card-border: rgba(0, 0, 0, .06);--text-primary: #1a1a2e;--text-secondary: #4a5568;--text-muted: #718096;--cyan: #0891b2;--cyan-dim: #0e7490;--cyan-glow: rgba(8, 145, 178, .15);--cyan-glow-strong: rgba(8, 145, 178, .3);--cyan-subtle: rgba(8, 145, 178, .06);--border-subtle: rgba(0, 0, 0, .08);--border-accent: rgba(8, 145, 178, .3);--bg-subtle: rgba(0, 0, 0, .02);--bg-subtle-hover: rgba(0, 0, 0, .05);--bg-track: rgba(0, 0, 0, .06);--bg-track-inactive: rgba(0, 0, 0, .12)}[data-theme=light] body:before{opacity:.015}[data-theme=light] body:after{opacity:.06}[data-theme=light] .btn-secondary{border-color:#0000001a}[data-theme=light] .btn-secondary:hover:not(:disabled){border-color:#0003;background:#00000008}[data-theme=light] .divider{background:linear-gradient(90deg,transparent,rgba(0,0,0,.08),transparent)}[data-theme=light] .spotify-search__input{background:#00000008;border-color:#0000001a}[data-theme=light] .spotify-search__input:focus{background:#00000005}[data-theme=light] .spotify-track{background:#00000005;border-color:#0000000f}[data-theme=light] .spotify-track:hover{background:#0000000d;border-color:#0000001a}[data-theme=light] .spotify-tabs{border-bottom-color:#00000014}[data-theme=light] .playlist-item{background:#00000005;border-color:#0000000f}[data-theme=light] .playlist-item:hover{background:#0000000d;border-color:#0000001a;border-left-color:#0000001a}[data-theme=light] .spotify-playlist{background:#00000005;border-color:#0000000f}[data-theme=light] .spotify-playlist:hover{background:#0000000d;border-color:#0000001a}[data-theme=light] ::-webkit-scrollbar-thumb{background:#0003}[data-theme=light] .queue-drawer{background:#f5f5f5;border-top-color:#00000014}[data-theme=light] .queue-drawer__footer{border-top-color:#0000000f}[data-theme=light] .queue-pill{background:#f5f5f5;border-color:#0000001a}[data-theme=light] .queue-pill:hover{background:#0000000a}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background:var(--bg-deep);color:var(--text-primary);min-height:100dvh;overflow-x:hidden;line-height:1.5}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;pointer-events:none;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px}body:after{content:"";position:fixed;top:-30%;left:50%;translate:-50% 0;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,var(--cyan-glow) 0%,transparent 70%);opacity:.12;pointer-events:none;z-index:0;filter:blur(80px)}#root{position:relative;z-index:1;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-lg)}h1,h2,h3{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;line-height:1.1}.card{background:var(--bg-card);border:1px solid var(--bg-card-border);border-radius:var(--radius-lg);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);padding:var(--space-lg);width:100%;max-width:420px}.btn{font-family:var(--font-display);font-weight:600;font-size:.95rem;letter-spacing:.03em;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all .25s var(--ease-out-expo);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:.75rem 1.75rem;position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;opacity:0;transition:opacity .25s}.btn:active{transform:scale(.97)}.btn-primary{background:var(--cyan);color:var(--bg-deep);box-shadow:0 0 20px var(--cyan-glow),0 0 60px #00e5ff1a}.btn-primary:hover:not(:disabled){box-shadow:0 0 30px var(--cyan-glow-strong),0 0 80px #00e5ff26;filter:brightness(1.1)}.btn-primary:disabled{opacity:.3;cursor:not-allowed;box-shadow:none}.btn-secondary{background:transparent;color:var(--text-primary);border:1px solid rgba(255,255,255,.1)}.btn-secondary:hover:not(:disabled){border-color:#ffffff40;background:#ffffff0a}.btn-secondary:disabled{opacity:.3;cursor:not-allowed}.btn-danger{background:transparent;color:var(--red);border:1px solid rgba(255,59,92,.2)}.btn-danger:hover:not(:disabled){background:#ff3b5c14;border-color:#ff3b5c66}.btn-ghost{background:transparent;color:var(--text-secondary);padding:.5rem 1rem}.btn-ghost:hover{color:var(--text-primary)}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.status-dot--synced{background:var(--green);box-shadow:0 0 8px var(--green-glow);animation:pulse-glow 2s ease-in-out infinite}.status-dot--syncing{background:var(--amber);box-shadow:0 0 8px var(--amber-glow);animation:pulse-glow 1s ease-in-out infinite}.status-dot--error{background:var(--red);box-shadow:0 0 8px var(--red-glow)}@keyframes pulse-glow{0%,to{opacity:1}50%{opacity:.5}}.room-code{font-family:var(--font-mono);font-size:2.2rem;font-weight:700;letter-spacing:.25em;color:var(--cyan);text-shadow:0 0 20px var(--cyan-glow),0 0 60px rgba(0,229,255,.15);text-align:center;padding:var(--space-xs) 0}.room-input{font-family:var(--font-mono);font-size:2.5rem;font-weight:700;letter-spacing:.3em;text-align:center;width:100%;max-width:220px;padding:.5rem;background:transparent;border:none;border-bottom:2px solid var(--text-muted);color:var(--cyan);caret-color:var(--cyan);outline:none;transition:border-color .3s,text-shadow .3s;text-shadow:0 0 10px rgba(0,229,255,.1)}.room-input::placeholder{color:var(--text-muted);letter-spacing:.15em;font-size:1.2rem;text-shadow:none}.room-input:focus{border-color:var(--cyan);text-shadow:0 0 20px var(--cyan-glow)}.upload-zone{border:2px dashed var(--text-muted);border-radius:var(--radius-md);padding:var(--space-xl) var(--space-lg);text-align:center;cursor:pointer;transition:all .3s var(--ease-out-expo);position:relative;overflow:hidden}.upload-zone:hover{border-color:var(--cyan-dim);background:var(--cyan-subtle)}.upload-zone--loaded{border-color:var(--cyan-dim);border-style:solid;background:var(--cyan-subtle)}.upload-zone input[type=file]{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.status-bar{display:flex;align-items:center;gap:var(--space-sm);font-size:.85rem;color:var(--text-secondary)}.divider{width:100%;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent);margin:var(--space-lg) 0}.text-center{text-align:center}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-cyan{color:var(--cyan)}.text-sm{font-size:.85rem}.text-xs{font-size:.75rem}.mt-xs{margin-top:var(--space-xs)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mt-xl{margin-top:var(--space-xl)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.flex-center{display:flex;align-items:center;justify-content:center}.flex-col{display:flex;flex-direction:column;align-items:center}.btn-spotify{background:var(--spotify);color:#fff;box-shadow:0 0 20px var(--spotify-glow),0 0 60px #1db9541a}.btn-spotify:hover:not(:disabled){box-shadow:0 0 30px #1db9548c,0 0 80px #1db95426;filter:brightness(1.1)}.btn-spotify:disabled{opacity:.3;cursor:not-allowed;box-shadow:none}.spotify-search{position:relative;width:100%}.spotify-search__icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;transition:color .25s}.spotify-search__input{font-family:var(--font-body);font-size:.9rem;width:100%;padding:.65rem .8rem .65rem 38px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-md);color:var(--text-primary);outline:none;transition:border-color .25s,box-shadow .25s,background .25s}.spotify-search__input::placeholder{color:var(--text-muted)}.spotify-search__input:focus{border-color:var(--spotify-dim);box-shadow:0 0 0 3px #1db9541a;background:#ffffff0f}.spotify-search:focus-within .spotify-search__icon{color:var(--spotify)}.spotify-track{display:flex;align-items:center;gap:10px;padding:8px 10px;background:#ffffff05;border:1px solid rgba(255,255,255,.04);border-radius:var(--radius-sm);cursor:pointer;text-align:left;width:100%;font-family:var(--font-body);color:var(--text-primary);transition:background .2s,border-color .2s}.spotify-track:hover{background:#ffffff0f;border-color:#ffffff1a}.spotify-track--active{background:var(--spotify-subtle);border-color:#1db95433}.spotify-track--active:hover{background:#1db9541a;border-color:#1db9544d}.spotify-track__add{background:none;border:1px solid rgba(255,255,255,.08);color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:var(--radius-sm);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:color .2s,background .2s,border-color .2s;line-height:1}.spotify-track__add:hover{color:var(--cyan);background:#00e5ff14;border-color:#00e5ff33}[data-theme=light] .spotify-track__add{border-color:#0000001a}[data-theme=light] .spotify-track__add:hover{background:#00e5ff14;border-color:#00e5ff33}.spotify-now-playing{display:flex;align-items:center;gap:12px;padding:12px 14px;background:linear-gradient(135deg,#1db95414,#1db95408);border:1px solid rgba(29,185,84,.15);border-radius:var(--radius-md);position:relative;overflow:hidden;width:100%;box-sizing:border-box}.spotify-now-playing:before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:var(--spotify);border-radius:0 2px 2px 0}.spotify-now-playing__art{width:48px;height:48px;border-radius:6px;flex-shrink:0;box-shadow:0 4px 12px #0006}.spotify-now-playing__info{flex:1;min-width:0}.spotify-now-playing__title{font-size:.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary)}.spotify-now-playing__artist{font-size:.73rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.spotify-now-playing__controls{display:flex;align-items:center;gap:2px;flex-shrink:0}.spotify-now-playing__btn{background:none;border:none;color:var(--spotify);cursor:pointer;padding:8px;border-radius:50%;flex-shrink:0;transition:background .2s;display:flex;align-items:center;justify-content:center}.spotify-now-playing__btn--sm{padding:6px;color:var(--text-secondary)}.spotify-now-playing__btn--sm:hover{color:var(--spotify)}.spotify-now-playing__btn:hover{background:#1db9541f}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:3px}.spotify-tabs{display:flex;gap:2px;width:100%;border-bottom:1px solid rgba(255,255,255,.06);padding-bottom:0}.spotify-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:8px 4px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-family:var(--font-body);font-size:.75rem;font-weight:500;cursor:pointer;transition:color .2s,border-color .2s;white-space:nowrap}.spotify-tab:hover{color:var(--text-primary)}.spotify-tab--active{color:var(--spotify);border-bottom-color:var(--spotify)}.spotify-library{display:flex;flex-direction:column;gap:4px;max-height:300px;overflow-y:auto;padding-right:2px;width:100%}.spotify-playlist{display:flex;align-items:center;gap:10px;padding:8px 10px;background:#ffffff05;border:1px solid rgba(255,255,255,.04);border-radius:var(--radius-sm);cursor:pointer;width:100%;text-align:left;font-family:var(--font-body);color:var(--text-primary);transition:background .2s,border-color .2s}.spotify-playlist:hover{background:#ffffff0f;border-color:#ffffff1a}.spotify-playlist__art{width:48px;height:48px;border-radius:6px;flex-shrink:0;object-fit:cover;box-shadow:0 2px 8px #0000004d;background:var(--bg-surface)}.spotify-back{display:flex;align-items:center;gap:6px;padding:6px 0;background:none;border:none;color:var(--spotify);font-family:var(--font-body);font-size:.82rem;font-weight:600;cursor:pointer;transition:opacity .2s;width:100%;text-align:left}.spotify-back:hover{opacity:.8}.spotify-loading{display:flex;align-items:center;justify-content:center;padding:var(--space-lg);color:var(--text-muted);font-size:.85rem}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;background:var(--text-muted);border-radius:2px;outline:none;cursor:pointer}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--cyan);box-shadow:0 0 6px var(--cyan-glow);cursor:pointer}input[type=range]::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--cyan);box-shadow:0 0 6px var(--cyan-glow);cursor:pointer;border:none}input[type=range]::-moz-range-track{background:var(--text-muted);height:4px;border-radius:2px}.eq-slider{writing-mode:vertical-lr;direction:rtl;height:80px;width:4px}.playlist-panel{width:100%}.playlist-panel__label{font-family:var(--font-body);font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);padding:0 2px;margin-bottom:6px}.playlist-panel__list{display:flex;flex-direction:column;gap:3px;overflow-y:auto;padding-right:2px}.playlist-item{display:flex;align-items:center;gap:8px;padding:6px 8px;background:#ffffff05;border:1px solid rgba(255,255,255,.04);border-left:3px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:background .2s,border-color .2s;-webkit-user-select:none;user-select:none}.playlist-item:hover{background:#ffffff0f;border-color:#ffffff1a;border-left-color:#ffffff1a}.playlist-item--current{background:var(--cyan-subtle);border-left-color:var(--cyan)}.playlist-item--current:hover{background:#00e5ff1a;border-left-color:var(--cyan)}.playlist-item--dragging{opacity:.6;background:#00e5ff14}.playlist-item__handle{color:var(--text-muted);cursor:grab;font-size:.9rem;line-height:1;flex-shrink:0;padding:2px;-webkit-user-select:none;user-select:none}.playlist-item__handle:active{cursor:grabbing}.playlist-item__art{width:32px;height:32px;border-radius:3px;flex-shrink:0;object-fit:cover}.playlist-item__info{flex:1;min-width:0}.playlist-item__name{font-size:.8rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary)}.playlist-item__meta{font-size:.68rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.playlist-item__remove{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1.1rem;padding:2px 6px;border-radius:4px;flex-shrink:0;transition:color .2s,background .2s;line-height:1}.playlist-item__remove:hover{color:var(--red);background:#ff3b5c1a}.queue-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:69}.queue-drawer{position:fixed;bottom:0;left:50%;width:100%;max-width:420px;height:50vh;background:var(--bg-surface);border:1px solid var(--bg-card-border);border-bottom:none;border-radius:var(--radius-lg) var(--radius-lg) 0 0;z-index:70;display:flex;flex-direction:column;padding-bottom:env(safe-area-inset-bottom)}.queue-drawer__handle{width:36px;height:4px;background:var(--text-muted);border-radius:var(--radius-full);margin:10px auto 0;flex-shrink:0}.queue-drawer__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-lg);flex-shrink:0}.queue-drawer__body{flex:1;overflow-y:auto;padding:0 var(--space-lg)}.queue-drawer__footer{display:flex;justify-content:center;gap:var(--space-md);padding:var(--space-sm) var(--space-lg);border-top:1px solid rgba(255,255,255,.04);flex-shrink:0}.queue-pill{position:fixed;bottom:calc(var(--space-md) + env(safe-area-inset-bottom));left:50%;z-index:68;background:var(--bg-surface);border:1px solid var(--bg-card-border);border-radius:var(--radius-full);padding:8px 20px;cursor:pointer;display:flex;align-items:center;gap:var(--space-sm);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);transition:background .2s;color:var(--text-primary);font-size:.82rem}.queue-pill:hover{background:#ffffff0f}.status-dot--warning{background:var(--yellow);box-shadow:0 0 6px var(--yellow)}.status-dot--poor{background:var(--red);box-shadow:0 0 6px var(--red);animation:pulse-red 1.5s ease-in-out infinite}@keyframes pulse-red{0%,to{opacity:1}50%{opacity:.5}}.status-dot--reconnecting{background:var(--yellow, #eab308);box-shadow:0 0 6px var(--yellow, #eab308);animation:pulse-yellow 1.5s ease-in-out infinite}@keyframes pulse-yellow{0%,to{opacity:1}50%{opacity:.4}}.reconnect-banner{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md, 8px);font-size:.8rem;font-family:var(--font-mono)}.reconnect-banner--warning{background:#eab3081a;color:var(--yellow, #eab308);border:1px solid rgba(234,179,8,.2)}.reconnect-banner--error{background:#ef44441a;color:var(--red, #ef4444);border:1px solid rgba(239,68,68,.2)}.theme-toggle{position:fixed;top:16px;right:16px;z-index:50;background:var(--bg-card);border:1px solid var(--bg-card-border);border-radius:var(--radius-full);padding:8px;cursor:pointer;color:var(--text-secondary);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;transition:color .25s,border-color .25s}.theme-toggle:hover{color:var(--text-primary);border-color:var(--cyan)}.visualizer-container{position:relative;width:100%}.visualizer{width:100%;height:80px;display:block;border-radius:var(--radius-sm)}.visualizer-toggle{position:absolute;top:4px;right:4px;background:var(--bg-card);border:1px solid var(--bg-card-border);border-radius:var(--radius-full);padding:4px;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:color .25s;opacity:0}.visualizer-container:hover .visualizer-toggle{opacity:1}.visualizer-toggle:hover{color:var(--cyan)}.install-prompt{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:60;display:flex;align-items:center;gap:var(--space-sm);padding:10px 16px;background:var(--bg-card);border:1px solid var(--bg-card-border);border-radius:var(--radius-lg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 4px 24px #0000004d;max-width:calc(100% - 32px)}.install-prompt__text{font-size:.8rem;color:var(--text-secondary);white-space:nowrap}.install-prompt__actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.sw-update-banner{position:fixed;top:16px;left:50%;transform:translate(-50%);z-index:60;display:flex;align-items:center;gap:var(--space-sm);padding:8px 14px;background:var(--bg-card);border:1px solid var(--cyan-dim);border-radius:var(--radius-lg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 4px 24px #0000004d}body{padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}@media (max-width: 639px){#root{padding:var(--space-md);padding-bottom:calc(var(--space-md) + env(safe-area-inset-bottom,0px))}.card{max-width:100%;border-radius:var(--radius-md);padding:var(--space-lg)}.room-code{font-size:2.2rem;letter-spacing:.2em}.room-input{font-size:2rem;letter-spacing:.25em}.btn{min-height:44px;padding:.75rem 1.25rem}.btn-ghost{min-height:44px}input[type=range]{height:6px}input[type=range]::-webkit-slider-thumb{width:20px;height:20px}input[type=range]::-moz-range-thumb{width:20px;height:20px}.theme-toggle{padding:10px;top:env(safe-area-inset-top,12px)}.status-bar{font-size:.78rem}.eq-slider{height:100px}.playlist-item{padding:8px 6px}.playlist-item__art{width:28px;height:28px}.playlist-item__name{font-size:.75rem}.playlist-item__meta{font-size:.62rem}.spotify-library{max-height:200px}.qr-container canvas,.qr-container svg{max-width:160px!important;max-height:160px!important}.spotify-now-playing{padding:8px 10px;gap:8px}.spotify-now-playing__art{width:40px;height:40px}.spotify-now-playing__title{font-size:.8rem}.spotify-now-playing__artist{font-size:.68rem}.spotify-now-playing__btn{padding:10px;min-width:44px;min-height:44px}.spotify-now-playing__btn--sm{padding:8px;min-width:44px;min-height:44px}.upload-zone{padding:var(--space-lg) var(--space-md)}.reconnect-banner{font-size:.75rem;padding:var(--space-xs) var(--space-sm)}.visualizer{height:48px}.visualizer-toggle{opacity:1}.install-prompt{bottom:calc(12px + env(safe-area-inset-bottom,0px));padding:8px 12px}.install-prompt__text{font-size:.72rem;white-space:normal}}@media (min-width: 640px) and (max-width: 1023px){.card{max-width:520px}.btn{min-height:44px}input[type=range]::-webkit-slider-thumb{width:18px;height:18px}input[type=range]::-moz-range-thumb{width:18px;height:18px}}@media (min-width: 1024px){.card{max-width:420px}}
