*{box-sizing:border-box}body,html,#root{margin:0;padding:0;height:100%;background:#0d0d10;color:#eaeaea;font-family:-apple-system,BlinkMacSystemFont,sans-serif;overflow-x:hidden}.app{display:grid;grid-template-rows:auto 1fr auto;grid-template-columns:240px 1fr;height:100vh;height:100dvh}.app>header{grid-column:1 / -1}.app>.sidebar{grid-row:2;grid-column:1}.app>main{grid-row:2;grid-column:2}.app>footer{grid-column:1 / -1}header{padding:16px 24px;border-bottom:1px solid #1f1f24;display:flex;align-items:center;gap:24px}header h1{margin:0;font-size:20px;font-weight:700;background:linear-gradient(90deg,#f36,#f93);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.searchbar{display:flex;gap:8px;flex:1;max-width:600px}.searchbar input{flex:1;padding:10px 14px;border:1px solid #2a2a30;background:#16161a;color:#eaeaea;border-radius:999px;outline:none;font-size:16px}.searchbar input:focus{border-color:#f36}.searchbar button{padding:10px 20px;border:none;background:#f36;color:#fff;border-radius:999px;cursor:pointer;font-weight:600}.searchbar button:disabled{opacity:.5}main{overflow-y:auto;padding:16px 24px 32px}.sidebar{background:#0a0a0d;border-right:1px solid #1f1f24;padding:16px 8px;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.sidebar nav{display:flex;flex-direction:column;gap:2px;margin-bottom:16px}.sidebar nav button{background:none;border:none;color:#ccc;text-align:left;padding:10px 14px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500}.sidebar nav button:hover{background:#16161a;color:#fff}.sidebar nav button.active{background:#2a1a20;color:#f36}.playlists-head{display:flex;justify-content:space-between;align-items:center;padding:0 14px 4px;font-size:11px;font-weight:700;color:#666;letter-spacing:1px}.playlists-head .new-btn{background:none;border:none;color:#888;cursor:pointer;font-size:16px;width:24px;height:24px;border-radius:50%}.playlists-head .new-btn:hover{background:#1a1a1f;color:#f36}.playlists-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1px}.playlists-list li{display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:8px;cursor:pointer;font-size:13px;color:#bbb;position:relative}.playlists-list li:hover{background:#16161a;color:#fff}.playlists-list li.active{background:#2a1a20;color:#f36}.playlists-list .pl-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlists-list .pl-count{font-size:10px;color:#666;font-variant-numeric:tabular-nums}.playlists-list .pl-actions{display:none;gap:2px}.playlists-list li:hover .pl-actions{display:flex}.playlists-list li:hover .pl-count{display:none}.playlists-list .pl-actions button{background:none;border:none;color:#aaa;cursor:pointer;width:20px;height:20px;border-radius:4px;font-size:11px}.playlists-list .pl-actions button:hover{background:#2a2a30;color:#fff}.playlists-list input{background:#0d0d10;border:1px solid #ff3366;border-radius:4px;color:#fff;padding:4px 8px;font-size:16px;width:100%;outline:none}.playlists-list .pl-empty{color:#555;font-size:11px;padding:8px 14px;cursor:default}.playlists-list .pl-empty:hover{background:none;color:#555}.view{display:flex;flex-direction:column}.view-head{display:flex;align-items:center;gap:12px;padding:8px 0 16px;border-bottom:1px solid #1f1f24;margin-bottom:12px}.view-head h2{margin:0;font-size:22px;font-weight:700}.view-head .count{font-size:12px;color:#888;background:#1a1a1f;padding:2px 8px;border-radius:999px}.view-head .view-actions{margin-left:auto;display:flex;gap:8px}.view-head .primary-sm,.view-head .ghost-sm{padding:6px 14px;border-radius:999px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid transparent}.view-head .primary-sm{background:#f36;color:#fff;border-color:#f36}.view-head .primary-sm:hover{background:#e02b59}.view-head .ghost-sm{background:none;border-color:#2a2a30;color:#ccc}.view-head .ghost-sm:hover{background:#1a1a1f}.search-row{padding-bottom:16px}.add-wrap{position:relative;display:flex;align-items:center}.add-menu{position:absolute;top:100%;right:0;margin-top:6px;background:#1a1a1f;border:1px solid #2a2a30;border-radius:8px;min-width:220px;max-height:320px;overflow-y:auto;z-index:40;padding:4px;box-shadow:0 8px 24px #0006}.add-menu .item{width:100%;background:none;border:none;color:#ddd;text-align:left;padding:8px 10px;border-radius:6px;cursor:pointer;font-size:13px;display:flex;align-items:center;gap:10px}.add-menu .item:hover{background:#2a2a30;color:#fff}.add-menu .item .ic{width:16px;text-align:center;color:#888}.add-menu .sep{height:1px;background:#2a2a30;margin:4px 0}.add-menu .label{font-size:10px;color:#666;font-weight:700;letter-spacing:1px;padding:6px 10px 4px}.results .row-remove{background:none;border:none;color:#666;cursor:pointer;width:24px;height:24px;border-radius:50%;font-size:12px;opacity:0;transition:opacity .15s,background .15s,color .15s}.results li:hover .row-remove{opacity:1}.results .row-remove:hover{background:#2a1a20;color:#ff6b6b}.burger{background:none;border:none;color:#eaeaea;font-size:22px;width:40px;height:40px;border-radius:8px;cursor:pointer;display:none;align-items:center;justify-content:center}.burger:hover{background:#1a1a1f}.mobile-only,.sidebar-backdrop{display:none}} .error{color:#ff6b6b}.results{list-style:none;margin:0;padding:0}.results li{display:flex;align-items:center;gap:12px;padding:8px;border-radius:8px;cursor:pointer;transition:background .15s}.results li:hover{background:#1a1a1f}.results li.active{background:#2a1a20}.results img{width:64px;height:36px;object-fit:cover;border-radius:4px;background:#222}.results .meta{flex:1;min-width:0}.results .title{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.results .sub{font-size:12px;color:#888;margin-top:2px}.results .duration{font-size:12px;color:#888;font-variant-numeric:tabular-nums}.heart{background:none;border:none;color:#777;cursor:pointer;line-height:1;padding:0;display:flex;align-items:center;justify-content:center;transition:color .15s,transform .1s}.heart.sm{width:24px;height:24px;font-size:16px}.heart.md{width:32px;height:32px;font-size:20px}.heart:hover,.heart.liked{color:#f36}.heart.liked:hover{color:#e02b59}.heart:active{transform:scale(.85)}.results .row-heart{opacity:0;transition:opacity .15s,color .15s,transform .1s}.results li:hover .row-heart,.results .row-heart.liked{opacity:1}.results .add-queue{background:none;border:1px solid #333;color:#aaa;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:16px;line-height:1;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s,background .15s,color .15s}.results li:hover .add-queue{opacity:1}.results .add-queue:hover{background:#f36;color:#fff;border-color:#f36}.header-tools{margin-left:auto;display:flex;align-items:center;gap:8px}.hdr-btn{background:none;border:1px solid #2a2a30;color:#eaeaea;padding:8px 14px;border-radius:999px;cursor:pointer;font-size:13px;display:flex;align-items:center;gap:6px}.hdr-btn:hover{background:#1a1a1f}.hdr-btn.active{background:#2a1a20;border-color:#f36}.hdr-btn .badge{background:#f36;color:#fff;font-size:11px;font-weight:700;padding:2px 7px;border-radius:999px;min-width:20px;text-align:center}.user-chip{display:flex;align-items:center;gap:8px;padding:4px 4px 4px 8px;border:1px solid #2a2a30;border-radius:999px}.user-chip .avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#f36,#f93);color:#fff;font-weight:700;font-size:12px;display:flex;align-items:center;justify-content:center}.user-chip .uname{font-size:13px;font-weight:600}.user-chip .ghost-btn{border:none;padding:4px 10px;background:transparent;font-size:13px;color:#aaa}.user-chip .ghost-btn:hover{color:#ff6b6b;background:#1a1a1f}.login-view{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at top,#1a0d18,#0d0d10 60%);padding:24px}.login-card{background:#131318;border:1px solid #1f1f24;border-radius:16px;padding:32px;width:100%;max-width:380px}.login-logo{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:24px}.login-logo img{width:56px;height:56px;border-radius:14px}.login-logo h1{margin:0;font-size:22px;font-weight:800;background:linear-gradient(90deg,#f36,#f93);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.login-card .tabs{display:flex;gap:4px;background:#0d0d10;border-radius:999px;padding:4px;margin-bottom:20px}.login-card .tabs button{flex:1;background:none;border:none;color:#aaa;padding:8px 0;border-radius:999px;cursor:pointer;font-size:13px;font-weight:600}.login-card .tabs button.active{background:#f36;color:#fff}.login-card form{display:flex;flex-direction:column;gap:14px}.login-card label{display:flex;flex-direction:column;gap:6px;font-size:12px;color:#aaa;font-weight:500}.login-card input{padding:10px 14px;background:#0d0d10;border:1px solid #2a2a30;border-radius:8px;color:#eaeaea;font-size:16px;outline:none;transition:border-color .15s}.login-card input:focus{border-color:#f36}.login-card .form-error{background:#2a1a20;border:1px solid #ff3366;color:#ff6b8b;padding:8px 12px;border-radius:8px;font-size:13px}.login-card button.primary{background:#f36;color:#fff;border:none;padding:12px;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;margin-top:4px}.login-card button.primary:hover{background:#e02b59}.login-card button.primary:disabled{opacity:.5;cursor:not-allowed}.boot-screen{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;color:#888}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:70}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#131318;border:1px solid #1f1f24;border-radius:12px;z-index:80;width:min(520px,90vw);max-height:80vh;display:flex;flex-direction:column}.modal-head{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #1f1f24}.modal-head h2{margin:0;font-size:16px}.modal-head .ghost{background:none;border:none;color:#aaa;font-size:16px;cursor:pointer;width:28px;height:28px;border-radius:50%}.modal-head .ghost:hover{background:#2a2a30;color:#fff}.invites-actions{padding:16px 20px;border-bottom:1px solid #1f1f24}.invites-actions .primary{background:#f36;color:#fff;border:none;padding:10px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer}.invites-actions .primary:hover{background:#e02b59}.invites-actions .primary:disabled{opacity:.5}.invites-empty{padding:30px 20px;text-align:center;color:#777;font-size:13px}.invites-list{list-style:none;margin:0;padding:8px;overflow-y:auto;flex:1}.invites-list li{padding:10px 12px;border-radius:8px;display:flex;flex-direction:column;gap:4px;border:1px solid #1f1f24;margin-bottom:6px}.invites-list li.used{opacity:.55}.invites-list .code-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.invites-list code{font-family:SF Mono,Menlo,monospace;font-size:14px;font-weight:700;letter-spacing:.5px;color:#f93}.invites-list .invite-status{font-size:11px;color:#888}.invites-list .ghost-sm{background:none;border:1px solid #2a2a30;color:#aaa;padding:3px 10px;border-radius:6px;cursor:pointer;font-size:11px}.invites-list .ghost-sm:hover{background:#1a1a1f;color:#fff}.invites-list .ghost-sm.danger{color:#ff6b6b;align-self:flex-start;margin-top:4px}.invites-list .ghost-sm.danger:hover{background:#2a1a20}.queue-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:50}.queue-drawer{position:fixed;top:0;right:0;bottom:0;width:380px;max-width:90vw;background:#131318;border-left:1px solid #1f1f24;z-index:60;transform:translate(100%);transition:transform .22s ease;display:flex;flex-direction:column}.queue-drawer.open{transform:translate(0)}.queue-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #1f1f24}.queue-head h2{margin:0;font-size:15px;font-weight:700}.queue-actions{display:flex;gap:8px}.queue-actions .ghost{background:none;border:1px solid #2a2a30;color:#aaa;padding:4px 10px;border-radius:6px;cursor:pointer;font-size:12px}.queue-actions .ghost:hover{background:#1a1a1f;color:#fff}.queue-empty{padding:40px 20px;text-align:center;color:#777;font-size:13px;line-height:1.6}.queue-list{list-style:none;margin:0;padding:8px;overflow-y:auto;flex:1}.queue-list li{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;cursor:pointer;transition:background .15s,opacity .15s;border:1px solid transparent}.queue-list li:hover{background:#1a1a1f}.queue-list li.active{background:#2a1a20}.queue-list li.dragging{opacity:.4}.queue-list li.drop-over{border-color:#f36}.queue-list li.locked{cursor:default}.queue-list li.locked .grip{color:#f36;cursor:default}.queue-list .grip{color:#555;font-size:14px;cursor:grab;-webkit-user-select:none;user-select:none}.queue-list img{width:44px;height:26px;object-fit:cover;border-radius:3px}.queue-list .meta{flex:1;min-width:0}.queue-list .title{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-list .sub{font-size:10px;color:#888;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-list .duration{font-size:10px;color:#888;font-variant-numeric:tabular-nums}.queue-list .rm{background:none;border:none;color:#666;cursor:pointer;font-size:12px;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s,background .15s,color .15s}.queue-list li:hover .rm{opacity:1}.queue-list .rm:hover{background:#2a2a30;color:#ff6b6b}footer{border-top:1px solid #1f1f24;background:#16161a;overflow-x:hidden;min-width:0}.player{display:grid;grid-template-columns:280px 1fr;align-items:center;gap:16px;padding:12px 24px}.player .now{display:flex;align-items:center;gap:12px;min-width:0}.player .now img{width:48px;height:48px;object-fit:cover;border-radius:4px;flex-shrink:0}.player .track-meta{min-width:0}.player .title{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player .sub{font-size:11px;color:#888;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player .controls{display:flex;flex-direction:column;align-items:center;gap:6px;max-width:720px;margin:0 auto;width:100%}.player .buttons{display:flex;align-items:center;gap:16px}.player .buttons button{background:none;border:none;color:#eaeaea;cursor:pointer;font-size:18px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .15s,color .15s}@media (hover: hover){.player .buttons button:hover:not(:disabled){background:#2a2a30}.player .buttons .play:hover{background:#ddd}}.player .buttons button:disabled{color:#555;cursor:not-allowed}.player .buttons button:focus{outline:none}.player .buttons .play{background:#fff;color:#000;width:36px;height:36px;font-size:16px}.player .buttons .play,.player .buttons .play:focus,.player .buttons .play:active{background:#fff;color:#000}.player .seek{display:flex;align-items:center;gap:10px;width:100%}.player .seek .time{font-size:11px;color:#999;font-variant-numeric:tabular-nums;min-width:36px;text-align:center}.player .seek input[type=range]{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;background:#2a2a30;border-radius:2px;outline:none;cursor:pointer}.player .seek input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:#f36;cursor:pointer}.player .seek input[type=range]::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:#f36;cursor:pointer;border:none}@media (max-width: 768px){.mobile-only{display:flex}.app{grid-template-columns:1fr}.app>main{grid-row:auto;grid-column:auto}header{flex-wrap:wrap;padding:10px 12px;gap:10px}header h1{font-size:18px}.searchbar{order:3;width:100%;max-width:none;flex-basis:100%}.header-tools{margin-left:auto;gap:6px}.hdr-btn{padding:0;width:40px;height:40px;font-size:16px;justify-content:center;position:relative}.hdr-btn .lbl{display:none}.hdr-btn .badge{font-size:10px;position:absolute;top:-4px;right:-4px;padding:1px 5px;min-width:16px}.user-chip .uname{display:none}.user-chip{padding:2px 2px 2px 4px}.sidebar{position:fixed;top:0;left:0;bottom:0;width:260px;z-index:60;transform:translate(-100%);transition:transform .22s ease}.sidebar.open{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:50}.app>.sidebar{grid-row:auto;grid-column:auto}main{padding:12px 14px 24px}.results img{width:48px;height:28px}.results .title{font-size:13px}.results .sub{font-size:11px}.results .add-queue{width:36px;height:36px}.results .row-heart,.results .add-queue,.results .row-remove{opacity:1}.add-menu{position:fixed;top:auto;bottom:90px;left:12px;right:12px;margin-top:0;max-width:none}.view-head h2{font-size:18px}.view-head .view-actions{width:100%;margin-left:0}.player{display:flex;flex-direction:column;align-items:stretch;padding:10px 14px;gap:8px;width:100%;max-width:100%;box-sizing:border-box;min-width:0}.player .now{min-width:0;width:100%;flex-wrap:nowrap}.player .now img{width:40px;height:40px;flex-shrink:0}.player .track-meta{min-width:0;flex:1}.player .title{font-size:12px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player .sub{font-size:10px}.player .controls{max-width:none;width:100%;min-width:0}.player .seek{min-width:0}.player .seek input[type=range]{flex:1 1 0;min-width:0;width:100%}.player .buttons button{width:44px;height:44px;font-size:22px}.player .buttons .play,.player .buttons .play:focus,.player .buttons .play:active{background:transparent;color:#fff;width:52px;height:52px;font-size:30px}.player .seek input[type=range]::-webkit-slider-thumb{width:16px;height:16px}.queue-drawer{width:100vw}.modal{width:95vw;max-height:85vh}.login-card{padding:24px 20px}}.hint,.error{padding:24px;text-align:center;color:#888}
