*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.sr-only{border-width:0}.visible{visibility:visible}.relative{position:relative}.inline-block{display:inline-block}.flex{display:flex}.hidden{display:none}.border{border-width:1px}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}*,:after,:before{margin:0;padding:0;box-sizing:border-box}:root{--bg-deep:#0a0a0a;--bg-surface:#141414;--bg-elevated:#1c1c1c;--bg-glass:hsla(0,0%,100%,.02);--bg-glass-hover:hsla(0,0%,100%,.04);--border:hsla(0,0%,100%,.06);--border-subtle:hsla(0,0%,100%,.04);--border-medium:hsla(0,0%,100%,.12);--text-primary:#f5f5f5;--text-secondary:hsla(0,0%,96%,.5);--text-tertiary:hsla(0,0%,96%,.25);--accent:#e8cfaa;--accent-dim:hsla(36,57%,79%,.12);--accent-glow:hsla(36,57%,79%,.06);--red:#c9544a;--green:#5a9e6f;--font-display:"Instrument Serif",Georgia,serif;--font-body:"DM Sans",-apple-system,sans-serif;--font-mono:"Geist Mono","SF Mono",monospace;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--ease-out:cubic-bezier(0.16,1,0.3,1);--ease-spring:cubic-bezier(0.34,1.56,0.64,1);--safe-bottom:env(safe-area-inset-bottom,0px)}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:var(--bg-deep);color:var(--text-primary);font-family:var(--font-body);min-height:100vh;min-height:100dvh;overflow-x:hidden;-webkit-tap-highlight-color:transparent;max-width:100vw}img{content-visibility:auto}.activity-card,.app,.main-content,.player-bar{max-width:100vw;box-sizing:border-box}.activity-track,.player-track-name{max-width:100%}.ambient-bg{position:fixed;inset:0;z-index:0;pointer-events:none;background:linear-gradient(180deg,var(--bg-deep) 0,#0d0d0f 100%)}.app{position:relative;z-index:2;display:grid;grid-template-columns:220px 1fr;grid-template-rows:1fr auto;height:100vh;height:100dvh}.sidebar{grid-row:1/3;background:var(--bg-surface);border-right:1px solid var(--border);padding:32px 24px;display:flex;flex-direction:column;gap:12px;overflow-y:auto}.logo{font-family:var(--font-display);font-size:1.1rem;letter-spacing:-.01em;color:var(--text-primary);margin-bottom:24px;padding:0;-webkit-user-select:none;-moz-user-select:none;user-select:none;font-weight:400;line-height:1.3;word-break:break-word}.sidebar-section{margin-top:12px}.nav-item{display:flex;align-items:center;gap:0;padding:12px 16px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:400;color:var(--text-secondary);cursor:pointer;transition:all .2s var(--ease-out);border:1px solid transparent;-webkit-user-select:none;-moz-user-select:none;user-select:none;letter-spacing:-.01em}.nav-item:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.nav-item.active{background:var(--bg-glass);color:var(--text-primary);border-color:var(--border)}.nav-item .badge{margin-left:auto;background:var(--accent-dim);color:var(--accent);font-family:var(--font-mono);font-size:.6rem;font-weight:500;padding:2px 7px;border-radius:20px}.sidebar-playlists{flex:1;display:flex;flex-direction:column;gap:2px;margin-top:4px}.playlist-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius-sm);font-size:.82rem;color:var(--text-secondary);cursor:pointer;transition:all .2s var(--ease-out)}.playlist-item:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.playlist-thumb{width:32px;height:32px;border-radius:6px;background:var(--bg-elevated);display:grid;place-items:center;flex-shrink:0}.sidebar-profile{margin-top:auto;padding-top:16px;border-top:1px solid var(--border-subtle);display:flex;align-items:center;gap:10px;padding-left:8px}.avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#7a6a9e);display:grid;place-items:center;font-family:var(--font-mono);font-size:.7rem;font-weight:500;color:var(--bg-deep);flex-shrink:0}.profile-name{font-size:.82rem;font-weight:500}.profile-handle{font-family:var(--font-mono);font-size:.65rem;color:var(--text-tertiary)}.main-content{overflow-y:auto;padding:32px 40px;scrollbar-width:thin;scrollbar-color:var(--border-medium) transparent}.main-content::-webkit-scrollbar{width:6px}.main-content::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:3px}.page-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:40px;gap:16px;flex-wrap:wrap}.page-title{font-family:var(--font-display);font-size:2.2rem;letter-spacing:-.02em;line-height:1.1;font-weight:400}.page-title em{color:var(--accent)}.page-subtitle{font-size:.875rem;color:var(--text-secondary);margin-top:10px;font-weight:400}.mobile-logo-title{display:none}.desktop-title{display:block}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:var(--radius-md);font-family:var(--font-body);font-size:.875rem;font-weight:500;border:1px solid var(--border);background:var(--bg-glass);color:var(--text-primary);cursor:pointer;transition:all .2s var(--ease-out);backdrop-filter:blur(4px);-webkit-tap-highlight-color:transparent}.btn:hover{background:var(--bg-glass-hover);border-color:hsla(0,0%,100%,.1)}.btn:active{transform:scale(.98)}.btn-primary{background:var(--accent);color:var(--bg-deep);border-color:var(--accent)}.btn-primary:hover{background:#f0daba;border-color:#f0daba}.btn svg{width:16px;height:16px}.section{margin-bottom:48px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.section-title{font-family:var(--font-display);font-size:1.5rem;letter-spacing:-.02em}.activity-feed{display:flex;flex-direction:column;gap:8px}.activity-card{display:grid;grid-template-columns:52px 1fr auto;align-items:center;gap:16px;padding:12px 16px;border-radius:var(--radius-md);background:transparent;border:1px solid var(--border);cursor:pointer;transition:all .2s var(--ease-out);position:relative;overflow:hidden}.activity-card:hover{border-color:hsla(0,0%,100%,.1);background:var(--bg-glass)}.activity-card.playing{border-color:hsla(36,57%,79%,.3);background:var(--accent-glow)}.activity-art{width:52px;height:52px;border-radius:var(--radius-sm);background:var(--bg-elevated);overflow:hidden;position:relative;z-index:1;flex-shrink:0}.activity-art .play-overlay{position:absolute;inset:0;display:grid;place-items:center;background:rgba(0,0,0,.6);opacity:0;transition:opacity .2s}.activity-card:hover .play-overlay{opacity:1}.play-overlay svg{width:20px;height:20px;color:#fff}.activity-info{position:relative;z-index:1;min-width:0}.activity-track{font-size:.9rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:6px}.activity-artist{font-size:.78rem;color:var(--text-secondary);margin-top:2px}.privacy-badge{display:inline-flex;align-items:center;flex-shrink:0}.privacy-badge svg{width:12px;height:12px;color:var(--text-tertiary)}.activity-shared{display:flex;align-items:center;gap:6px;margin-top:6px;font-size:.7rem;color:var(--text-tertiary)}.activity-meta{position:relative;z-index:1;display:flex;flex-direction:column;align-items:flex-end;gap:6px}.activity-time{font-family:var(--font-mono);font-size:.65rem;color:var(--text-tertiary)}.activity-duration{font-family:var(--font-mono);font-size:.68rem;color:var(--text-secondary)}.activity-actions{display:flex;gap:4px;opacity:0;transition:opacity .2s}.activity-card:hover .activity-actions{opacity:1}.icon-btn{width:32px;height:32px;display:grid;place-items:center;border-radius:50%;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent}.icon-btn:hover{background:var(--bg-glass);color:var(--text-primary)}.icon-btn svg{width:16px;height:16px}.icon-btn.liked svg{color:var(--red);fill:var(--red)}.playlists-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.playlist-card{background:var(--bg-glass);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:all .35s var(--ease-out)}.playlist-card:hover{border-color:var(--border-medium);transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.3)}.playlist-cover{aspect-ratio:1;background:var(--bg-elevated);display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;overflow:hidden;position:relative}.playlist-cover img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .4s var(--ease-out)}.playlist-card:hover .playlist-cover img{transform:scale(1.05)}.playlist-cover .play-btn-overlay{position:absolute;inset:0;display:grid;place-items:center;background:rgba(0,0,0,.4);opacity:0;transition:opacity .3s}.playlist-card:hover .play-btn-overlay{opacity:1}.play-btn-circle{width:48px;height:48px;border-radius:50%;background:var(--accent);display:grid;place-items:center;color:var(--bg-deep);transform:scale(.8);transition:transform .3s var(--ease-spring)}.playlist-card:hover .play-btn-circle{transform:scale(1)}.play-btn-circle svg{width:20px;height:20px;margin-left:2px}.playlist-card-info{padding:16px}.playlist-card-title{font-size:.88rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-card-meta{display:flex;align-items:center;gap:8px;margin-top:6px;font-size:.72rem;color:var(--text-tertiary)}.playlist-card-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--text-tertiary)}.modal-overlay{position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.8);backdrop-filter:blur(4px);display:grid;place-items:center;opacity:0;pointer-events:none;transition:opacity .2s}.modal-overlay.open{opacity:1;pointer-events:all}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;width:90%;max-width:440px;transform:translateY(20px) scale(.96);transition:transform .3s var(--ease-out);max-height:90vh;overflow-y:auto}.modal-overlay.open .modal{transform:translateY(0) scale(1)}.modal-title{font-family:var(--font-display);font-size:1.5rem;margin-bottom:20px;font-weight:400}.modal-desc{font-size:.875rem;color:var(--text-secondary);margin-bottom:24px}.share-track-preview{display:flex;align-items:center;gap:14px;padding:14px;background:var(--bg-glass);border:1px solid var(--border-subtle);border-radius:var(--radius-md);margin-bottom:24px}.share-link-row{display:flex;gap:8px;margin-bottom:20px}.share-link-input{flex:1;padding:11px 14px;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-mono);font-size:.75rem;outline:none;transition:border-color .2s}.share-link-input:focus{border-color:var(--accent)}.modal-actions{display:flex;gap:10px;justify-content:flex-end}.share-mode-tabs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:12px}.share-mode-tab{border:1px solid var(--border);background:var(--bg-glass);color:var(--text-secondary);border-radius:var(--radius-sm);padding:10px 8px;font-size:.78rem;font-family:var(--font-body);cursor:pointer;transition:all .2s var(--ease-out)}.share-mode-tab:hover{color:var(--text-primary);border-color:hsla(0,0%,100%,.1)}.share-mode-tab.active{color:var(--bg-deep);background:var(--accent);border-color:var(--accent);font-weight:600}.share-mode-card{border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:12px;background:var(--bg-glass)}.share-mode-card-title{font-size:.84rem;color:var(--text-primary);font-weight:500}.share-mode-card-desc{margin-top:4px;margin-bottom:10px;font-size:.72rem;color:var(--text-tertiary)}.legacy-share-details{margin-top:12px;border-top:1px dashed var(--border);padding-top:10px}.legacy-share-details summary{cursor:pointer;color:var(--text-secondary);font-size:.78rem}.legacy-share-copy{font-size:.72rem;color:var(--text-tertiary);margin:8px 0 10px}.player-bar{grid-column:2;background:var(--bg-surface);border-top:1px solid var(--border);padding:16px 32px;display:grid;grid-template-columns:260px 1fr 180px;align-items:center;gap:24px;position:relative;padding-bottom:calc(16px + var(--safe-bottom))}.player-track{display:flex;align-items:center;gap:12px}.player-art{width:44px;height:44px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0;position:relative}.player-art img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.art-placeholder{width:100%;height:100%;display:grid;place-items:center;background:var(--bg-elevated)}.player-art.spinning img{animation:spin 12s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.player-track-info{min-width:0}.player-track-name{font-size:.85rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-track-artist{font-size:.75rem;color:var(--text-secondary);margin-top:2px}.player-track-actions{display:flex;gap:4px;margin-top:4px}.player-controls{flex-direction:column}.controls-row,.player-controls{display:flex;align-items:center;gap:10px}.ctrl-btn{width:36px;height:36px;display:grid;place-items:center;border-radius:50%;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent}.ctrl-btn:hover{color:var(--text-primary)}.ctrl-btn svg{width:18px;height:18px}.ctrl-btn.active{color:var(--accent)}.play-btn-main{width:48px;height:48px;display:grid;place-items:center;border-radius:50%;border:none;background:var(--text-primary);color:var(--bg-deep);cursor:pointer;transition:all .2s var(--ease-out);-webkit-tap-highlight-color:transparent}.play-btn-main:hover{transform:scale(1.05)}.play-btn-main:active{transform:scale(.97)}.play-btn-main svg{width:20px;height:20px}.progress-row{display:flex;align-items:center;gap:10px;width:100%;max-width:600px}.time-label{font-family:var(--font-mono);font-size:.62rem;color:var(--text-tertiary);min-width:36px;text-align:center}.progress-bar{flex:1;height:4px;background:var(--bg-elevated);border-radius:2px;cursor:pointer;position:relative;transition:height .15s;touch-action:none}.progress-bar:hover{height:6px}.progress-fill{height:100%;border-radius:2px;background:var(--text-primary);position:relative}.progress-fill:after{content:"";position:absolute;right:-6px;top:50%;transform:translateY(-50%);width:12px;height:12px;border-radius:50%;background:var(--text-primary);opacity:0;transition:opacity .15s}.progress-bar:hover .progress-fill:after{opacity:1}.player-right{justify-content:flex-end;gap:12px}.player-right,.volume-row{display:flex;align-items:center}.volume-row{gap:10px}.volume-bar{width:120px;height:4px;background:var(--bg-elevated);border-radius:2px;cursor:pointer;touch-action:none}.volume-fill{height:100%;border-radius:2px;background:var(--text-primary);transition:width .1s}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius-lg);padding:32px;text-align:center;cursor:pointer;transition:all .2s;margin-bottom:32px}.upload-zone:hover{border-color:hsla(0,0%,100%,.12);background:var(--bg-glass)}.upload-zone.dragging{border-color:var(--accent);background:var(--accent-glow);transform:scale(1.02)}.upload-zone.error{border-color:var(--red);background:rgba(201,84,74,.05)}.upload-zone svg{width:32px;height:32px;color:var(--text-tertiary);margin-bottom:12px}.upload-zone p{font-size:.875rem;color:var(--text-secondary)}.upload-zone .hint{font-size:.75rem;color:var(--text-tertiary);margin-top:6px}.upload-progress{margin-bottom:20px;padding:16px;background:var(--bg-glass);border:1px solid var(--border);border-radius:var(--radius-md)}.upload-progress-bar{height:3px;background:var(--bg-elevated);border-radius:2px;overflow:hidden;margin-top:8px}.upload-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s}.privacy-toggle{margin-bottom:24px;padding:16px;background:var(--bg-glass);border:1px solid var(--border);border-radius:var(--radius-md)}.privacy-toggle-label{display:flex;align-items:center;gap:12px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.privacy-toggle-input{position:absolute;opacity:0;width:0;height:0}.privacy-toggle-slider{position:relative;width:44px;height:24px;background:var(--bg-elevated);border-radius:24px;transition:background .2s;flex-shrink:0}.privacy-toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:var(--text-tertiary);border-radius:50%;transition:all .2s}.privacy-toggle-input:checked+.privacy-toggle-slider{background:var(--accent-dim)}.privacy-toggle-input:checked+.privacy-toggle-slider:before{transform:translateX(20px);background:var(--accent)}.privacy-toggle-text{display:flex;align-items:center;gap:8px;font-size:.875rem;color:var(--text-secondary)}.privacy-toggle-text svg{width:16px;height:16px;flex-shrink:0}.privacy-toggle-input:checked~.privacy-toggle-text,.toast{color:var(--text-primary)}.toast{position:fixed;bottom:100px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:var(--radius-xl);padding:12px 24px;font-size:.82rem;z-index:200;opacity:0;transition:all .3s var(--ease-out);pointer-events:none;display:flex;align-items:center;gap:8px;backdrop-filter:blur(20px)}.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}.toast svg{width:16px;height:16px;color:var(--green)}.empty-state{text-align:center;padding:60px 20px;color:var(--text-tertiary)}.empty-state svg{width:48px;height:48px;margin-bottom:16px;opacity:.4}.stagger-in{opacity:0;transform:translateY(16px);animation:staggerIn .6s var(--ease-out) forwards}@keyframes staggerIn{to{opacity:1;transform:translateY(0)}}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:50;background:var(--bg-surface);border-top:1px solid var(--border);padding:8px 0 calc(8px + var(--safe-bottom))}.mobile-nav-items{display:flex;justify-content:space-around;align-items:center;max-width:100%}.mobile-nav-item{display:flex;align-items:center;justify-content:center;padding:10px 16px;color:var(--text-tertiary);cursor:pointer;transition:color .2s;-webkit-tap-highlight-color:transparent;min-width:60px}.mobile-nav-item.active{color:var(--accent)}.mobile-nav-item svg{width:24px;height:24px}.mobile-nav-item img{border-radius:50%}.share-page{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;position:relative;z-index:2}.share-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px;width:100%;max-width:400px;text-align:center}.share-art{width:160px;height:160px;border-radius:var(--radius-md);margin:0 auto 24px;overflow:hidden;background:var(--bg-elevated)}.share-art img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.share-title{font-family:var(--font-display);font-size:1.5rem;margin-bottom:6px;font-weight:400}.share-artist{font-size:.875rem;color:var(--text-secondary);margin-bottom:24px}.share-play-btn{width:56px;height:56px;border-radius:50%;background:var(--accent);border:none;display:grid;place-items:center;cursor:pointer;margin:0 auto 20px;transition:all .2s var(--ease-out);color:var(--bg-deep)}.share-play-btn:hover{transform:scale(1.05)}.share-play-btn:active{transform:scale(.97)}.share-play-btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.share-play-btn svg{width:24px;height:24px;margin-left:2px}.share-progress{width:100%;margin-bottom:20px}@media (max-width:900px){.app{grid-template-columns:1fr}.sidebar{display:none}.mobile-nav{display:block}.logo{font-size:.95rem}.mobile-logo-title{display:block}.desktop-title{display:none}.main-content{padding:16px;padding-bottom:calc(180px + var(--safe-bottom));overflow-x:hidden}.page-header{margin-bottom:24px}.page-title{font-size:1.5rem;line-height:1.2}.page-subtitle{font-size:.8rem;margin-top:6px}.section{margin-bottom:32px}.section-title{font-size:1.2rem}.playlists-grid{grid-template-columns:repeat(2,1fr);gap:12px}.player-bar{grid-column:1;position:fixed;left:0;right:0;bottom:calc(60px + var(--safe-bottom));z-index:40;grid-template-columns:1fr;padding:12px 16px;gap:8px}.player-track{display:flex;gap:10px;order:-1;min-width:0}.player-track-info{min-width:0;flex:1}.player-track-name{font-size:.8rem}.player-track-artist{font-size:.7rem}.player-art{width:40px;height:40px}.player-track-actions{display:none}.player-controls{gap:6px}.controls-row{gap:10px}.ctrl-btn{width:44px;height:44px}.ctrl-btn svg{width:18px;height:18px}.play-btn-main{width:48px;height:48px}.icon-btn{width:44px;height:44px}.icon-btn svg{width:18px;height:18px}.player-right,.visualizer-container{display:none}.activity-card{gap:10px;padding:12px}.activity-art{width:48px;height:48px}.activity-info{min-width:0;flex:1}.activity-track{font-size:.85rem}.activity-artist{font-size:.72rem}.activity-meta{gap:4px}.activity-duration{font-size:.65rem}.activity-card .activity-actions{opacity:1}.upload-zone{padding:24px 16px}.toast{bottom:calc(160px + var(--safe-bottom))}.progress-bar{height:6px}.progress-fill:after{opacity:1}.privacy-toggle{padding:12px;margin-bottom:16px}.privacy-toggle-text{font-size:.8rem}.modal{padding:24px;max-width:calc(100vw - 32px)}.modal-title{font-size:1.3rem}.share-link-input{font-size:.7rem}}@media (max-width:480px){.main-content{padding:12px;padding-bottom:calc(180px + var(--safe-bottom))}.page-title{font-size:1.3rem}.page-subtitle{font-size:.75rem}.section-title{font-size:1.1rem}.playlists-grid{grid-template-columns:repeat(2,1fr);gap:10px}.activity-card{padding:10px;gap:8px}.activity-track{font-size:.8rem}.activity-artist{font-size:.7rem}.upload-zone{padding:20px 12px}.privacy-toggle{padding:10px;font-size:.75rem}.btn{padding:8px 14px;font-size:.8rem}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;pointer-events:auto!important}.google-sign-in-btn{display:inline-flex;align-items:center;gap:10px;padding:10px 20px;border-radius:var(--radius-xl);font-family:var(--font-body);font-size:.82rem;font-weight:500;border:1px solid var(--border-medium);background:var(--bg-glass);color:var(--text-primary);cursor:pointer;transition:all .25s var(--ease-out);backdrop-filter:blur(20px);-webkit-tap-highlight-color:transparent}.google-sign-in-btn:hover{background:var(--bg-glass-hover);border-color:hsla(0,0%,100%,.15);transform:translateY(-1px)}.google-sign-in-btn img{width:18px;height:18px;border-radius:2px}.sign-out-btn{background:none;border:none;color:var(--text-tertiary);font-family:var(--font-mono);font-size:.65rem;cursor:pointer;padding:4px 0;transition:color .2s}.sign-out-btn:hover{color:var(--text-secondary)}.sign-in-prompt{text-align:center;padding:48px 20px;border:2px dashed var(--border-medium);border-radius:var(--radius-lg);margin-bottom:32px}.sign-in-prompt p{font-size:.85rem;color:var(--text-secondary);margin-bottom:16px}.sign-in-prompt .hint{font-size:.72rem;color:var(--text-tertiary);margin-top:12px}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.ctrl-btn:focus-visible,.icon-btn:focus-visible,.play-btn-main:focus-visible,button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.skip-link{position:absolute;top:-40px;left:0;background:var(--accent);color:var(--bg-deep);padding:8px 16px;z-index:1000;font-size:.875rem;font-family:var(--font-body);text-decoration:none;border-radius:0 0 var(--radius-sm) 0;transition:top .2s}.skip-link:focus{top:0}.search-bar{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--bg-glass);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:24px;transition:border-color .2s}.search-bar:focus-within{border-color:hsla(0,0%,100%,.12)}.search-bar svg{width:18px;height:18px;color:var(--text-tertiary);flex-shrink:0}.search-bar input{flex:1;background:none;border:none;color:var(--text-primary);font-family:var(--font-body);font-size:.875rem;outline:none}.search-bar input::-moz-placeholder{color:var(--text-tertiary)}.search-bar input::placeholder{color:var(--text-tertiary)}.search-clear{background:none;border:none;color:var(--text-tertiary);cursor:pointer;width:24px;height:24px;display:grid;place-items:center;border-radius:50%;transition:all .2s}.search-clear:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.search-clear svg{width:14px;height:14px}.activity-card.skeleton{pointer-events:none;border-color:transparent}.skeleton-art{width:52px;height:52px;border-radius:var(--radius-sm);background:var(--bg-elevated);animation:shimmer 1.5s ease-in-out infinite}.skeleton-info{display:flex;flex-direction:column;gap:8px;min-width:0}.skeleton-line{height:12px;border-radius:6px;background:var(--bg-elevated);animation:shimmer 1.5s ease-in-out infinite}.skeleton-line.short{height:10px}.skeleton-meta{display:flex;justify-content:flex-end}@keyframes shimmer{0%,to{opacity:.4}50%{opacity:.8}}.detail-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:40px;width:90%;max-width:480px;text-align:center;position:relative;max-height:90vh;overflow-y:auto;transform:translateY(20px) scale(.96);transition:transform .3s var(--ease-out)}.modal-overlay.open .detail-modal{transform:translateY(0) scale(1)}.detail-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--text-tertiary);cursor:pointer;width:36px;height:36px;display:grid;place-items:center;border-radius:50%;transition:all .2s;z-index:1}.detail-close:hover{background:var(--bg-glass);color:var(--text-primary)}.detail-close svg{width:20px;height:20px}.detail-art-wrapper{display:flex;flex-direction:column;align-items:center;margin-bottom:24px}.detail-art{width:280px;height:280px;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-elevated);margin-bottom:12px}.detail-art img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.change-cover-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:none;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-family:var(--font-body);font-size:.78rem;cursor:pointer;transition:all .2s}.change-cover-btn:hover{background:var(--bg-glass);color:var(--text-primary);border-color:hsla(0,0%,100%,.1)}.change-cover-btn:disabled{opacity:.5;cursor:not-allowed}.change-cover-btn svg{width:14px;height:14px}.detail-title{font-family:var(--font-display);font-size:1.8rem;font-weight:400;margin-bottom:6px;letter-spacing:-.02em}.detail-artist{font-size:.875rem;color:var(--text-secondary);margin-bottom:4px}.detail-duration{font-family:var(--font-mono);font-size:.72rem;color:var(--text-tertiary)}.detail-controls{display:flex;align-items:center;justify-content:center;gap:16px;margin:24px 0}.detail-progress{width:100%;max-width:320px;margin:0 auto 24px}.detail-time{display:flex;justify-content:space-between;margin-top:8px;font-family:var(--font-mono);font-size:.62rem;color:var(--text-tertiary)}.detail-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.detail-actions .btn{flex:1 1 170px;min-width:0;justify-content:center}.btn-danger{border-color:rgba(201,84,74,.3);color:var(--red)}.btn-danger:hover{background:rgba(201,84,74,.1);border-color:rgba(201,84,74,.5)}@media (max-width:900px){.detail-modal{padding:24px 20px}.detail-art{width:220px;height:220px}.detail-title{font-size:1.5rem}.search-bar{margin-bottom:16px}}@media (max-width:480px){.detail-art{width:180px;height:180px}.detail-title{font-size:1.3rem}.detail-controls{gap:12px}.search-bar input{font-size:.82rem}}.queue-overlay{position:fixed;inset:0;z-index:90;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity .25s var(--ease-out)}.queue-overlay.open{opacity:1;pointer-events:all}.queue-panel{position:absolute;right:0;top:0;bottom:0;width:380px;max-width:100vw;background:var(--bg-surface);border-left:1px solid var(--border);display:flex;flex-direction:column;transform:translateX(100%);transition:transform .3s var(--ease-out);overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.queue-overlay.open .queue-panel{transform:translateX(0)}.queue-header{display:flex;align-items:center;justify-content:space-between;padding:24px 20px 16px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg-surface);z-index:1}.queue-header h2{font-family:var(--font-display);font-size:1.4rem;font-weight:400;letter-spacing:-.02em}.queue-header-actions{display:flex;align-items:center;gap:8px}.queue-section{padding:16px 20px 8px}.queue-section-title{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);margin-bottom:10px;display:flex;align-items:center;gap:8px}.queue-count{display:inline-flex;align-items:center;justify-content:center;background:var(--accent-dim);color:var(--accent);font-family:var(--font-mono);font-size:.6rem;font-weight:500;padding:1px 7px;border-radius:20px;min-width:20px;height:18px}.queue-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);transition:all .15s var(--ease-out);cursor:default}.queue-item:hover{background:var(--bg-glass-hover)}.queue-item.now-playing{background:var(--accent-glow);border:1px solid hsla(36,57%,79%,.15)}.queue-item.draggable{cursor:grab}.queue-item.draggable:active{cursor:grabbing}.queue-item.dragging{opacity:.4;transform:scale(.98)}.queue-grip{width:20px;height:20px;display:grid;place-items:center;color:var(--text-tertiary);flex-shrink:0;cursor:grab;opacity:.4;transition:opacity .15s}.queue-grip svg{width:14px;height:14px}.queue-item:hover .queue-grip{opacity:.8}.queue-item-art{width:40px;height:40px;border-radius:6px;overflow:hidden;flex-shrink:0;position:relative;background:var(--bg-elevated)}.queue-item-art img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.queue-now-indicator{position:absolute;bottom:3px;left:50%;transform:translateX(-50%);display:flex;gap:2px;align-items:flex-end;height:10px}.queue-now-indicator:after,.queue-now-indicator:before{content:"";display:block;width:2px;border-radius:1px;background:var(--accent);animation:queueBars .8s ease-in-out infinite}.queue-now-indicator:before{height:6px;animation-delay:0s}.queue-now-indicator:after{height:10px;animation-delay:.2s}@keyframes queueBars{0%,to{transform:scaleY(.4)}50%{transform:scaleY(1)}}.queue-item-info{flex:1;min-width:0}.queue-item-title{font-size:.82rem;font-weight:500}.queue-item-artist,.queue-item-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-item-artist{font-size:.68rem;color:var(--text-secondary);margin-top:1px}.queue-item-duration{font-family:var(--font-mono);font-size:.62rem;color:var(--text-tertiary);flex-shrink:0}.queue-item-actions{display:flex;gap:2px;flex-shrink:0;opacity:0;transition:opacity .15s}.queue-item:hover .queue-item-actions{opacity:1}.queue-item-actions .icon-btn{width:28px;height:28px}.queue-item-actions .icon-btn svg{width:14px;height:14px}.queue-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-tertiary);text-align:center}.queue-empty svg{width:48px;height:48px;margin-bottom:16px;opacity:.3}.queue-empty p{font-size:.875rem}.queue-empty .hint{font-size:.75rem;margin-top:6px;opacity:.6}.queue-toggle{position:relative}.queue-badge{position:absolute;top:2px;right:2px;background:var(--accent);color:var(--bg-deep);font-family:var(--font-mono);font-size:.55rem;font-weight:600;min-width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0 3px;line-height:1}.queue-toggle.active{color:var(--accent)}.mobile-nav-item{position:relative}.queue-badge-mobile{position:absolute;top:4px;right:8px;background:var(--accent);color:var(--bg-deep);font-family:var(--font-mono);font-size:.5rem;font-weight:600;min-width:14px;height:14px;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0 2px;line-height:1}@media (max-width:900px){.queue-panel{width:100%;border-left:none}.queue-header{padding:16px 16px 12px}.queue-section{padding:12px 16px 6px}.queue-item{padding:8px 6px}.queue-item-actions{opacity:1}.queue-grip{display:none}.queue-item-art{width:36px;height:36px}}@media (max-width:480px){.queue-item-title{font-size:.78rem}.queue-item-artist{font-size:.65rem}}.auth-gate{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-deep);padding:24px}.auth-gate-card{text-align:center;max-width:360px;width:100%;padding:48px 32px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg,16px)}.auth-gate-logo{font-family:var(--font-display);font-size:1.2rem;color:var(--text-primary);margin-bottom:24px;letter-spacing:-.01em}.auth-gate-card .google-sign-in-btn{width:100%;justify-content:center}.auth-gate-card .btn{font-size:.85rem}.auth-gate-card svg:not(.google-sign-in-btn svg){width:48px;height:48px;color:var(--text-tertiary)}.admin-add-section{margin-bottom:24px}.admin-input-row{display:flex;gap:8px}.admin-email-input{flex:1;padding:10px 14px;background:var(--bg-glass);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;font-family:var(--font-body);outline:none;transition:border-color .2s}.admin-email-input:focus{border-color:var(--accent)}.admin-email-input::-moz-placeholder{color:var(--text-tertiary)}.admin-email-input::placeholder{color:var(--text-tertiary)}.admin-user-list{display:flex;flex-direction:column;gap:4px}.admin-user-card{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--bg-glass);border:1px solid var(--border);border-radius:var(--radius-md);transition:background .15s}.admin-user-card:hover{background:var(--bg-glass-hover)}.admin-user-info{display:flex;align-items:center;gap:10px;min-width:0;flex:1}.admin-user-email{font-size:.875rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-owner-badge{font-size:.65rem;padding:2px 8px;background:var(--accent-dim);color:var(--accent);border-radius:99px;font-weight:500;letter-spacing:.03em;text-transform:uppercase;flex-shrink:0}.admin-user-date{font-size:.75rem;color:var(--text-tertiary);font-family:var(--font-mono);flex-shrink:0}.admin-remove-btn{color:var(--text-tertiary)!important;flex-shrink:0}.admin-remove-btn:hover{color:var(--red)!important}@media (max-width:600px){.admin-user-date{display:none}.admin-user-info{gap:8px}}.track-tag{display:inline-flex;align-items:center;padding:2px 6px;border-radius:999px;font-size:.62rem;font-family:var(--font-mono);color:var(--accent);background:var(--accent-dim)}.versioning-panel{margin-bottom:16px;padding:12px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-glass)}.version-row{display:flex;align-items:center;gap:10px}.version-label{font-size:.78rem;color:var(--text-secondary);min-width:72px}.version-select{flex:1;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-primary);border-radius:var(--radius-sm);padding:8px 10px;font-size:.8rem}.analytics-error{margin-bottom:16px;padding:10px 12px;border-radius:var(--radius-md);border:1px solid rgba(201,84,74,.4);background:rgba(201,84,74,.08);color:#e8877f;font-size:.82rem}.analytics-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:20px}.analytics-card{border:1px solid var(--border);background:var(--bg-glass);border-radius:var(--radius-md);padding:14px}.analytics-k{font-size:.72rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em}.analytics-v{margin-top:8px;font-size:1.5rem;font-family:var(--font-display)}.analytics-table{display:flex;flex-direction:column;gap:6px}.analytics-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto auto;gap:10px;align-items:center;border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;background:var(--bg-glass)}.analytics-track{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.analytics-metric{font-family:var(--font-mono);font-size:.72rem;color:var(--text-secondary)}.share-mode-grid{display:grid;gap:10px;margin-bottom:12px}.share-mode-label{display:grid;gap:6px;font-size:.78rem;color:var(--text-secondary)}.share-links-list{display:grid;gap:8px}.share-secondary-action{margin-top:4px;background:none;border:none;color:var(--text-secondary);font-size:.74rem;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.share-secondary-action:hover{color:var(--text-primary)}.share-secondary-action:disabled{opacity:.5;cursor:not-allowed}@media (max-width:900px){.analytics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.analytics-row{grid-template-columns:minmax(0,1fr);gap:4px}.share-link-row{flex-direction:column;margin-bottom:12px}.share-link-row .btn{width:100%;justify-content:center}}