*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--mag: #ff00cc;--mag-dk: #cc00a0;--violet: #7c3aed;--mauve: #b388ff;--indigo: #818cf8;--cyan: #67e8f9;--pink: #f472b6;--rose: #fb7185;--gold: #fbbf24;--bg: #0d0010;--bg2: #120018;--glass: rgba(255,255,255,.07);--glass-hov: rgba(255,255,255,.11);--glass-str: rgba(255,255,255,.1);--glass-bd: rgba(255,255,255,.14);--glass-bd-t: rgba(255,255,255,.26);--glass-bd-l: rgba(255,255,255,.2);--glass-sh: 0 8px 32px rgba(180,0,255,.18);--glass-sh-lg:0 16px 48px rgba(180,0,255,.22);--grad-primary: linear-gradient(135deg, var(--mag), var(--violet));--grad-text: linear-gradient(90deg, var(--mag), var(--mauve), var(--cyan));--grad-bg: linear-gradient(135deg, #1a0030 0%, #2d0060 30%, #0d0018 60%, #1a0030 100%);--text: #f0ecff;--text-2: rgba(240,236,255,.65);--text-3: rgba(240,236,255,.38);--danger: #f87171;--radius: 16px;--radius-sm: 10px;--radius-pill:9999px;--ease: cubic-bezier(.4, 0, .2, 1);--fast: .15s var(--ease);--med: .25s var(--ease);--slow: .4s var(--ease)}html{font-size:16px}body{font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(ellipse 80% 55% at 15% 25%,rgba(255,0,204,.2) 0%,transparent 60%),radial-gradient(ellipse 70% 50% at 85% 15%,rgba(124,58,237,.16) 0%,transparent 55%),radial-gradient(ellipse 60% 40% at 50% 85%,rgba(103,232,249,.09) 0%,transparent 50%),radial-gradient(ellipse 50% 60% at 5% 90%,rgba(244,114,182,.12) 0%,transparent 50%),var(--grad-bg)}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;background:none;font:inherit;color:inherit}img{display:block;max-width:100%}input,textarea{font:inherit;color:inherit}.glass{background:var(--glass);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid var(--glass-bd);border-top-color:var(--glass-bd-t);border-left-color:var(--glass-bd-l);box-shadow:var(--glass-sh),inset 0 1px #ffffff14}.glass-strong{background:var(--glass-str);backdrop-filter:blur(32px) saturate(200%);-webkit-backdrop-filter:blur(32px) saturate(200%);border:1px solid rgba(255,255,255,.18);border-top-color:#ffffff52;border-left-color:#ffffff3d;box-shadow:var(--glass-sh-lg),inset 0 2px #ffffff1f,inset 0 -1px #b400ff14}.grad-text{background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.spinner{width:32px;height:32px;border:2.5px solid rgba(255,255,255,.1);border-top-color:var(--mag);border-radius:50%;animation:spin .7s linear infinite;margin:auto}.spinner-sm{width:18px;height:18px;border-width:2px}@keyframes spin{to{transform:rotate(360deg)}}.alert{padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.9rem}.alert-error{background:#f871711a;border:1px solid rgba(248,113,113,.35);color:var(--rose)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:.55rem 1.25rem;border-radius:var(--radius-pill);font-size:.875rem;font-weight:600;transition:all var(--fast);position:relative;overflow:hidden}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--grad-primary);color:#fff;box-shadow:0 4px 20px #ff00cc59}.btn-primary:hover:not(:disabled){box-shadow:0 6px 28px #ff00cc8c;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-ghost{background:var(--glass);color:var(--text-2);border:1px solid var(--glass-bd);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.btn-ghost:hover{background:var(--glass-hov);color:var(--text);border-color:#ffffff40}.btn-spotify{background:var(--grad-primary);color:#fff;padding:.85rem 2.25rem;font-size:1rem;border-radius:var(--radius-pill);box-shadow:0 4px 24px #f0c6}.btn-spotify:hover{box-shadow:0 8px 36px #f0c9;transform:translateY(-1px)}.btn-full{width:100%}.input{width:100%;background:#ffffff0d;border:1px solid var(--glass-bd);border-radius:var(--radius-sm);color:var(--text);padding:.7rem 1rem;font-size:.95rem;outline:none;transition:border-color var(--fast),box-shadow var(--fast),background var(--fast);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.input::placeholder{color:var(--text-3)}.input:focus{border-color:#ff00cc80;background:#ffffff12;box-shadow:0 0 0 3px #ff00cc1f}.input-error{border-color:#f8717180}.textarea{resize:vertical;min-height:100px;line-height:1.6}.splash{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1.5rem;position:relative;z-index:1}.splash-logo{font-size:2rem;font-weight:800;letter-spacing:-1px}.splash-logo span{background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-shell{display:flex;flex-direction:column;min-height:100vh;position:relative;z-index:1}.app-body{display:grid;grid-template-columns:260px 1fr 320px;gap:0;flex:1;max-width:1360px;margin:0 auto;width:100%;padding:0 16px}.navbar{position:sticky;top:0;z-index:200;display:flex;align-items:center;padding:0 24px;height:60px;background:#0d0010b8;backdrop-filter:blur(32px) saturate(180%);-webkit-backdrop-filter:blur(32px) saturate(180%);border-bottom:1px solid rgba(255,255,255,.08);box-shadow:0 1px #ff00cc0f}.nav-logo-wrap{display:flex;align-items:center;gap:10px;text-decoration:none}.nav-logo-circle{width:34px;height:34px;border-radius:50%;background:var(--grad-primary);display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:900;color:#fff;box-shadow:0 0 16px #ff00cc8c,0 0 32px #7c3aed4d;flex-shrink:0;transition:box-shadow var(--med)}.nav-logo-wrap:hover .nav-logo-circle{box-shadow:0 0 24px #ff00ccbf,0 0 48px #7c3aed73}.nav-logo-text{font-size:1.2rem;font-weight:800;letter-spacing:-.5px;background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav-links{display:flex;gap:2px;margin-left:20px}.nav-link{display:flex;align-items:center;gap:7px;padding:7px 14px;border-radius:10px;font-size:.875rem;font-weight:500;color:var(--text-2);transition:all var(--fast);text-decoration:none}.nav-link:hover{color:var(--text);background:#ffffff0f}.nav-link.active{color:#f8e;background:#ff00cc1f;border:1px solid rgba(255,0,204,.22);box-shadow:0 0 12px #ff00cc26}.nav-link-icon{font-size:1rem}.nav-right{display:flex;align-items:center;gap:10px;margin-left:auto;flex-shrink:0}.nav-share-btn{padding:.45rem 1.1rem;font-size:.85rem}.nav-avatar-btn{display:flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;border-radius:var(--radius-pill);background:var(--glass);border:1px solid var(--glass-bd);transition:all var(--fast);text-decoration:none}.nav-avatar-btn:hover{background:var(--glass-hov);border-color:#ff00cc4d}.nav-avatar{width:30px;height:30px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,0,204,.4)}.nav-avatar-placeholder{width:30px;height:30px;border-radius:50%;background:var(--grad-primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;color:#fff}.nav-username{font-size:.82rem;font-weight:600;color:var(--text-2)}.nav-logout-btn{font-size:.8rem;color:var(--text-3);padding:.35rem .75rem;border-radius:var(--radius-pill);border:1px solid rgba(255,255,255,.08);transition:all var(--fast)}.nav-logout-btn:hover{color:var(--rose);border-color:#f8717159}.sidebar{padding:20px 12px 20px 0;border-right:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;gap:6px}.sidebar-section{margin-bottom:4px}.sidebar-section-title{font-size:9.5px;font-weight:700;letter-spacing:1.6px;text-transform:uppercase;color:var(--text-3);padding:4px 12px 8px;display:block}.sidebar-nav-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:12px;font-size:.875rem;font-weight:500;color:var(--text-2);text-decoration:none;transition:all var(--fast);position:relative;cursor:pointer;border:1px solid transparent}.sidebar-nav-item:hover{color:var(--text);background:#ffffff0d}.sidebar-nav-item.active{color:#f8e;background:linear-gradient(135deg,#ff00cc1f,#7c3aed14);border-color:#ff00cc2e;box-shadow:0 0 16px #ff00cc1a}.sidebar-item-icon{font-size:1.05rem;flex-shrink:0}.sidebar-stats{border-radius:14px;padding:14px;margin:4px 0}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.stat-cell{text-align:center;padding:10px 6px;border-radius:10px;background:#ffffff0a;border:1px solid rgba(255,255,255,.07);transition:all var(--fast)}.stat-cell:hover{background:#ff00cc14;border-color:#ff00cc2e}.stat-value{font-size:1.35rem;font-weight:800;line-height:1;background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:block}.stat-label{font-size:.7rem;color:var(--text-3);margin-top:3px;display:block}.suggestions-card{border-radius:14px;padding:12px;margin:4px 0}.suggestion-row{display:flex;align-items:center;gap:9px;padding:7px 0;border-bottom:1px solid rgba(255,255,255,.05);transition:all var(--fast)}.suggestion-row:last-child{border-bottom:none}.suggestion-avatar{width:34px;height:34px;border-radius:50%;flex-shrink:0;object-fit:cover;border:1.5px solid rgba(255,255,255,.12)}.suggestion-avatar-placeholder{width:34px;height:34px;border-radius:50%;flex-shrink:0;background:var(--grad-primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;color:#fff;border:1.5px solid rgba(255,255,255,.12)}.suggestion-info{flex:1;min-width:0}.suggestion-name{font-size:.82rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.suggestion-sub{font-size:.72rem;color:var(--text-3);margin-top:1px}.suggestion-follow-btn{flex-shrink:0;padding:4px 12px;border-radius:var(--radius-pill);font-size:.75rem;font-weight:700;background:#ff00cc1f;border:1px solid rgba(255,0,204,.28);color:#f9e;transition:all var(--fast)}.suggestion-follow-btn:hover{background:#ff00cc38;box-shadow:0 0 12px #ff00cc40}.suggestion-follow-btn.following{background:#ffffff0d;border-color:#ffffff1f;color:var(--text-3)}.suggestion-follow-btn.following:hover{border-color:#f8717166;color:var(--rose);background:#f8717114}.main-feed{padding:20px;border-right:1px solid rgba(255,255,255,.06);min-width:0}.create-box{border-radius:18px;padding:16px 18px;margin-bottom:20px;transition:all var(--med)}.create-box:hover{background:var(--glass-hov)}.create-row{display:flex;align-items:center;gap:12px}.create-avatar{width:38px;height:38px;border-radius:50%;flex-shrink:0;object-fit:cover;border:2px solid rgba(255,0,204,.3)}.create-avatar-placeholder{width:38px;height:38px;border-radius:50%;flex-shrink:0;background:var(--grad-primary);display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:.9rem;border:2px solid rgba(255,0,204,.4)}.create-input-fake{flex:1;background:#ffffff0d;border:1px solid rgba(255,255,255,.09);border-radius:var(--radius-pill);padding:10px 18px;font-size:.88rem;color:var(--text-3);cursor:pointer;transition:all var(--fast);text-decoration:none;display:block}.create-input-fake:hover{background:#ffffff14;border-color:#ff00cc4d;color:var(--text-2)}.create-share-btn{flex-shrink:0;padding:.5rem 1.1rem;font-size:.85rem}.feed-tabs{display:flex;gap:8px;margin-bottom:18px}.feed-tab{padding:8px 22px;border-radius:var(--radius-pill);font-size:.875rem;font-weight:600;color:var(--text-3);border:1px solid rgba(255,255,255,.09);background:transparent;transition:all var(--med);cursor:pointer}.feed-tab:hover{color:var(--text-2);border-color:#ffffff2e;background:#ffffff0a}.feed-tab.active{background:var(--grad-primary);border-color:transparent;color:#fff;box-shadow:0 4px 20px #f0c6,0 0 0 1px #ffffff14;transform:none}.feed{display:flex;flex-direction:column;gap:14px}.feed-loading{display:flex;justify-content:center;padding:3rem}.feed-empty{text-align:center;padding:3rem 1.5rem;color:var(--text-3);line-height:2;border-radius:var(--radius);border:1px dashed rgba(255,255,255,.08)}.feed-empty a{color:var(--mauve)}.feed-sentinel{height:1px}.feed-loading-more{display:flex;justify-content:center;padding:1rem}.feed-end{text-align:center;color:var(--text-3);font-size:.82rem;padding:.75rem}.post-card{border-radius:20px;padding:18px 20px;display:flex;flex-direction:column;gap:12px;transition:all var(--med);position:relative;overflow:hidden;animation:postIn .35s var(--ease) both}@keyframes postIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.post-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(135deg,#ff00cc0a,#7c3aed0a,#67e8f905);opacity:0;transition:opacity var(--med)}.post-card:hover{background:var(--glass-hov)}.post-card:hover:before{opacity:1}.post-header{display:flex;align-items:center;justify-content:space-between}.post-author-link{display:flex;align-items:center;gap:9px;transition:opacity var(--fast);text-decoration:none}.post-author-link:hover{opacity:.8}.post-avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.12);flex-shrink:0}.post-avatar-placeholder{width:38px;height:38px;border-radius:50%;background:var(--grad-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;flex-shrink:0}.post-author-name{font-weight:700;font-size:.9rem}.post-meta{display:flex;align-items:center;gap:.6rem}.post-time{font-size:.78rem;color:var(--text-3)}.post-delete-btn{color:var(--text-3);font-size:1.1rem;line-height:1;padding:.15rem .4rem;border-radius:6px;transition:all var(--fast)}.post-delete-btn:hover{color:var(--danger);background:#f871711a}.post-caption{font-size:.92rem;line-height:1.65;white-space:pre-wrap;word-break:break-word;color:var(--text-2)}.post-track,.spotify-embed{border-radius:12px;overflow:hidden}.post-footer{display:flex;align-items:center;gap:6px;padding-top:10px;border-top:1px solid rgba(255,255,255,.05)}.like-btn{display:flex;align-items:center;gap:5px;padding:.35rem .85rem;border-radius:var(--radius-pill);font-size:.85rem;color:var(--text-3);border:1px solid transparent;transition:all var(--fast)}.like-btn:hover{color:#ff6b9d;border-color:#ff6b9d4d;background:#ff6b9d14}.like-btn.liked{color:#ff6b9d;border-color:#ff6b9d4d;background:#ff6b9d1a}.like-icon{font-size:.95rem;transition:transform .2s var(--ease)}.like-btn.liked .like-icon{transform:scale(1.18)}.like-count{font-size:.82rem;font-weight:600}.follow-btn{padding:.45rem 1.2rem}.btn-follow-active{background:#ff00cc1f;border:1px solid rgba(255,0,204,.28);color:#f9e}.btn-follow-active:hover{background:#f8717114;border-color:#f8717159;color:var(--rose)}.favorite-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem 1.2rem;border-radius:var(--radius-pill);font-size:.875rem;font-weight:600;background:transparent;color:var(--text-3);border:1px solid rgba(255,255,255,.1);transition:all var(--fast)}.favorite-btn:hover:not(:disabled){color:var(--gold);border-color:#fbbf2466;background:#fbbf2414}.favorite-btn.favorited{color:var(--gold);border-color:#fbbf2466;background:#fbbf241a}.favorite-btn.favorited:hover:not(:disabled){color:var(--text-3);border-color:#ffffff1a;background:transparent}.favorite-icon{font-size:.95rem;transition:transform .2s var(--ease)}.favorite-btn.favorited .favorite-icon{transform:scale(1.18)}.track-search,.track-search-input-wrap{position:relative}.track-search-input{padding-right:2.5rem}.track-search-spinner{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);width:16px;height:16px;border:2px solid rgba(255,255,255,.1);border-top-color:var(--mag);border-radius:50%;animation:spin .6s linear infinite}.track-search-results{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:300;background:#14001ee6;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid var(--glass-bd);border-radius:var(--radius-sm);overflow:hidden;list-style:none;max-height:320px;overflow-y:auto;box-shadow:0 12px 40px #0009}.track-result{display:flex;align-items:center;gap:.75rem;padding:.7rem 1rem;cursor:pointer;transition:background var(--fast);border-bottom:1px solid rgba(255,255,255,.04)}.track-result:last-child{border-bottom:none}.track-result:hover{background:#ff00cc14}.track-result-img{width:44px;height:44px;border-radius:6px;object-fit:cover;flex-shrink:0}.track-result-info{display:flex;flex-direction:column;gap:.1rem;min-width:0}.track-result-name{font-size:.88rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-result-artist{font-size:.78rem;color:var(--text-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.right-panel{padding:20px 0 20px 20px;display:flex;flex-direction:column;gap:20px}.now-playing-card{border-radius:20px;padding:14px 14px 10px;position:relative;overflow:hidden;background:linear-gradient(135deg,#ff00cc1f,#7c3aed1a,#67e8f90f)}.now-playing-card:before{content:"";position:absolute;top:-50px;right:-50px;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,rgba(255,0,204,.18) 0%,transparent 70%);pointer-events:none}.np-label{font-size:9px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:#ffa0ffa6;margin-bottom:10px;display:block}.np-embed-wrap{border-radius:12px;overflow:hidden;position:relative;z-index:1}.np-spotify-iframe{display:block;border-radius:12px}.np-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:20px 0;text-align:center}.np-empty-icon{font-size:2rem;opacity:.5}.np-empty-text{font-size:.78rem;color:var(--text-3);line-height:1.5}.trending-card{border-radius:18px;padding:16px}.panel-section-title{font-size:.8rem;font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:6px}.panel-section-title-text{background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.trending-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid rgba(255,255,255,.05);transition:all var(--fast);cursor:pointer}.trending-row:last-child{border-bottom:none}.trending-row:hover{padding-left:4px}.trending-row-active{background:#ff00cc14;border-radius:8px;padding-left:4px;border-bottom-color:transparent!important}.trending-num{font-size:1.1rem;font-weight:900;width:22px;flex-shrink:0;background:var(--grad-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.trending-art{width:34px;height:34px;border-radius:6px;object-fit:cover;flex-shrink:0;border:1px solid rgba(255,255,255,.08)}.trending-art-placeholder{width:34px;height:34px;border-radius:6px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.95rem;border:1px solid rgba(255,255,255,.08)}.trending-info{flex:1;min-width:0}.trending-title{font-size:.82rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trending-artist{font-size:.72rem;color:var(--text-3);margin-top:1px}.trending-plays{font-size:.7rem;color:#ffa0ff8c;flex-shrink:0}.rp-wtf-card{border-radius:18px;padding:16px}.rp-wtf-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.05);transition:all var(--fast)}.rp-wtf-row:last-child{border-bottom:none}.rp-wtf-avatar{width:36px;height:36px;border-radius:50%;flex-shrink:0;object-fit:cover;border:1.5px solid rgba(255,255,255,.12)}.rp-wtf-avatar-placeholder{width:36px;height:36px;border-radius:50%;flex-shrink:0;background:var(--grad-primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.82rem;color:#fff;border:1.5px solid rgba(255,255,255,.12)}.rp-wtf-info{flex:1;min-width:0}.rp-wtf-name{font-size:.82rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rp-wtf-sub{font-size:.7rem;color:var(--text-3);margin-top:1px}.rp-wtf-follow-btn{flex-shrink:0;padding:4px 12px;border-radius:var(--radius-pill);font-size:.73rem;font-weight:700;background:#ff00cc1f;border:1px solid rgba(255,0,204,.28);color:#f9e;transition:all var(--fast)}.rp-wtf-follow-btn:hover{background:#ff00cc38;box-shadow:0 0 12px #ff00cc40}.rp-wtf-follow-btn.following{background:#ffffff0d;border-color:#ffffff1f;color:var(--text-3)}.rp-wtf-follow-btn.following:hover{border-color:#f8717166;color:var(--rose);background:#f8717114}.rp-section{display:flex;flex-direction:column;gap:10px}.rp-section-title{font-size:.8rem;font-weight:700;display:flex;align-items:center;gap:6px}.rp-section-title-text{background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.og-preview-card{border-radius:14px;overflow:hidden}.og-preview-image{height:80px;background:linear-gradient(135deg,#19002d,#f0c3,#7c3aed33);display:flex;align-items:center;justify-content:center;font-size:2rem;border-bottom:1px solid rgba(255,255,255,.06)}.og-preview-body{padding:11px 13px}.og-preview-title{font-size:.82rem;font-weight:700;margin-bottom:3px}.og-preview-desc{font-size:.72rem;color:var(--text-3);line-height:1.4}.og-preview-url{font-size:.68rem;color:#ff00cc73;margin-top:5px}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1.5rem;position:relative;z-index:1}.login-card{max-width:420px;width:100%;border-radius:24px;padding:2.5rem 2.25rem;display:flex;flex-direction:column;gap:1.25rem;text-align:center}.login-logo-wrap{display:flex;justify-content:center;align-items:center;gap:12px}.login-logo-circle{width:52px;height:52px;border-radius:50%;background:var(--grad-primary);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:900;color:#fff;box-shadow:0 0 24px #f0c9,0 0 48px #7c3aed4d}.login-logo-text{font-size:2rem;font-weight:900;letter-spacing:-1px}.login-tagline{font-size:1.2rem;font-weight:700}.login-desc{font-size:.88rem;color:var(--text-2);line-height:1.7}.login-note{font-size:.76rem;color:var(--text-3)}.spotify-icon{width:20px;height:20px}.create-page{max-width:560px;margin:0 auto;padding:8px 0}.create-title{font-size:1.5rem;font-weight:800;margin-bottom:1.5rem}.create-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.45rem}.form-label{font-size:.82rem;color:var(--text-3);font-weight:600;letter-spacing:.3px}.selected-track{display:flex;flex-direction:column;gap:.5rem}.selected-track-meta{font-size:.82rem;color:var(--text-3)}.char-count{font-size:.75rem;color:var(--text-3);text-align:right}.char-count-warn{color:var(--danger)}.profile-page{display:flex;flex-direction:column;gap:1.25rem}.profile-header{display:flex;align-items:flex-start;gap:1.25rem;border-radius:20px;padding:1.5rem}.profile-avatar-wrap{flex-shrink:0}.profile-avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;border:2.5px solid rgba(255,0,204,.4);box-shadow:0 0 20px #f0c3}.profile-avatar-placeholder{width:72px;height:72px;border-radius:50%;background:var(--grad-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:800;box-shadow:0 0 20px #ff00cc4d}.profile-info{display:flex;flex-direction:column;gap:.75rem;flex:1}.profile-name{font-size:1.4rem;font-weight:800}.profile-stats{display:flex;gap:1.25rem;font-size:.85rem;color:var(--text-3)}.profile-stats strong{color:var(--text);font-weight:700}.profile-posts{display:flex;flex-direction:column;gap:1rem}.profile-empty{text-align:center;padding:2rem;color:var(--text-3)}.load-more-btn{width:100%;margin-top:.5rem}.profile-actions{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.people-page{display:flex;flex-direction:column;gap:1.25rem}.people-title{font-size:1.5rem;font-weight:800}.people-search{position:relative}.people-search-input{width:100%;background:#ffffff0d;border:1px solid var(--glass-bd);border-radius:12px;color:var(--text);padding:.8rem 2.5rem .8rem 1rem;font-size:.95rem;outline:none;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:border-color var(--fast),box-shadow var(--fast)}.people-search-input:focus{border-color:#ff00cc73;box-shadow:0 0 0 3px #ff00cc1a}.people-search-input::placeholder{color:var(--text-3)}.people-search-spinner{position:absolute;right:.75rem;top:50%;transform:translateY(-50%)}.people-empty{text-align:center;padding:2rem;color:var(--text-3)}.people-list{list-style:none;display:flex;flex-direction:column;gap:.75rem}.person-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;border-radius:var(--radius);padding:.9rem 1.1rem;transition:all var(--med)}.person-row:hover{background:var(--glass-hov)}.person-info{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0;transition:opacity var(--fast);text-decoration:none}.person-info:hover{opacity:.85}.person-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.1);flex-shrink:0}.person-avatar-placeholder{width:44px;height:44px;border-radius:50%;flex-shrink:0;background:var(--grad-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem}.person-name{font-size:.92rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.person-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.footer{display:flex;align-items:center;justify-content:center;gap:.6rem;padding:1rem 1.5rem;border-top:1px solid rgba(255,255,255,.05);font-size:.75rem;color:var(--text-3);position:relative;z-index:1}.footer-sep{opacity:.3}.footer-link{color:var(--text-3);transition:color var(--fast)}.footer-link:hover{color:var(--mauve)}.sidebar-sticky,.right-panel-sticky{position:sticky;top:80px;max-height:calc(100vh - 100px);overflow-y:auto;scrollbar-width:none}.sidebar-sticky::-webkit-scrollbar,.right-panel-sticky::-webkit-scrollbar{display:none}@media (max-width: 1200px){.app-body{grid-template-columns:220px 1fr 290px}}@media (max-width: 960px){.app-body{grid-template-columns:1fr}.sidebar,.right-panel{display:none}.main-feed{border-right:none;padding:16px}}@media (max-width: 600px){.navbar{padding:0 14px}.nav-links,.nav-username{display:none}.main-feed{padding:12px}.post-card{padding:14px}.feed-tabs{overflow-x:auto}.profile-header{flex-direction:column;align-items:center;text-align:center}.profile-stats,.profile-actions{justify-content:center}.person-row{flex-direction:column;align-items:flex-start}.person-actions{align-self:flex-end}}.nav-mini-player{display:flex;align-items:center;gap:8px;padding:5px 10px 5px 6px;border-radius:var(--radius-pill);max-width:220px;overflow:hidden;flex-shrink:0;animation:fadeInSlide .3s var(--ease)}@keyframes fadeInSlide{0%{opacity:0;transform:translateY(-6px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.nav-mini-art{width:28px;height:28px;border-radius:6px;object-fit:cover;flex-shrink:0}.nav-mini-art-placeholder{width:28px;height:28px;border-radius:6px;flex-shrink:0;background:var(--grad-primary);display:flex;align-items:center;justify-content:center;font-size:.85rem}.nav-mini-info{display:flex;flex-direction:column;min-width:0;flex:1}.nav-mini-title{font-size:.72rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-mini-artist{font-size:.65rem;color:var(--text-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-mini-play-btn{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:var(--grad-primary);display:flex;align-items:center;justify-content:center;font-size:.7rem;color:#fff;box-shadow:0 2px 10px #f0c6;transition:all var(--fast)}.nav-mini-play-btn:hover{transform:scale(1.1);box-shadow:0 4px 16px #ff00cc8c}.nav-mini-play-btn.playing{background:#ffffff26}.notif-wrap{position:relative}.notif-bell-btn{position:relative;width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);transition:all var(--fast)}.notif-bell-btn:hover{background:#ffffff1f}.notif-bell-btn.active{background:#ff00cc1f;border-color:#ff00cc4d}@keyframes bellRing{0%{transform:rotate(0)}10%{transform:rotate(-18deg)}20%{transform:rotate(18deg)}30%{transform:rotate(-14deg)}40%{transform:rotate(14deg)}50%{transform:rotate(-8deg)}60%{transform:rotate(8deg)}70%{transform:rotate(-4deg)}80%{transform:rotate(4deg)}to{transform:rotate(0)}}.notif-bell-btn.ringing .notif-bell-icon{display:inline-block;animation:bellRing .8s cubic-bezier(.36,.07,.19,.97);transform-origin:top center}.notif-badge{position:absolute;top:-2px;right:-2px;min-width:18px;height:18px;border-radius:9px;background:var(--mag);color:#fff;font-size:.62rem;font-weight:800;display:flex;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 0 8px #f0c9;border:2px solid var(--bg);animation:popIn .3s var(--ease)}@keyframes popIn{0%{transform:scale(0)}to{transform:scale(1)}}.notif-panel{position:absolute;top:calc(100% + 10px);right:0;width:340px;border-radius:18px;z-index:1000;animation:slideDown .2s var(--ease);overflow:hidden}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.notif-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:1px solid rgba(255,255,255,.07)}.notif-panel-title{font-size:.85rem;font-weight:800;background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.notif-clear-all{font-size:.72rem;color:var(--text-3);transition:color var(--fast);padding:2px 6px;border-radius:6px}.notif-clear-all:hover{color:var(--rose);background:#f8717114}.notif-loading{display:flex;justify-content:center;padding:24px}.notif-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:28px 16px;text-align:center}.notif-empty-icon{font-size:2rem;opacity:.4}.notif-empty p{font-size:.85rem;font-weight:600}.notif-empty-sub{font-size:.72rem;color:var(--text-3)}.notif-list{list-style:none;max-height:400px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.notif-item{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.04);transition:background var(--fast);position:relative}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:#ffffff0a}.notif-item.unread{background:#ff00cc0a}.notif-item.unread:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--mag);border-radius:0 2px 2px 0}.notif-actor-avatar{position:relative;flex-shrink:0}.notif-actor-avatar img,.notif-actor-placeholder{width:36px;height:36px;border-radius:50%;object-fit:cover}.notif-actor-placeholder{background:var(--grad-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem}.notif-type-badge{position:absolute;bottom:-2px;right:-4px;width:18px;height:18px;border-radius:50%;background:var(--bg2);border:1.5px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;font-size:.65rem}.notif-content{flex:1;min-width:0}.notif-label{font-size:.78rem;line-height:1.45;margin-bottom:2px}.notif-label strong{color:var(--text)}.notif-comment-preview{font-size:.72rem;color:var(--text-3);font-style:italic;margin-bottom:2px}.notif-time{font-size:.67rem;color:var(--text-3)}.notif-dismiss-btn{flex-shrink:0;width:22px;height:22px;border-radius:50%;font-size:1rem;color:var(--text-3);line-height:1;display:flex;align-items:center;justify-content:center;transition:all var(--fast);opacity:0}.notif-item:hover .notif-dismiss-btn{opacity:1}.notif-dismiss-btn:hover{background:#f8717126;color:var(--rose)}.comment-thread{border-top:1px solid rgba(255,255,255,.06);margin-top:10px;padding-top:8px}.comment-toggle-btn{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--text-3);padding:4px 0;transition:color var(--fast);width:100%}.comment-toggle-btn:hover{color:var(--text-2)}.comment-icon{font-size:.85rem}.comment-chevron{margin-left:auto;font-size:.95rem;color:var(--text-3);transition:transform var(--fast);display:inline-block}.comment-chevron.open{transform:rotate(90deg)}.comment-thread-body{margin-top:10px;display:flex;flex-direction:column;gap:10px;animation:fadeInDown .2s var(--ease)}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.comment-composer{display:flex;align-items:flex-start;gap:8px}.comment-composer-right{flex:1;display:flex;flex-direction:column;gap:6px}.comment-composer-footer{display:flex;align-items:center;justify-content:space-between}.comment-char-hint{font-size:.68rem;color:var(--text-3)}.comment-avatar-wrap{flex-shrink:0}.comment-avatar{width:30px;height:30px;border-radius:50%;object-fit:cover;border:1.5px solid rgba(255,255,255,.1)}.comment-avatar-placeholder{width:30px;height:30px;border-radius:50%;background:var(--grad-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700}.comment-input{width:100%;resize:none;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:var(--text);padding:8px 10px;font-size:.82rem;line-height:1.5;outline:none;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:border-color var(--fast),box-shadow var(--fast)}.comment-input:focus{border-color:#f0c6;box-shadow:0 0 0 2px #ff00cc14}.comment-input::placeholder{color:var(--text-3)}.comment-submit-btn{padding:5px 14px;font-size:.78rem}.comment-cancel-btn{padding:5px 10px;font-size:.78rem}.comment-list{display:flex;flex-direction:column;gap:0}.comment-empty{font-size:.78rem;color:var(--text-3);text-align:center;padding:8px 0}.comment-loading{display:flex;justify-content:center;padding:12px}.comment-row{display:flex;align-items:flex-start;gap:8px;padding:6px 0;position:relative}.comment-reply{position:relative}.comment-thread-line{position:absolute;left:-16px;top:0;bottom:50%;width:1px;background:linear-gradient(to bottom,rgba(255,0,204,.2),transparent)}.comment-content{flex:1;min-width:0}.comment-bubble{border-radius:12px;padding:8px 11px;display:inline-flex;flex-direction:column;gap:3px;max-width:100%}.comment-author{font-size:.75rem;font-weight:700;color:var(--mauve);text-decoration:none;transition:color var(--fast)}.comment-author:hover{color:var(--mag)}.comment-body{font-size:.82rem;line-height:1.5;word-break:break-word}.comment-mention{color:var(--cyan);font-weight:600;background:#67e8f91a;border-radius:4px;padding:0 2px}.comment-actions{display:flex;align-items:center;gap:12px;padding:3px 4px}.comment-time{font-size:.67rem;color:var(--text-3)}.comment-action-btn{font-size:.72rem;color:var(--text-3);transition:color var(--fast)}.comment-action-btn:hover{color:var(--mauve)}.comment-delete-btn:hover{color:var(--rose)!important}.comment-reply-box{margin-top:6px;display:flex;flex-direction:column;gap:6px}.comment-reply-actions{display:flex;align-items:center;justify-content:flex-end;gap:6px}
