@import"https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Inter:wght@300;400;500&family=DM+Mono:wght@400;500&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--bg: #08080a;--bg1: #0d0d10;--bg2: #121215;--bg3: #18181c;--bg4: #1e1e24;--surface-0: var(--bg);--surface-1: var(--bg1);--surface-2: var(--bg2);--surface-3: var(--bg3);--fg: #dddbe8;--fg2: #d8d8d8;--fg3: #ffffff;--fg4: #5b5b5c;--text: var(--fg);--text-muted: var(--fg2);--text-subtle: var(--fg3);--accent: #a78bfa;--accent-hi: #7c5de8;--accent-dim: rgba(167, 139, 250, .1);--accent-border: rgba(167, 139, 250, .25);--success: #22c55e;--success-dim: rgba(34, 197, 94, .1);--orange: #f97316;--orange-dim: rgba(249, 115, 22, .1);--blue: #60a5fa;--blue-dim: rgba(96, 165, 250, .1);--pink: #f472b6;--pink-dim: rgba(244, 114, 182, .1);--err: #f87171;--err-dim: rgba(248, 113, 113, .08);--border: #3a3a3a;--border2: #28282f;--border3: rgba(221, 219, 232, .12);--font-display: "Bebas Neue", sans-serif;--font-body: "Geist", "Inter", sans-serif;--font-mono: "Fragment Mono", "DM Mono", monospace;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 24px;--sp-6: 32px;--sp-7: 48px;--r-sm: 2px;--r-md: 6px;--r-lg: 10px;--r-xl: 14px;--r-pill: 999px;--nav-width: 160px;--header-h: 52px;--ease: cubic-bezier(.16, 1, .3, 1);--t1: .1s;--t2: .2s;--t3: .35s}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%}body{min-height:100%;background:var(--bg);color:var(--fg);font-family:var(--font-body);font-size:14px;font-weight:400;line-height:1.5;-webkit-font-smoothing:antialiased}#root{min-height:100vh;display:grid;grid-template-rows:1fr;width:100%}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}a{color:inherit;text-decoration:none}input,select,textarea{font-family:inherit}.app{display:grid;grid-template-columns:var(--nav-width) 1fr;grid-template-rows:var(--header-h) 1fr;grid-template-areas:"header header" "nav    main";min-height:100vh;width:100%}.header{grid-area:header;display:flex;align-items:center;padding:0 var(--sp-6);height:var(--header-h);border-bottom:1px solid var(--border);background:#08080af2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);position:sticky;top:0;z-index:100}.header-brand{display:flex;align-items:center;gap:var(--sp-2);flex-shrink:0}.brand-mark{width:16px;height:16px;border-radius:50%;border:2px solid var(--accent);flex-shrink:0}.brand-name{font-family:var(--font-display);font-size:20px;letter-spacing:.04em;color:var(--fg);line-height:1}.brand-dot{color:var(--accent)}.connect-wallet{margin-left:auto;flex-shrink:0}.btn-connect{padding:5px 14px;font-size:11px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--border2);border-radius:var(--r-sm);color:var(--fg2);background:transparent;transition:color var(--t1),border-color var(--t1)}.btn-connect:hover{color:var(--accent);border-color:var(--accent-border)}.wallet-address{font-family:var(--font-mono);font-size:11px;color:var(--fg2);padding:5px 10px;border:1px solid var(--border);border-radius:var(--r-sm);max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wallet-label{margin:10px}.wallet-balance{padding:2px var(--sp-2);font-size:12px;font-weight:500;letter-spacing:.02em}.wallet-balance-currency{opacity:.7;margin-right:1px}.wallet-balance-unit{opacity:.5;font-size:10px;margin-left:2px;letter-spacing:.05em}.nav{grid-area:nav;display:flex;flex-direction:column;padding:var(--sp-4) 0;border-right:1px solid var(--border);background:var(--surface-0);position:sticky;top:var(--header-h);height:calc(100vh - var(--header-h));overflow-y:auto;scrollbar-width:none}.nav::-webkit-scrollbar{display:none}.nav-btn{display:flex;align-items:center;gap:var(--sp-2);padding:9px var(--sp-4);font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--fg3);border-left:2px solid transparent;white-space:nowrap;transition:color var(--t1),border-color var(--t1),background var(--t1)}.nav-btn:hover{color:var(--fg2);background:var(--surface-1)}.nav-btn.active{color:var(--fg);border-left-color:var(--accent);background:var(--surface-2)}.nav-section-label{padding:var(--sp-5) var(--sp-5) var(--sp-2);font-size:9px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--fg4)}.main{grid-area:main;padding:var(--sp-5) var(--sp-5) 120px;min-width:0}.btn-primary{display:inline-flex;align-items:center;gap:var(--sp-2);padding:10px var(--sp-5);font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--bg);background:var(--accent);border:none;border-radius:var(--r-sm);cursor:pointer;transition:opacity var(--t1),transform var(--t1)}.btn-primary:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:none;opacity:.95}.btn-primary:disabled{opacity:.25;cursor:not-allowed}.btn-ghost{display:inline-flex;align-items:center;gap:var(--sp-2);padding:6px 14px;font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--fg2);border:1px solid var(--border2);border-radius:var(--r-sm);transition:color var(--t1),border-color var(--t1),background var(--t1)}.btn-ghost:hover{color:var(--fg);border-color:var(--border3);background:var(--surface-1)}.btn-accent-ghost{display:inline-flex;align-items:center;gap:var(--sp-2);padding:5px 12px;font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);border:1px solid var(--accent-border);border-radius:var(--r-sm);background:transparent;transition:background var(--t1),border-color var(--t1)}.btn-accent-ghost:hover{background:var(--accent-dim);border-color:var(--accent)}.btn-accent-ghost:disabled{opacity:.3;cursor:not-allowed}.input-base{background:transparent;border:none;outline:none;font-size:14px;font-weight:400;color:var(--fg);width:100%}.input-base::placeholder{color:var(--fg3);font-weight:300}.input-base:disabled{opacity:.35;cursor:not-allowed}.input-underline{display:flex;align-items:center;gap:var(--sp-2);border-bottom:1px solid var(--border2);padding-bottom:4px;transition:border-color var(--t1)}.input-underline:focus-within{border-bottom-color:var(--accent)}.label-mono{font-size:9px;font-weight:500;text-transform:uppercase;letter-spacing:.14em;color:var(--fg3)}.upload-spinner{display:inline-block;width:14px;height:14px;border:1.5px solid var(--fg3);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.upload-error{font-size:12px;color:var(--err);border-left:2px solid var(--err);padding:var(--sp-2) var(--sp-3);margin:var(--sp-3) 0;background:var(--err-dim)}::-webkit-scrollbar{width:3px;height:3px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--fg4);border-radius:2px}.browse-view{display:flex;flex-direction:column;width:100%;min-width:0}.browse-toolbar{display:flex;align-items:center;gap:var(--sp-4);margin-bottom:var(--sp-2);padding-bottom:var(--sp-4);border-bottom:1px solid var(--border)}.browse-count{font-family:var(--font-mono);font-size:11px;color:var(--fg3);flex-shrink:0;margin-left:auto}.search-box{display:flex;align-items:center;gap:var(--sp-2);flex:1;max-width:320px;border-bottom:1px solid var(--border2);padding-bottom:4px;transition:border-color var(--t1)}.search-box:focus-within{border-bottom-color:var(--accent)}.search-icon{font-size:15px;color:var(--fg3);flex-shrink:0;line-height:1}.search-input{flex:1;background:transparent;border:none;outline:none;font-size:13px;font-weight:300;color:var(--fg);min-width:0}.search-input::placeholder{color:var(--fg3)}.search-clear{font-size:11px;color:var(--fg3);padding:2px;transition:color var(--t1)}.search-clear:hover{color:var(--fg)}.browse-filters{display:flex;flex-direction:column;gap:0;margin-bottom:var(--sp-5);border-bottom:1px solid var(--border)}.bf-group{display:flex;align-items:baseline;gap:var(--sp-4);padding:10px 0;border-top:1px solid var(--border)}.bf-label{font-size:9px;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:var(--fg3);flex-shrink:0;width:90px}.bf-pills{display:flex;flex-wrap:wrap;gap:6px}.bf-row{display:flex;flex-wrap:wrap;align-items:center;gap:6px}.bf-pill{padding:3px 10px;font-size:10px;font-weight:500;letter-spacing:.06em;text-transform:capitalize;color:var(--fg3);background:transparent;border:1px solid var(--border);border-radius:var(--r-sm);cursor:pointer;transition:color var(--t1),border-color var(--t1),background var(--t1);white-space:nowrap}.bf-pill:hover{color:var(--fg2);border-color:var(--border2)}.bf-pill--active{color:var(--accent);border-color:var(--accent-border);background:var(--accent-dim)}.bf-max-wrap{display:flex;align-items:center;gap:var(--sp-1);border-bottom:1px solid var(--border2);padding-bottom:2px;margin-left:var(--sp-1);transition:border-color var(--t1)}.bf-max-wrap:focus-within{border-bottom-color:var(--accent)}.bf-max-symbol{font-family:var(--font-mono);font-size:11px;color:var(--fg3)}.bf-max-input{background:transparent;border:none;outline:none;font-family:var(--font-mono);font-size:11px;color:var(--fg);width:64px;padding:2px 0}.bf-max-input::placeholder{color:var(--fg3)}.bf-max-input::-webkit-inner-spin-button,.bf-max-input::-webkit-outer-spin-button{-webkit-appearance:none}.bf-addr-wrap{display:flex;align-items:center;gap:var(--sp-2);flex:1;border-bottom:1px solid var(--border2);padding-bottom:2px;max-width:340px;transition:border-color var(--t1)}.bf-addr-wrap:focus-within{border-bottom-color:var(--accent)}.bf-addr-input{flex:1;background:transparent;border:none;outline:none;font-family:var(--font-mono);font-size:11px;color:var(--fg);padding:2px 0;min-width:0}.bf-addr-input::placeholder{color:var(--fg3);font-family:var(--font-body)}.bf-clear-all{align-self:flex-start;margin:var(--sp-2) 0 var(--sp-3);font-size:10px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--fg3);background:transparent;border:none;cursor:pointer;transition:color var(--t1)}.bf-clear-all:hover{color:var(--err)}.track-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--bg4);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;width:100%}.lib-list{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--r-sm);overflow:hidden;margin-top:var(--sp-3)}.lib-row{display:grid;grid-template-columns:36px 3px 1fr auto auto 28px;align-items:center;gap:var(--sp-3);padding:9px var(--sp-3) 9px var(--sp-2);border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--t1)}.lib-row:last-child{border-bottom:none}.lib-row:hover,.lib-row--playing{background:var(--surface-2)}.lib-row--playing .lib-row-title{color:var(--accent)}.lib-row--removing{opacity:0;transform:translate(-8px);transition:opacity .3s var(--ease),transform .3s var(--ease)}.lib-row-num{display:flex;align-items:center;justify-content:center;width:36px;flex-shrink:0}.lib-row-idx{font-family:var(--font-mono);font-size:11px;color:var(--fg4)}.lib-row-eq{display:flex;align-items:flex-end;gap:2px;height:13px}.lib-row-eq span{display:block;width:2px;border-radius:1px;background:var(--eq-color, var(--accent));animation:tgEq .6s ease-in-out infinite alternate}.lib-row-eq span:nth-child(1){height:5px;animation-delay:0s}.lib-row-eq span:nth-child(2){height:13px;animation-delay:.15s}.lib-row-eq span:nth-child(3){height:8px;animation-delay:.3s}.lib-row-swatch{width:3px;height:28px;border-radius:2px;flex-shrink:0;opacity:.7}.lib-row-info{display:flex;flex-direction:column;gap:2px;min-width:0}.lib-row-title{font-size:13px;font-weight:500;color:var(--fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em;transition:color var(--t1)}.lib-row-artist{font-size:11px;font-weight:300;color:var(--fg2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lib-row-genre{font-size:9px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;padding:2px 7px;border:1px solid;border-radius:var(--r-pill);white-space:nowrap;flex-shrink:0}.lib-row-owned{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--success);flex-shrink:0}.lib-row-remove{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:var(--r-sm);font-size:9px;color:var(--fg4);opacity:0;transition:color var(--t1),opacity var(--t1),background var(--t1)}.lib-row:hover .lib-row-remove{opacity:1}.lib-row-remove:hover{color:var(--err);background:var(--err-dim)}@media(max-width:600px){.track-grid{grid-template-columns:repeat(2,1fr)}}.tg-card{background:var(--surface-1);padding:12px 12px 10px;cursor:pointer;transition:background var(--t1),transform var(--t2) var(--ease);display:flex;flex-direction:column;gap:var(--sp-2);position:relative}.tg-card:hover{background:var(--surface-2);transform:translateY(-1px)}.tg-card--playing{background:var(--surface-2)}.tg-art{width:100%;aspect-ratio:1 / 1;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;flex-shrink:0}.tg-art-img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}.tg-art-initial{font-family:var(--font-display);font-size:64px;line-height:1;position:relative;z-index:1;letter-spacing:.02em}.tg-eq{position:absolute;bottom:8px;left:8px;display:flex;gap:2px;align-items:flex-end;height:14px;z-index:2}.tg-eq span{display:block;width:3px;border-radius:1px;background:var(--eq-color, var(--accent));animation:tgEq .6s ease-in-out infinite alternate}.tg-eq span:nth-child(1){height:6px;animation-delay:0s}.tg-eq span:nth-child(2){height:12px;animation-delay:.15s}.tg-eq span:nth-child(3){height:8px;animation-delay:.3s}@keyframes tgEq{to{height:3px}}.tg-body{display:flex;flex-direction:column;gap:3px;min-width:0}.tg-title{font-size:14px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3;letter-spacing:-.01em}.tg-card--playing .tg-title{color:var(--accent)}.tg-artist{font-size:12px;font-weight:400;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tg-meta{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-top:4px}.tg-genre{font-size:10px;font-weight:500;padding:2px 8px;border-radius:var(--r-pill);border:1px solid;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:90px;letter-spacing:.04em;text-transform:uppercase}.tg-price{font-family:var(--font-mono);font-size:11px;color:var(--fg2);white-space:nowrap;flex-shrink:0}.tg-price--free{color:var(--success);font-size:10px;letter-spacing:.06em;text-transform:uppercase}.tg-buy{display:none;position:absolute;bottom:10px;right:10px;padding:5px 12px;font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--bg);background:var(--accent);border:none;border-radius:var(--r-pill);cursor:pointer;transition:opacity var(--t1);white-space:nowrap}.tg-card:hover .tg-buy{display:block}.tg-buy:hover{opacity:.85}.tg-buy:disabled{opacity:.4;cursor:not-allowed}.tg-card--skeleton{pointer-events:none}.tg-skel{border-radius:var(--r-sm);background:var(--surface-3);animation:tgShimmer 1.6s ease-in-out infinite}@keyframes tgShimmer{0%,to{opacity:.4}50%{opacity:.8}}.tg-art.tg-skel{aspect-ratio:1 / 1;width:100%;border-radius:var(--r-md)}.tg-skel--title{height:12px;width:78%;margin-bottom:4px}.tg-skel--sub{height:10px;width:52%}.tg-skel--tag{height:18px;width:52px;border-radius:var(--r-pill)}.tg-skel--price{height:10px;width:36px}.track-table{width:100%;border-collapse:collapse}.track-table thead tr{border-bottom:1px solid var(--border)}.track-table th{padding:10px 12px;text-align:left;font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--fg3);white-space:nowrap}.tt-col-num{width:44px;text-align:center}.tt-col-album{width:180px}.tt-col-genre{width:90px}.tt-col-dur{width:60px}.tt-col-price{width:100px}.tt-col-buy{width:80px}.tt-row{border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--t1)}.tt-row:hover,.tt-row--playing{background:var(--surface-1)}.tt-row td{padding:11px 12px;vertical-align:middle}.tt-cell-num{text-align:center;width:44px;font-family:var(--font-mono);font-size:12px;color:var(--fg3);position:relative}.tt-num{transition:opacity var(--t1)}.tt-play-hint{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:9px;color:var(--fg2);opacity:0;transition:opacity var(--t1)}.tt-row:hover .tt-num{opacity:0}.tt-row:hover .tt-play-hint{opacity:1}.tt-eq{display:inline-flex;align-items:flex-end;gap:2px;height:13px}.tt-eq span{display:block;width:2px;border-radius:1px;background:var(--accent);animation:ttEq .7s ease-in-out infinite alternate;transform-origin:bottom}.tt-eq span:nth-child(1){height:35%;animation-delay:0s}.tt-eq span:nth-child(2){height:100%;animation-delay:.12s}.tt-eq span:nth-child(3){height:55%;animation-delay:.04s}@keyframes ttEq{0%{transform:scaleY(.15)}to{transform:scaleY(1)}}.tt-row-title-wrap{display:flex;align-items:center;gap:14px}.tt-art{width:40px;height:40px;border-radius:var(--r-sm);background:var(--surface-3);flex-shrink:0;overflow:hidden;display:flex;align-items:center;justify-content:center}.tt-art-img{width:100%;height:100%;object-fit:cover;display:block}.tt-art-initials{font-family:var(--font-display);font-size:18px;color:hsl(var(--hue, 120),40%,55%);line-height:1;-webkit-user-select:none;user-select:none;letter-spacing:.02em}.tt-title{font-size:13px;font-weight:500;color:var(--fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:260px;letter-spacing:-.01em}.tt-row--playing .tt-title{color:var(--accent)}.tt-artist{font-size:11px;font-weight:300;color:var(--fg2);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tt-album{font-size:12px;font-weight:300;color:var(--fg2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;max-width:160px}.tt-genre{font-size:10px;font-weight:500;color:var(--fg3);text-transform:uppercase;letter-spacing:.08em}.tt-dur{font-family:var(--font-mono);font-size:11px;color:var(--fg3)}.tt-price{font-family:var(--font-mono);font-size:11px;color:var(--fg2);white-space:nowrap}.tt-price--free{font-family:var(--font-mono);font-size:10px;color:var(--fg3)}.tt-buy-btn{padding:5px 12px;font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:transparent;border:1px solid var(--accent-border);border-radius:var(--r-sm);transition:background var(--t1),border-color var(--t1)}.tt-buy-btn:hover{background:var(--accent-dim);border-color:var(--accent)}.tt-row--skeleton{pointer-events:none;animation:skelPulse 2s ease-in-out infinite}@keyframes skelPulse{0%,to{opacity:.3}50%{opacity:.7}}.tt-skel{background:var(--surface-3);border-radius:var(--r-sm);height:10px}.tt-skel--sm{width:28px}.tt-skel--md{width:90px;height:11px}.tt-skel--art{width:40px;height:40px;border-radius:var(--r-sm);flex-shrink:0}.chain-loading{display:flex;align-items:center;gap:var(--sp-3);color:var(--fg2);font-size:12px;padding:60px 0;justify-content:center}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-3);padding:100px 0;color:var(--fg3);text-align:center}.empty-icon{font-size:28px;opacity:.2;margin-bottom:var(--sp-1)}.empty-state p{font-size:13px;font-weight:300}.end-of-list{display:flex;align-items:center;gap:var(--sp-4);padding:36px 0 var(--sp-2);color:var(--fg3);font-size:10px;letter-spacing:.1em;text-transform:uppercase}.end-of-list:before,.end-of-list:after{content:"";flex:1;height:1px;background:var(--border)}.player-bar{position:fixed;bottom:0;left:var(--nav-width);right:0;height:72px;background:#08080af5;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border);display:flex;align-items:center;gap:var(--sp-5);padding:0 var(--sp-6);z-index:90}.player-track{display:flex;align-items:center;gap:var(--sp-3);flex:1;min-width:0}.player-art{width:40px;height:40px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:18px;background:hsl(var(--hue, 200),40%,18%);color:hsl(var(--hue, 200),60%,60%);flex-shrink:0;overflow:hidden;position:relative}.player-art-img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}.player-art-initials{position:relative;z-index:1}.player-title{font-size:13px;font-weight:500;color:var(--fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-artist{font-size:11px;font-weight:300;color:var(--fg2);margin-top:2px}.player-controls{display:flex;align-items:center;gap:var(--sp-3);flex-shrink:0}.player-error{font-size:11px;color:var(--err)}.btn-play-large{padding:8px 20px;font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--fg);background:var(--accent-hi);border:none;border-radius:var(--r-sm);cursor:pointer;transition:opacity var(--t1);white-space:nowrap}.btn-play-large:hover:not(:disabled){opacity:.88}.btn-play-large:disabled{opacity:.35;cursor:not-allowed}.btn-play-large.active{background:var(--accent);color:var(--bg)}.player-meta{display:flex;align-items:center;gap:var(--sp-4);flex-shrink:0}.player-genre{font-size:10px;color:var(--fg3);text-transform:uppercase;letter-spacing:.08em}.player-album{font-size:11px;font-weight:300;color:var(--fg3)}.player-duration{font-family:var(--font-mono);font-size:11px;color:var(--fg3)}.upload-view{display:flex;justify-content:center;align-items:flex-start;padding-top:var(--sp-6)}.studio-wrap{width:100%;max-width:520px;display:flex;flex-direction:column;gap:var(--sp-6)}.studio-header{display:flex;flex-direction:column;gap:var(--sp-2)}.studio-title{font-family:var(--font-display);font-size:52px;letter-spacing:.02em;line-height:1}.studio-sub{font-size:13px;font-weight:300;color:var(--fg2)}.studio-badge-row{display:flex;flex-wrap:wrap;gap:6px}.studio-badge{display:inline-flex;align-items:center;gap:6px;padding:4px var(--sp-2);border:1px solid var(--border);border-radius:var(--r-sm)}.studio-badge-key{font-size:9px;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:var(--fg3)}.studio-badge-val{font-family:var(--font-mono);font-size:11px;color:var(--fg2)}.studio-drop{border:1px solid var(--border2);border-radius:var(--r-sm);background:var(--surface-1);min-height:120px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color var(--t2) var(--ease),background var(--t2);position:relative;overflow:hidden}.studio-drop:not(.has-file):hover{background:var(--surface-2)}.studio-drop.is-dragging{border-color:var(--accent);background:var(--accent-dim)}.studio-drop.has-file{min-height:64px;cursor:default}.studio-drop-state{display:flex;flex-direction:column;align-items:center;gap:var(--sp-2);padding:var(--sp-5);text-align:center;width:100%}.studio-drop-state.studio-drop-filled{flex-direction:row;text-align:left;gap:var(--sp-3);padding:14px 18px}.studio-drop-arrow{font-size:22px;color:var(--fg3);line-height:1;transition:transform var(--t2) var(--ease),color var(--t2)}.studio-drop.is-dragging .studio-drop-arrow{transform:translateY(4px);color:var(--accent)}.studio-drop-label{font-size:13px;font-weight:400;color:var(--fg2)}.studio-drop-hint{font-family:var(--font-mono);font-size:10px;color:var(--fg3)}.studio-drop-browse{margin-top:6px;padding:5px 14px;font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--fg2);border:1px solid var(--border2);border-radius:var(--r-sm);background:transparent;transition:color var(--t1),border-color var(--t1)}.studio-drop-browse:hover{color:var(--accent);border-color:var(--accent-border)}.studio-drop-note{font-size:18px;color:var(--accent);flex-shrink:0;line-height:1}.studio-drop-info{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0}.studio-drop-filename{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.studio-drop-meta{font-family:var(--font-mono);font-size:11px;color:var(--fg3)}.studio-drop-clear{font-size:11px;color:var(--fg3);padding:3px 6px;border-radius:var(--r-sm);flex-shrink:0;transition:color var(--t1)}.studio-drop-clear:hover{color:var(--err)}.studio-form{display:flex;flex-direction:column;gap:0}.studio-fields{display:grid;grid-template-columns:1fr 1fr;gap:0 var(--sp-5)}@media(max-width:480px){.studio-fields{grid-template-columns:1fr}}.studio-field{display:flex;flex-direction:column;padding:var(--sp-4) 0;border-bottom:1px solid var(--border);gap:6px}.studio-label{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:var(--fg3);display:flex;align-items:center;gap:4px}.studio-required{color:var(--accent)}.studio-label-dim{font-weight:400;text-transform:none;letter-spacing:0;color:var(--fg3);font-size:10px}.studio-input{background:transparent;border:none;outline:none;font-size:14px;font-weight:400;color:var(--fg);padding:0;width:100%}.studio-input::placeholder{color:var(--fg3);font-weight:300}.studio-input:disabled{opacity:.35;cursor:not-allowed}.studio-actions{display:flex;flex-direction:column;gap:var(--sp-3);padding-top:var(--sp-5)}.studio-submit{width:100%;padding:14px;font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--bg);background:var(--accent);border:none;border-radius:var(--r-sm);cursor:pointer;transition:opacity var(--t1)}.studio-submit:hover:not(:disabled){opacity:.88}.studio-submit:disabled{opacity:.25;cursor:not-allowed}.studio-hint{font-size:11px;font-weight:300;color:var(--fg3);text-align:center;line-height:1.7}.studio-hint strong{color:var(--fg2);font-weight:400}.studio-done{display:flex;flex-direction:column;align-items:flex-start;gap:var(--sp-3);padding:40px 0}.studio-done-glyph{font-family:var(--font-display);font-size:80px;color:var(--accent);line-height:1;letter-spacing:.02em}.studio-done-title{font-size:15px;font-weight:500}.studio-done-sub{font-size:13px;font-weight:300;color:var(--fg2)}.studio-cid-row{display:flex;align-items:center;gap:var(--sp-3);border:1px solid var(--border);border-radius:var(--r-sm);padding:var(--sp-2) var(--sp-3);width:100%}.studio-cid-label{font-size:9px;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:var(--fg3);flex-shrink:0}.studio-cid-value{font-family:var(--font-mono);font-size:11px;color:var(--fg2);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.studio-cid-copy{font-family:var(--font-mono);font-size:10px;color:var(--fg3);padding:2px var(--sp-2);border:1px solid var(--border);border-radius:var(--r-sm);flex-shrink:0;transition:color var(--t1),border-color var(--t1)}.studio-cid-copy:hover{color:var(--accent);border-color:var(--accent-border)}.studio-done-action{margin-top:var(--sp-1);padding:10px var(--sp-5);font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase}@media(max-width:680px){:root{--nav-width: 0px}.app{grid-template-columns:1fr;grid-template-areas:"header" "main"}.nav{display:none}.player-bar{left:0}.main{padding:var(--sp-4) var(--sp-4) 100px}.header{padding:0 var(--sp-4)}}.scroll-top-btn{grid-area:main;position:fixed;bottom:96px;right:32px;width:76px;height:76px;border-radius:50%;background:var(--surface-3);border:1px solid var(--border2);color:var(--fg);font-size:22px;line-height:36px;text-align:center;padding:0;display:block;cursor:pointer;z-index:200;transition:color var(--t1),border-color var(--t1),background var(--t1)}.scroll-top-btn:hover{color:var(--accent);border-color:var(--accent-border);background:var(--surface-2)}.studio-panel{display:flex;flex-direction:column;gap:0}.studio-section{display:flex;flex-direction:column;gap:0;border:1px solid var(--border);border-radius:var(--r-sm);margin-bottom:var(--sp-4);overflow:hidden}.studio-section-label{font-size:9px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--fg3);padding:10px var(--sp-4);border-bottom:1px solid var(--border);background:var(--surface-1)}.studio-field-row{display:flex;align-items:center;gap:var(--sp-4);padding:11px var(--sp-4);border-bottom:1px solid var(--border);transition:background var(--t1)}.studio-field-row:last-child{border-bottom:none}.studio-field-row:focus-within{background:var(--surface-2)}.studio-field-row .studio-label{width:100px;flex-shrink:0}.studio-field-row .studio-input{flex:1;font-size:13px}.track-row{display:grid;grid-template-columns:28px 1fr 72px 120px 24px;align-items:center;gap:var(--sp-3);padding:8px var(--sp-4);border-bottom:1px solid var(--border);transition:background var(--t1)}.track-row:focus-within{background:var(--surface-2)}.track-row-header{background:var(--surface-1);pointer-events:none}.track-row-header span{font-size:9px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--fg3)}.track-row-num{font-family:var(--font-mono);font-size:11px;color:var(--fg3);text-align:center;flex-shrink:0}.track-row-title{font-size:13px;min-width:0}.track-row-duration{font-family:var(--font-mono);font-size:12px;width:72px;text-align:right}.track-row-file{font-size:10px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--fg3);border:1px solid var(--border2);border-radius:var(--r-sm);padding:4px 10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color var(--t1),border-color var(--t1);cursor:pointer;text-align:left}.track-row-file:hover{color:var(--accent);border-color:var(--accent-border)}.track-row-file.has-file{color:var(--success);border-color:#22c55e40}.track-row-remove{font-size:11px;color:var(--fg3);padding:3px;border-radius:var(--r-sm);transition:color var(--t1);justify-self:center}.track-row-remove:hover{color:var(--err)}.studio-add-track{padding:10px var(--sp-4);font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--fg3);text-align:left;transition:color var(--t1),background var(--t1)}.studio-add-track:hover{color:var(--accent);background:var(--surface-1)}.upload-success{font-size:13px;color:var(--success);border-left:2px solid var(--success);padding:var(--sp-2) var(--sp-3);background:var(--success-dim)}.link-btn{color:var(--accent);font-size:inherit;text-decoration:underline;text-underline-offset:2px;cursor:pointer;background:none;border:none;padding:0;font-family:inherit}.link-btn:hover{opacity:.8}.tg-card--owned{opacity:.85}.tg-owned-badge{position:absolute;bottom:8px;right:8px;font-size:11px;color:var(--success);font-family:var(--font-mono)}.tg-price--owned{color:var(--success);font-size:10px;letter-spacing:.06em;text-transform:uppercase}.tg-buy-confirm{position:absolute;bottom:10px;right:10px;font-size:10px;font-family:var(--font-mono);color:var(--success);pointer-events:none}.tg-saved-toast{position:absolute;bottom:0;left:0;right:0;background:var(--success-dim);border-top:1px solid rgba(34,197,94,.25);color:var(--success);font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;text-align:center;padding:6px;animation:toastSlide .2s var(--ease) both;pointer-events:none}@keyframes toastSlide{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.lib-filters{display:flex;flex-wrap:wrap;align-items:center;gap:6px;padding:10px 16px 12px;border-bottom:1px solid var(--border)}.lib-search-wrap{position:relative;display:flex;align-items:center;flex:0 0 auto}.lib-search-icon{position:absolute;left:8px;font-size:15px;color:var(--fg3);pointer-events:none}.lib-search{background:var(--bg2);border:1px solid var(--border);border-radius:20px;padding:4px 28px 4px 26px;font-size:12px;color:var(--fg1);outline:none;width:160px;transition:border-color .15s}.lib-search:focus{border-color:var(--fg3)}.lib-search-clear{position:absolute;right:8px;background:none;border:none;color:var(--fg3);cursor:pointer;font-size:10px;padding:0}.lib-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--fg3);font-size:11px;font-family:var(--font-mono, monospace);cursor:pointer;transition:all .15s;white-space:nowrap}.lib-pill:hover{border-color:var(--fg3);color:var(--fg1)}.lib-pill--active{color:var(--fg1)}.lib-pill--playing{border-color:#60a5fa44;color:#60a5fa}.lib-pill--playing.lib-pill--active{background:#60a5fa20;border-color:#60a5fa}.lib-pill--artist-active{background:var(--bg3, #2a2a2a);border-color:var(--fg2);color:var(--fg1)}.lib-pill--clear{border-color:transparent;color:var(--fg3);text-decoration:underline;padding-left:4px;padding-right:4px}.lib-pill--clear:hover{color:var(--fg1)}.player-bar{position:fixed;bottom:0;left:var(--nav-width);right:0;height:76px;background:#08080af7;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid var(--border);display:grid;grid-template-columns:1fr 2fr 1fr;align-items:center;gap:var(--sp-4);padding:0 var(--sp-6);z-index:90}.player-track{display:flex;align-items:center;gap:var(--sp-3);min-width:0}.player-art{width:42px;height:42px;border-radius:var(--r-sm);flex-shrink:0;background:hsl(var(--hue, 260),30%,16%);display:flex;align-items:center;justify-content:center;overflow:hidden}.player-art-initials{font-family:var(--font-display);font-size:20px;color:hsl(var(--hue, 260),60%,65%);line-height:1;letter-spacing:.02em}.player-track-info{min-width:0;display:flex;flex-direction:column;gap:2px}.player-title{font-size:13px;font-weight:500;color:var(--fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em}.player-artist{font-size:11px;font-weight:300;color:var(--fg2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-center{display:flex;flex-direction:column;align-items:center;gap:6px}.player-controls{display:flex;align-items:center;gap:var(--sp-3)}.player-btn{background:none;border:none;cursor:pointer;color:var(--fg3);font-size:13px;padding:4px 6px;border-radius:var(--r-sm);transition:color var(--t1);display:flex;align-items:center;justify-content:center;line-height:1}.player-btn:hover:not(:disabled){color:var(--fg)}.player-btn:disabled{opacity:.2;cursor:not-allowed}.player-btn--play{width:34px;height:34px;border-radius:50%;background:var(--accent-hi);color:var(--bg);font-size:12px;transition:opacity var(--t1),transform var(--t1)}.player-btn--play:hover:not(:disabled){opacity:.85;transform:scale(1.05)}.player-btn--play:disabled{opacity:.35;cursor:not-allowed}.player-btn--skip{font-size:14px}.player-progress-row{display:flex;align-items:center;gap:var(--sp-2);width:100%;max-width:420px}.player-time{font-family:var(--font-mono);font-size:10px;color:var(--fg3);flex-shrink:0;min-width:28px;text-align:center}.player-progress{flex:1;height:18px;display:flex;align-items:center;cursor:pointer;position:relative}.player-progress-track{width:100%;height:2px;background:var(--border);border-radius:1px;position:relative}.player-progress-fill{position:absolute;left:0;top:0;height:100%;background:var(--accent);border-radius:1px;transition:width .1s linear;pointer-events:none}.player-progress-thumb{position:absolute;top:50%;transform:translate(-50%,-50%);width:10px;height:10px;border-radius:50%;background:var(--fg);opacity:0;transition:opacity var(--t1);pointer-events:none}.player-progress:hover .player-progress-thumb{opacity:1}.player-error{font-size:10px;color:var(--err);font-family:var(--font-mono)}.player-meta{display:flex;align-items:center;justify-content:flex-end;gap:var(--sp-3);flex-shrink:0}.player-genre{font-size:10px;color:var(--fg3);text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-mono)}.player-price{font-family:var(--font-mono);font-size:11px;color:var(--fg2)}.player-queue-pos{font-family:var(--font-mono);font-size:10px;color:var(--fg3)}@media(max-width:680px){.player-bar{left:0;grid-template-columns:1fr auto;grid-template-rows:auto auto;height:auto;padding:var(--sp-3) var(--sp-4);gap:var(--sp-2)}.player-center{grid-column:1 / -1;order:-1}.player-meta{display:none}}
