@import "https://fonts.googleapis.com/css2?family=Azeret+Mono:wght@400;600;800;900&display=swap";
:root{--bg:#000216;--panel:#050b45;--text:#f4f3f8;--muted:#848ab0;--pink:#ff00df;--pink-dark:#7a005f;--blue:#1238ff;--border:#ffffff14;--font-app:"Azeret Mono", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;--5-x-position:19.6094%;--5-y-position:60.4688%;--6-x-position:79.6094%;--6-y-position:20.9766%;--7-x-position:70.625%;--7-y-position:71.0156%}@property --5-x-position{syntax:"<percentage>";inherits:false;initial-value:19.6094%}@property --5-y-position{syntax:"<percentage>";inherits:false;initial-value:60.4688%}@property --6-x-position{syntax:"<percentage>";inherits:false;initial-value:79.6094%}@property --6-y-position{syntax:"<percentage>";inherits:false;initial-value:20.9766%}@property --7-x-position{syntax:"<percentage>";inherits:false;initial-value:70.625%}@property --7-y-position{syntax:"<percentage>";inherits:false;initial-value:71.0156%}*{box-sizing:border-box}html,body{background:var(--bg);color:var(--text);font-family:var(--font-app);margin:0;padding:0}body :not(svg):not(path):not(circle):not(line):not(rect):not(polygon):not(polyline){font-family:var(--font-app)}button,input,textarea,select{font:inherit}img{max-width:100%;display:block}body{overflow:hidden}.app-shell{background:var(--bg);grid-template-columns:minmax(620px,1fr) minmax(560px,720px);gap:2rem;min-height:100vh;padding:2rem 2.5rem;display:grid}.browse-shell{grid-template-columns:1fr}.browse-shell .left-panel{display:none}.browse-shell .right-panel{align-items:stretch;width:100%;padding-right:96px}.touch-square-shell{gap:0;padding:0}.touch-square-shell .right-panel{width:100%;padding-right:0}.touch-square-shell .left-panel{display:none}.browse-shell .library-grid,.browse-shell .playlist-grid,.browse-shell .media-grid{grid-template-columns:repeat(6,minmax(0,1fr))}.browse-shell .library-screen{padding-top:.5rem}.library-screen .screen-header{margin-bottom:5rem}.library-screen .screen-topbar{margin-bottom:1.6rem}.library-screen .screen-title{letter-spacing:.02em;font-size:clamp(3.8rem,6vw,6rem)}.auth-shell{background:radial-gradient(100% 100% at var(--5-x-position) var(--5-y-position), #02f 0%, transparent), radial-gradient(100% 100% at var(--6-x-position) var(--6-y-position), #ff00ea 0%, transparent), radial-gradient(100% 100% at var(--7-x-position) var(--7-y-position), #00053e 0%, transparent), #00053e;grid-template-columns:1fr;place-items:center;padding:0;transition-timing-function:ease-in-out;animation-name:main;animation-duration:24s;animation-iteration-count:infinite}.left-panel{justify-content:center;align-items:center;min-width:0;display:flex}.right-panel{flex-direction:column;justify-content:flex-start;align-items:center;min-width:0;display:flex;position:relative}.auth-shell .right-panel{justify-content:center;width:100%;min-height:100vh}.turntable-wrap{aspect-ratio:1;place-items:center;width:min(94vh,88vw,1380px);display:grid;position:relative}.record{aspect-ratio:1;background-image:url(/images/record-gradient.png);background-position:50%;background-size:cover;border-radius:50%;width:82%;animation:4s linear infinite paused spinRecord;position:absolute;overflow:hidden;box-shadow:0 0 120px #ff00e52e,0 0 40px #1238ff40}.record:after{content:"";mix-blend-mode:overlay;background:linear-gradient(140deg,#ffffff26 0%,#ffffff0d 15%,#0003 60%,#0000 100%);border-radius:50%;position:absolute;inset:0}.record-grooves{opacity:.38;background:repeating-radial-gradient(circle,#0000 0 2.65%,#ffffff29 2.72% 2.92%);border-radius:50%;position:absolute;inset:3%}.record-inner{background:radial-gradient(circle,#ff27f0 0%,#ff00e5 100%);border-radius:50%;position:absolute;inset:33%}.record-hole{background:#00104a;border-radius:50%;position:absolute;inset:48%}.record-label{background:radial-gradient(circle,#ff00e5 0%,#d000ff 100%);border-radius:50%;place-items:center;display:grid;position:absolute;inset:34%;overflow:hidden;box-shadow:0 0 24px #0000002e}.record-label-image{object-fit:cover;width:100%;height:100%}.record-label-fallback{background:radial-gradient(circle,#ff00e5 0%,#d000ff 100%);width:100%;height:100%}.record.spinning{animation-play-state:running}@keyframes spinRecord{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tonearm{background:linear-gradient(270deg, var(--pink), #c900ff);transform-origin:92%;border-radius:999px;width:75%;height:16px;position:absolute;top:10%;right:10%;transform:rotate(-20deg);box-shadow:0 0 24px #ff00df33}.tonearm:before{content:"";background:radial-gradient(circle, var(--pink) 0 38%, #6b005f 39% 64%, #43004d 65% 100%);border-radius:999px;width:74px;height:74px;position:absolute;top:50%;right:-26px;transform:translateY(-50%);box-shadow:0 0 0 10px #ff00e51f}.tonearm:after{content:"";background:#70005f;border-radius:12px;width:56px;height:84px;position:absolute;top:-22px;left:-10px}.player-screen,.screen{flex-direction:column;width:100%;height:calc(100vh - 4rem);min-height:0;display:flex}.player-topbar,.screen-topbar{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.screen-header{margin-bottom:1.5rem}.screen-header .screen-topbar{margin-bottom:.8rem}.screen-topbar-left{justify-content:flex-start;align-items:center;gap:1.5rem;display:flex}.back-link,.speaker-button,.queue-close,.connect-button,.library-tile,.playlist-card,.up-next-card,.circle-button,.player-shortcut{color:var(--text);background:0 0;border:0}.back-link,.mini-status,.screen-title,.section-title,.library-tile-label,.track-title,.queue-header h2,.big-back{text-transform:uppercase;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.back-link{cursor:pointer;letter-spacing:.02em;font-size:1rem}.back-link:hover{opacity:.85}.screen-title,.screen-heading-link{text-align:left;width:100%;display:block}.topbar-actions{align-items:center;gap:1rem;display:flex}.player-shortcut{cursor:pointer;width:32px;height:32px;color:var(--text);place-items:center;padding:0;display:grid}.player-shortcut-icon{width:20px;height:20px;display:block}.player-shortcut:hover{color:var(--pink)}.big-back{font-size:clamp(2.2rem,4vw,4rem);font-weight:800;line-height:1}.speaker-button{border:2px solid var(--pink);cursor:pointer;border-radius:0;place-items:center;width:44px;height:44px;font-size:1.2rem;display:grid}.player-card{text-align:center;flex-direction:column;align-items:center;width:100%;max-width:620px;display:flex}.player-stage-screen{--player-turntable-size:min(78vh, 64vw, 1200px);justify-content:center}.player-stage{flex:1;justify-content:center;align-items:center;width:100%;min-height:0;display:flex;position:relative;overflow:hidden}.player-stage-turntable{justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:absolute;inset:0}.player-turntable-stack{pointer-events:none;flex-direction:column;justify-content:center;align-items:center;gap:4.4rem;display:flex}.player-stage-screen .turntable-wrap{width:var(--player-turntable-size)}.player-stage-screen .tonearm{transform-origin:93%;width:57%;height:14px;top:12%;right:7%;transform:rotate(-71deg)}.player-stage-screen .tonearm:before{width:66px;height:66px;right:-18px;box-shadow:0 0 0 12px #ff00e51a}.player-stage-screen .tonearm:after{background:#380032;width:70px;height:52px;top:-20px;left:-48px}.player-touch-square-screen{width:100%;height:100%;min-height:100vh}.player-touch-square-stage{cursor:pointer;width:100%;height:100%;min-height:100vh;position:relative;overflow:hidden}.player-touch-square-stage:focus-visible{outline-offset:-8px;outline:2px solid #6572fce6}.player-touch-square-artwork-shell{transform-origin:50%;will-change:transform;animation:18s linear infinite paused spinTouchArtwork;position:absolute;inset:-36%}.player-touch-square-artwork-shell.is-spinning{animation-play-state:running}.player-touch-square-artwork{object-fit:cover;width:100%;height:100%}.player-touch-square-grooves{pointer-events:none;mix-blend-mode:screen;opacity:.55;background:repeating-radial-gradient(circle,#ffffff1f 0 2px,#ffffff03 2px 12px);border-radius:50%;position:absolute;inset:0}.player-touch-square-center-hole{background:#03051f;border-radius:50%;width:75px;height:75px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 5px #f5f4ff14,0 0 22px #0000004d}.player-touch-square-artwork-fallback{background:radial-gradient(circle at 34% 34%,#ff00e580,#0000 28%),radial-gradient(circle at 68% 68%,#0022ff73,#0000 34%),linear-gradient(140deg,#10006e 0%,#03052d 100%);justify-content:center;align-items:center;width:100%;height:100%;display:flex}.player-touch-square-fallback-disc{background:repeating-radial-gradient(circle,#ffffff14 0 2px,#0000 2px 11px),linear-gradient(140deg,#ff00e5 0%,#1d2bff 100%);border-radius:50%;width:100%;height:100%;box-shadow:0 0 42px #5d35ff42}.player-touch-square-overlay{opacity:0;pointer-events:none;background:#0104166b;justify-content:center;align-items:center;padding:2rem;transition:opacity .18s;display:flex;position:absolute;inset:0}.player-touch-square-overlay.is-visible{opacity:1;pointer-events:auto}.player-touch-square-controls{flex-wrap:wrap;justify-content:center;align-items:center;gap:1.6rem;display:flex}.player-touch-square-button{color:#f5f4ff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);text-shadow:0 0 24px #00000073;background:#0509246b;border:0;border-radius:50%;justify-content:center;align-items:center;width:156px;height:156px;font-size:3.2rem;line-height:1;display:inline-flex;box-shadow:0 18px 40px #00000038}.player-touch-square-button svg{width:4rem;height:4rem}@keyframes spinTouchArtwork{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.app-control-rail{z-index:3;flex-direction:column;gap:1rem;display:flex;position:absolute;top:50%;right:0;transform:translateY(-50%)}.player-rail-expander-slot{justify-content:flex-end;align-items:center;height:20px;display:flex}.app-control-rail-item{justify-content:flex-end;align-items:center;display:flex;position:relative}.app-control-rail-label{opacity:0;pointer-events:none;white-space:nowrap;color:#3f4173;letter-spacing:.04em;text-transform:uppercase;background:0 0;border-radius:12px;padding:.85rem 1rem;font-size:.95rem;font-weight:400;transition:opacity .18s,transform .22s;position:absolute;top:50%;right:calc(100% + .85rem);transform:translate(14px,-50%);box-shadow:0 18px 44px #00000047}.app-control-rail-label.is-visible{opacity:1;transform:translateY(-50%)}.player-rail-button,.app-control-rail .speaker-button{width:64px;height:64px;color:var(--text);cursor:pointer;background:#ffffff1f;border:0;border-radius:12px;place-items:center;transition:background-color .16s,color .16s,box-shadow .16s;display:grid}.player-rail-button:hover,.app-control-rail .speaker-button:hover{color:#c6c8ff;background:#ffffff2e}.player-rail-button svg,.app-control-rail .speaker-icon,.player-rail-button .player-shortcut-icon{width:28px;height:28px;display:block}.player-rail-play{background:#ffffff2e;font-size:1.55rem}.player-rail-button.is-active{color:var(--pink);background:#ff00df29;box-shadow:inset 0 0 0 1px #ff00df47}.player-rail-expander{margin-bottom:.2rem;color:#4c4c4c!important;background:0 0!important;height:20px!important}.player-rail-expander.is-active{box-shadow:none}.player-rail-expander.is-hidden{visibility:hidden;pointer-events:none}.player-rail-expander svg{width:20px;height:20px}.player-info-corner{z-index:3;max-width:min(30vw,650px);position:absolute;bottom:2.6rem;left:1rem}.player-title-row{align-items:center;gap:.7rem;display:flex}.player-info-corner .track-title{text-align:left;text-transform:uppercase;letter-spacing:0;color:#7e81d1;margin:0 0 .3rem;font-family:Azeret Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:28px;font-style:normal;font-weight:800;line-height:normal}.player-title-favourite{color:#7e81d1;background:0 0;border:0;flex:none;justify-content:center;align-items:center;width:1.55rem;height:1.55rem;margin:0 0 .3rem;padding:0;display:inline-flex}.player-title-favourite .heart-icon{width:100%;height:100%}.player-title-favourite.is-active{color:#ff4ae1}.player-info-corner .track-artist{text-align:left;text-transform:uppercase;letter-spacing:0;color:#7e81d1;margin:0;font-family:Azeret Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:18px;font-style:normal;font-weight:600;line-height:20px}.player-up-next-line{text-transform:uppercase;letter-spacing:0;color:#6572fc;margin:.9rem 0 0;font-family:Azeret Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:18px;font-style:normal;line-height:20px}.player-up-next-label{color:#6572fc;font-weight:900}.player-up-next-title{color:#6572fc;font-weight:400}.player-progress-dock{z-index:3;pointer-events:auto;width:min(34vw,480px);margin:0;position:static;transform:none}.player-artwork-frame{aspect-ratio:1;border-right:4px solid var(--pink);border-bottom:4px solid var(--pink);background:#ffffff08;width:100%;max-width:520px;overflow:hidden}.player-artwork-image{object-fit:cover;width:100%;height:100%}.player-artwork-fallback{width:100%;height:100%;color:var(--muted);background:linear-gradient(135deg,#ff00e533,#1238ff66);place-items:center;display:grid}.mini-status{color:var(--muted);letter-spacing:.08em;justify-content:center;gap:.75rem;margin-top:.75rem;font-size:.9rem;display:flex}.track-title{letter-spacing:.04em;max-width:100%;margin:3.6rem 0 .35rem;font-size:clamp(2.8rem,5vw,4.8rem);font-weight:800;line-height:.95}.track-artist{color:var(--muted);text-align:center;margin:0;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:1.5rem}.player-controls{justify-content:center;align-items:center;gap:1rem;margin:2rem 0;display:flex}.circle-button{cursor:pointer;background:#ffffff1f;border:0;border-radius:0;place-items:center;width:62px;height:62px;font-size:1.2rem;display:grid}.play-main{width:94px;height:94px;font-size:1.6rem}.volume-control{position:relative}.speaker-button{cursor:pointer;width:54px;height:54px;color:var(--pink);background:#ff00df1f;border:0;border-radius:0;place-items:center;display:grid}.speaker-icon{width:24px;height:24px;display:block}.volume-popover{z-index:30;background:#060b43f5;align-items:center;gap:.9rem;width:260px;padding:.85rem 1rem;display:flex;position:absolute;top:50%;right:calc(100% + 12px);transform:translateY(-50%);box-shadow:0 18px 48px #00000059}.volume-slider{appearance:none;background:0 0;flex:1;margin:0}.volume-slider::-webkit-slider-runnable-track{background:#ffffff40;height:4px}.volume-slider::-webkit-slider-thumb{appearance:none;background:var(--pink);cursor:pointer;border-radius:999px;width:14px;height:14px;margin-top:-5px}.volume-slider::-moz-range-track{background:#ffffff40;height:4px}.volume-slider::-moz-range-thumb{background:var(--pink);cursor:pointer;border:0;border-radius:999px;width:14px;height:14px}.volume-value{color:var(--text);text-align:right;min-width:42px;padding-right:.4rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.85rem}.progress-wrap{width:100%;max-width:520px;margin-bottom:2rem;position:relative}.progress-line{background:#ffffff8c;width:100%;height:2px;position:relative}.progress-fill{background:#ffffffe6;height:100%;position:absolute;inset:0 auto 0 0}.progress-dot{background:var(--pink);border-radius:999px;width:14px;height:14px;position:absolute;top:50%;transform:translate(-50%,-50%)}.progress-slider{opacity:0;cursor:pointer;width:100%;height:28px;position:absolute;inset:-14px 0 auto}.progress-slider:disabled{cursor:default}.track-times{color:var(--muted);justify-content:space-between;margin-top:.9rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;display:flex}.up-next-card{color:#110012;text-align:left;cursor:pointer;background:linear-gradient(#ff00df,#ff14ea);border-radius:16px;width:100%;max-width:520px;padding:.9rem 1.2rem;box-shadow:6px 6px #1238fff2}.up-next-card strong{color:#110012;margin-top:.2rem;font-size:1.55rem;font-weight:800;display:block}.up-next-label{font-size:1rem;display:block}.error-box{color:#ffb9b9;background:#ff505014;border:1px solid #ff505059;margin-bottom:1rem;padding:.9rem 1rem}.connect-button{background:var(--pink);color:#15001f;cursor:pointer;align-self:flex-start;margin-bottom:1rem;padding:.9rem 1.2rem;font-weight:800}.auth-landing{place-items:center;width:100%;min-height:100vh;padding:2rem;display:grid}.auth-card{text-align:center;background:#000254eb;border-radius:42px;flex-direction:column;justify-content:flex-start;align-items:center;width:min(560px,100vw - 3rem);min-height:840px;padding:4rem 3.25rem 3rem;display:flex;box-shadow:0 24px 90px #00000057,inset 0 1px #ffffff0a}.auth-turntable{aspect-ratio:1;place-items:center;width:100%;max-width:330px;margin-bottom:5rem;display:grid}.auth-turntable-image{object-fit:contain;filter:drop-shadow(0 0 28px #ff00df3d);width:100%;height:100%}.auth-title{color:var(--text);letter-spacing:.06em;text-transform:uppercase;margin:0 0 1.75rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:clamp(1.8rem,2.8vw,2.8rem);font-weight:800;line-height:1.02}.auth-copy{color:var(--text);opacity:.95;letter-spacing:.09em;text-transform:uppercase;margin:0 0 3rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.9rem;line-height:1.35}.auth-connect-button{color:#000;width:min(100%,316px);min-height:50px;box-shadow:none;letter-spacing:-.01em;background:#fff;border-radius:999px;justify-content:center;align-self:center;align-items:center;gap:.5rem;margin-top:1rem;margin-bottom:1.2rem;padding:.85rem 1.4rem;font-weight:600;display:inline-flex}.auth-connect-button:hover{background:#f3f3f3}.auth-secondary-button{color:var(--text);background:#ffffff1a}.auth-secondary-button:hover{background:#ffffff29}.auth-code-input{text-align:center;letter-spacing:.22em;text-transform:uppercase;width:min(100%,316px);margin:0 auto 1rem}.auth-apple-icon{width:14px;height:18px;display:block}.session-code-overlay{z-index:50;background:#0000007a;place-items:center;padding:2rem;display:grid;position:fixed;inset:0}.session-code-card{text-align:center;background:#000254f2;border-radius:24px;width:min(420px,100vw - 3rem);padding:2rem;box-shadow:0 24px 90px #00000057}.session-code-label,.session-code-copy{text-transform:uppercase;color:#7e81d1;margin:0}.session-code-label{letter-spacing:.18em;font-size:.9rem}.session-code-value{letter-spacing:.18em;color:var(--text);margin:1rem 0;font-size:clamp(2.1rem,7vw,3.4rem);font-weight:800}.session-code-copy{margin-bottom:1.5rem;font-size:.85rem;line-height:1.4}.auth-status{color:#f4f3f8c2;letter-spacing:.08em;text-transform:uppercase;min-height:1.25rem;margin:0;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.8rem}.screen-title{letter-spacing:.03em;margin:0;font-size:clamp(2.6rem,5vw,4.8rem);font-weight:800}.screen-heading-link{padding:0}.library-grid,.playlist-grid{grid-template-columns:repeat(3,minmax(0,1fr));align-items:start;gap:2rem;width:100%;display:grid}.library-tile,.playlist-card{text-align:left;cursor:pointer;padding:0}.playlist-card{flex-direction:column;justify-content:flex-start;align-self:start;width:100%;display:flex}.library-tile.disabled{cursor:default;opacity:.95}.library-tile{text-align:center;background:#050b45c7;border-radius:22px;flex-direction:column;justify-content:flex-start;align-items:center;min-height:560px;padding:3rem 1.75rem 2.25rem;transition:transform .22s,box-shadow .22s,background-color .22s;display:flex;transform:translateY(0)scale(1);box-shadow:0 28px 80px #0000003d}.library-tile:hover{background:#070e52eb;transform:translateY(-8px)scale(1.04);box-shadow:0 36px 96px #0000004d}.library-tile-image{aspect-ratio:1/1.22;background-position:50%;background-repeat:no-repeat;background-size:contain;border-radius:16px;width:100%;margin-bottom:1.9rem}.tile-art-1{background-image:url(/images/playlists.png)}.tile-art-2{background-image:url(/images/albums.png)}.tile-art-3{background-image:url(/images/artists.png)}.tile-art-4{background-image:url(/images/recents.png)}.tile-art-5{background-image:url(/images/songs.png)}.tile-art-6{background-image:url(/images/favourites.png)}.tile-art-7{background:radial-gradient(circle at 34% 34%,#ff00df80,#0000 24%),radial-gradient(circle at 72% 64%,#1238ff7a,#0000 30%),linear-gradient(140deg,#090e52fa,#000429fa)}.library-tile-label{letter-spacing:.04em;text-align:center;text-wrap:balance;text-transform:uppercase;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:clamp(1.2rem,1.6vw,1.9rem);font-weight:800;line-height:1.18}.content-scroll{padding-right:.25rem;overflow-y:auto}.content-section{margin-bottom:3rem}.collection-search-section{margin-bottom:2rem}.section-title{letter-spacing:.03em;margin:0 0 1.4rem;font-size:clamp(2rem,4vw,3.5rem);font-weight:800}.playlist-section-title{letter-spacing:.12em;color:var(--muted);font-size:clamp(1rem,1.6vw,1.35rem)}.playlist-detail-title{font-size:clamp(2rem,3.2vw,3rem)}.playlist-detail-title-row{align-items:center;gap:.9rem;display:flex}.collection-header-actions{flex-wrap:wrap;gap:.85rem;margin-top:1.25rem;display:flex}.collection-section-heading{align-items:center;gap:.8rem;margin-bottom:1.1rem;display:flex}.collection-section-heading .section-title{margin-bottom:0}.collection-section-actions{align-items:center;gap:.35rem;display:inline-flex}.collection-section-icon-button{color:#e9ebff;background:#7a81d138;border:0;border-radius:8px;justify-content:center;align-items:center;width:2.35rem;height:2.35rem;padding:0;transition:background .16s,color .16s,transform .16s;display:inline-flex}.collection-section-icon-button:hover{color:#fff;background:#6572fc52;transform:translateY(-1px)}.collection-section-icon-button svg{width:1.05rem;height:1.05rem}.playlist-detail-favourite{flex:none}.album-detail-artist{color:var(--muted);text-transform:uppercase;margin:0 0 1.2rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:1.1rem}.playlist-card-image{aspect-ratio:1;background:#ffffff08;border-radius:18px;margin-bottom:1rem;position:relative;overflow:hidden}.playlist-card-main{color:inherit;text-align:left;cursor:pointer;background:0 0;border:0;width:100%;padding:0;display:block}.playlist-card-copy{flex:1}.playlist-card-image img{object-fit:cover;width:100%;height:100%}.playlist-fallback{border-radius:inherit;background:linear-gradient(135deg,#ff00e533,#1238ff66);width:100%;height:100%}.playlist-card-body h3{text-transform:uppercase;margin:0 0 .35rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:1.1rem;font-weight:700}.playlist-card-body p{color:var(--muted);margin:0;font-size:.95rem;line-height:1.35}.media-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:2rem;display:grid}.media-card{border-radius:20px;position:relative}.media-card-main{width:100%;color:inherit;text-align:left;cursor:pointer;background:0 0;border:0;padding:0}.media-card-image-wrap{position:relative}.media-card-copy{margin-top:1rem}.media-card-image{aspect-ratio:1;background:#ffffff08;border-radius:18px;overflow:hidden}.media-card-image img{object-fit:cover;width:100%;height:100%}.media-card-fallback{border-radius:inherit;color:#ffffffe6;text-transform:uppercase;background:linear-gradient(135deg,#ff00e53d,#1238ff73);place-items:center;width:100%;height:100%;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:clamp(3rem,7vw,5rem);display:grid}.media-card-body h3{text-transform:uppercase;margin:0 0 .35rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:1.1rem;font-weight:700}.media-card-body p{color:var(--muted);margin:0;line-height:1.35}.media-card-eyebrow{color:var(--pink);letter-spacing:.1em;text-transform:uppercase;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.78rem;margin:0 0 .45rem!important}.media-card-play{position:absolute;bottom:12px;right:12px}.media-favourite-button{width:42px;height:42px;color:var(--text);cursor:pointer;background:#060b43d1;border:0;border-radius:0;position:absolute;top:12px;right:12px}.media-favourite-button.is-active{color:var(--pink);background:#ff00df1f}.heart-icon{width:22px;height:22px;margin:auto;display:block}.queue-row-button{width:100%;color:inherit;text-align:left;cursor:pointer;background:0 0;border:0;grid-template-columns:28px 52px 1fr auto;align-items:center;gap:1rem;min-width:0;display:grid}.queue-row-button:hover{background:#ffffff0a}.playlist-card-image{position:relative}.playlist-play-button{color:#110012;cursor:pointer;background:#ff00dfeb;border:0;border-radius:0;place-items:center;width:52px;height:52px;font-size:1.2rem;font-weight:800;display:grid;position:absolute;bottom:12px;right:12px;box-shadow:4px 4px #1238fff2}.playlist-favourite-button{color:var(--text);box-shadow:none;background:#060b43d1;top:12px;bottom:auto;right:12px}.playlist-detail-hero{grid-template-columns:280px 1fr;align-items:start;gap:2rem;margin-bottom:3rem;display:grid}.playlist-detail-art{aspect-ratio:1;background:#ffffff08;border-radius:20px;overflow:hidden}.playlist-detail-art img{object-fit:cover;width:100%;height:100%}.playlist-detail-description{color:var(--muted);max-width:48ch;line-height:1.5}.playlist-detail-actions{align-items:center;gap:1rem;margin-top:1.25rem;display:flex}.action-button{color:var(--text);cursor:pointer;text-transform:uppercase;background:#ffffff1f;border:0;padding:.9rem 1.2rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.action-button.primary{background:var(--pink);color:#15001f;border-color:var(--pink)}.action-button.is-active{color:var(--pink);background:#ff00df1f}.playlist-detail-action-favourite{place-items:center;width:52px;height:52px;padding:0;display:grid}.track-list{flex-direction:column;gap:.4rem;display:flex}.track-row{grid-template-columns:1fr auto;align-items:center;gap:.75rem;display:grid}.track-row-main{width:100%;color:inherit;text-align:left;cursor:pointer;background:0 0;border:0;grid-template-columns:40px 56px 1fr auto;align-items:center;gap:1rem;padding:.8rem .75rem;display:grid}.track-row-main:hover{background:#ffffff0a}.track-row-index,.track-row-duration{color:var(--muted);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.track-row-art{background:#ffffff08;border-radius:12px;width:56px;height:56px;overflow:hidden}.track-row-art img{object-fit:cover;width:100%;height:100%}.track-row-art-fallback{border-radius:inherit;background:linear-gradient(135deg,#ff00e533,#1238ff66);width:100%;height:100%}.track-row-meta{min-width:0}.track-row-meta strong{text-transform:uppercase;white-space:nowrap;text-overflow:ellipsis;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;display:block;overflow:hidden}.track-row-meta p{color:var(--muted);margin:.25rem 0 0}.track-row-add{color:#fff;cursor:pointer;background:#ffffff1f;border:0;border-radius:0;width:44px;height:44px;font-size:1.4rem}.track-row-actions{align-items:center;gap:.5rem;display:flex}.track-row-add.is-added{border-color:var(--pink);color:var(--pink);background:#ff00df14}.songs-toolbar{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.songs-search{width:min(100%,420px);color:var(--text);background:#ffffff0a;border:2px solid #fff3;padding:.95rem 1rem}.songs-track-row-main{grid-template-columns:56px 1fr auto}.browse-shell .songs-screen .songs-track-list{grid-template-columns:repeat(6,minmax(0,1fr));gap:2rem;display:grid}.browse-shell .songs-screen .songs-card-row{background:#050b45c7;flex-direction:column;align-items:stretch;gap:1rem;min-height:0;padding:1.25rem;display:flex;box-shadow:0 28px 80px #0000003d}.browse-shell .songs-screen .songs-track-row-main{flex-direction:column;align-items:stretch;gap:1rem;padding:0;display:flex}.browse-shell .songs-screen .track-row-art{aspect-ratio:1;width:100%;height:auto}.browse-shell .songs-screen .track-row-meta strong,.browse-shell .songs-screen .track-row-meta p{white-space:normal;text-overflow:clip;overflow:visible}.browse-shell .songs-screen .track-row-duration{margin-top:.25rem;display:block}.browse-shell .songs-screen .track-row-actions{justify-content:flex-end}@media (max-width:900px){.playlist-detail-hero{grid-template-columns:1fr}.track-row-main{grid-template-columns:28px 48px 1fr}.songs-track-row-main{grid-template-columns:48px 1fr}.track-row-duration{display:none}}.queue-overlay{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);z-index:100;background:#01053b94;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0}.queue-card{border-right:4px solid var(--pink);border-bottom:4px solid var(--pink);background:#060b43f5;border-radius:24px;flex-direction:column;width:min(700px,90vw);max-height:min(70vh,760px);display:flex;overflow:hidden;box-shadow:0 18px 48px #00000061}.queue-header{border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:flex-start;padding:2rem 2rem 1.5rem;display:flex}.queue-header-actions{align-items:center;gap:.75rem;display:flex}.queue-header h2{margin:0;font-size:clamp(2rem,4vw,3.8rem);font-weight:800}.queue-header p{color:var(--muted);letter-spacing:.05em;margin:.8rem 0 0;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.95rem}.queue-close{color:var(--muted);cursor:pointer;font-size:2rem;line-height:1}.queue-clear{color:var(--text);cursor:pointer;background:#ffffff1f;border:0;justify-content:center;align-items:center;width:42px;height:42px;padding:0;font-size:1rem;line-height:1;display:inline-flex}.queue-clear:disabled{opacity:.35;cursor:default}.queue-list{flex:1;min-height:0;padding:1.2rem 2rem 2rem;overflow-y:auto}.queue-row{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.75rem;min-width:0;padding:.9rem 0;display:grid}.queue-actions{align-items:center;gap:.35rem;display:flex}.queue-action{width:36px;height:36px;color:var(--text);cursor:pointer;background:#ffffff1f;border:0}.queue-action:disabled{opacity:.35;cursor:default}.queue-action-remove{color:#ff9aa3}.queue-index,.queue-duration{color:var(--muted);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.queue-art{background:#ffffff08;border-radius:12px;width:52px;height:52px;overflow:hidden}.queue-art img{object-fit:cover;width:100%;height:100%}.queue-art-fallback{border-radius:inherit;background:linear-gradient(135deg,#ff00e533,#1238ff66);width:100%;height:100%}.queue-meta{min-width:0;overflow:hidden}.queue-meta strong{text-transform:uppercase;white-space:nowrap;text-overflow:ellipsis;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:1.15rem;display:block;overflow:hidden}.queue-meta p{color:var(--muted);text-transform:uppercase;margin:.2rem 0 0;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.muted{color:var(--muted)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes main{25%{--5-x-position:15%;--5-y-position:15%;--6-x-position:85%;--6-y-position:80%}50%{--5-x-position:80%;--5-y-position:15%;--6-x-position:15%;--6-y-position:85%;--7-x-position:20%;--7-y-position:20%}}@media (max-width:1200px){body{overflow:auto}.app-shell{grid-template-columns:1fr;padding:1.5rem}.touch-square-shell{gap:0;padding:0}.left-panel{order:2}.right-panel{order:1}.turntable-wrap{width:min(88vw,640px)}.player-card{max-width:none}.player-stage-screen .turntable-wrap{width:min(72vw,860px)}.player-stage-screen{--player-turntable-size:min(72vw, 860px)}.player-progress-dock{width:min(50vw,420px)}.library-grid,.playlist-grid,.media-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.auth-card{min-height:760px}}@media (max-width:760px){.app-shell{grid-template-columns:1fr;padding:0 0 1.25rem}.left-panel{display:none}.right-panel{align-items:stretch;width:100%;padding-right:0}.browse-shell .right-panel{width:100%;padding-right:0}.screen,.player-screen{width:100%;height:auto;min-height:auto}.content-scroll{padding:0 1rem 11.5rem;overflow:visible}.screen-header{margin-bottom:1rem;padding:0 1rem}.content-section{margin-bottom:2rem}.player-card{max-width:none}.player-stage-screen{--player-turntable-size:min(92vw, 420px);justify-content:flex-start;height:auto;min-height:auto}.player-stage{flex-direction:column;justify-content:flex-start;align-items:stretch;gap:1.5rem;padding:0 1rem;display:flex;overflow:visible}.player-stage-turntable{width:100%;height:auto;position:static;inset:auto}.player-stage-screen .turntable-wrap{width:min(100%,420px);margin:0 auto}.player-turntable-stack{gap:1.5rem;width:100%}.player-stage-screen .record{width:84%}.player-stage-screen .tonearm{width:45%;top:9%;right:6%;transform:rotate(-68deg)}.app-control-rail{z-index:15;background:linear-gradient(#00053e00 0%,#00053ef0 22%);grid-template-columns:repeat(4,minmax(0,1fr));justify-content:stretch;gap:.75rem;width:100%;margin-top:1.5rem;padding:1rem 1rem 0;display:grid;position:sticky;bottom:0;transform:none}.rail-item-previous{order:1}.rail-item-play{order:2}.rail-item-next{order:3}.rail-item-volume{order:4}.rail-item-now-playing{order:5}.rail-item-library{order:6}.rail-item-queue{order:7}.rail-item-logout{order:8}.rail-item-session-code,.player-rail-expander-slot{display:none}.app-control-rail-item{justify-content:center}.player-rail-button,.app-control-rail .speaker-button{width:52px;height:52px;margin:0 auto}.app-control-rail-label{display:none}.player-info-corner,.player-progress-dock{width:100%;max-width:none;position:static;transform:none}.player-info-corner{order:2;margin-top:0;padding:0 .25rem}.player-info-corner .track-title,.player-info-corner .track-artist{text-align:left}.player-info-corner .track-title{font-size:1.6rem;line-height:1.08}.player-info-corner .track-artist,.player-up-next-line{font-size:.95rem;line-height:1.25rem}.player-progress-dock{order:3;width:100%;margin-top:0}.player-artwork-frame,.progress-wrap,.up-next-card{max-width:none}.player-topbar,.screen-topbar,.songs-toolbar{flex-direction:column;align-items:flex-start}.songs-toolbar{z-index:4;background:var(--bg);padding-inline:1rem;padding-bottom:.75rem;position:sticky;top:0}.topbar-actions{justify-content:space-between;width:100%}.auth-landing{padding:1rem}.auth-card{border-radius:28px;width:min(100%,420px);min-height:auto;padding:2.5rem 1.5rem 2rem}.auth-turntable{max-width:250px;margin-bottom:3.5rem}.auth-title{font-size:2.2rem}.auth-copy{margin-bottom:2rem;font-size:.8rem}.browse-shell .songs-screen .songs-track-list{grid-template-columns:1fr;gap:.4rem}.browse-shell .songs-screen .songs-card-row{box-shadow:none;background:0 0;grid-template-columns:1fr auto;gap:.75rem;padding:0;display:grid}.browse-shell .songs-screen .songs-track-row-main{grid-template-columns:48px 1fr;align-items:center;gap:1rem;padding:.8rem .75rem;display:grid}.browse-shell .songs-screen .track-row-art{aspect-ratio:auto;width:48px;height:48px}.browse-shell .songs-screen .track-row-meta strong,.browse-shell .songs-screen .track-row-meta p{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.browse-shell .songs-screen .track-row-duration{margin-top:0;display:none}.browse-shell .songs-screen .track-row-actions{justify-content:flex-start}.screen-header .screen-topbar{margin-bottom:.65rem}.library-screen .screen-header{margin-bottom:1.5rem}.library-screen .screen-title{font-size:3rem;line-height:.95}.browse-shell .library-grid,.browse-shell .playlist-grid,.browse-shell .media-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.browse-shell .media-grid{grid-template-columns:1fr;gap:1.25rem}.playlist-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.media-grid{grid-template-columns:1fr;gap:1.25rem}.library-tile{border-radius:18px;min-height:0;padding:1.25rem .9rem 1rem}.library-tile-image{aspect-ratio:1/1.05;margin-bottom:1rem}.library-tile-label{font-size:1rem}.playlist-card-body h3,.media-card-body h3{white-space:normal;text-overflow:clip;font-size:1.05rem;line-height:1.2;overflow:visible}.playlist-card-body p,.media-card-body p{white-space:normal;font-size:.95rem;line-height:1.4}.track-title{font-size:2.2rem}.big-back,.screen-title,.section-title,.queue-header h2{font-size:2rem}.player-controls{gap:.75rem}.circle-button{width:56px;height:56px}.play-main{width:78px;height:78px}.queue-card{border-radius:20px;width:min(100vw - .5rem,560px);max-height:80vh}.queue-row{grid-template-columns:1fr;gap:.75rem}.queue-duration{display:none}.queue-row-button{grid-template-columns:24px 44px 1fr}.queue-actions{justify-content:flex-end}.playlist-detail-actions{flex-wrap:wrap}.action-button{text-align:center;flex:calc(50% - .5rem);min-width:0}.playlist-detail-action-favourite{flex:0 0 52px}}
