:root{--color-bg-primary: #f5f0f8;--color-bg-secondary: #ede4f5;--color-bg-card: #ffffff;--color-bg-glass: rgba(255, 255, 255, .7);--color-bg-overlay: rgba(40, 20, 60, .3);--color-brand-primary: #7c4d9f;--color-brand-secondary: #9c7fbf;--color-brand-light: #d4c4e8;--color-brand-accent: #b388eb;--color-brand-gold: #c9a84c;--color-brand-red: #d4556e;--color-brand-pink: #e87da0;--color-brand-red-dark: #b33a4a;--color-brand-red-light: #e87da0;--color-brand-orange: #d4855e;--color-brand-purple: #7c4d9f;--color-brand-teal: #5cbfb5;--color-brand-blue: #7eb8da;--color-text-primary: #1a1a1a;--color-text-secondary: #6b6b7b;--color-text-hint: #a0a0b0;--color-text-white: #ffffff;--color-text-on-brand: #ffffff;--color-text-tertiary: #a0a0b0;--color-text-inactive: #a0a0b0;--color-border: #e8e0f0;--color-border-light: #f0eaf5;--color-glass-border: rgba(124, 77, 159, .1);--color-glass-border-hover: rgba(124, 77, 159, .2);--color-glass-shine: rgba(124, 77, 159, .08);--font-family-base: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", "PingFang SC", "Helvetica Neue", "Helvetica", "Arial", sans-serif;--font-family-display: -apple-system, BlinkMacSystemFont, "SF Pro Display", "PingFang SC", "Helvetica Neue", sans-serif;--font-family-mono: "SF Mono", "SFMono-Regular", ui-monospace, "Menlo", "Monaco", "Consolas", monospace;--font-size-caption: .6875rem;--font-size-xs: .75rem;--font-size-sm: .8125rem;--font-size-base: .9375rem;--font-size-md: 1.0625rem;--font-size-lg: 1.25rem;--font-size-xl: 1.5rem;--font-size-2xl: 2rem;--font-size-3xl: 2.5rem;--font-size-4xl: 3.5rem;--font-size-5xl: 3rem;--font-weight-light: 300;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-heavy: 800;--line-height-tight: 1.2;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-base: 12px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--spacing-3xl: 2.5rem;--spacing-4xl: 3rem;--radius-sm: 6px;--radius-base: 10px;--radius-md: 14px;--radius-lg: 20px;--radius-xl: 24px;--radius-full: 999px;--shadow-sm: 0 1px 3px rgba(100, 50, 130, .06);--shadow-base: 0 2px 12px rgba(100, 50, 130, .08);--shadow-md: 0 4px 20px rgba(100, 50, 130, .1);--shadow-lg: 0 8px 32px rgba(100, 50, 130, .12);--shadow-glow: 0 0 30px rgba(124, 77, 159, .2);--shadow-glass: 0 4px 24px rgba(100, 50, 130, .08);--shadow-glow-primary: 0 0 30px rgba(124, 77, 159, .2);--shadow-glow-accent: 0 0 30px rgba(179, 136, 235, .2);--shadow-glow-pink: 0 0 30px rgba(232, 125, 160, .2);--shadow-red-glow: 0 0 30px rgba(212, 85, 110, .2);--blur-glass: blur(20px);--blur-glass-light: blur(10px);--transition-fast: .15s cubic-bezier(.25, .1, .25, 1);--transition-base: .25s cubic-bezier(.25, .1, .25, 1);--transition-slow: .4s cubic-bezier(.25, .1, .25, 1);--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px);--safe-area-left: env(safe-area-inset-left, 0px);--safe-area-right: env(safe-area-inset-right, 0px);--gradient-primary: linear-gradient(135deg, #7c4d9f, #b388eb);--gradient-warm: linear-gradient(135deg, #b388eb, #e87da0);--gradient-soft: linear-gradient(135deg, #ede4f5, #f5f0f8);--gradient-card: linear-gradient(180deg, #ffffff, #faf8fc);--gradient-cool: linear-gradient(135deg, #7c4d9f, #9c7fbf);--gradient-sunset: linear-gradient(135deg, #e87da0, #c9a84c);--gradient-ocean: linear-gradient(135deg, #5cbfb5, #7eb8da);--gradient-spring: linear-gradient(135deg, #e87da0, #7c4d9f);--gradient-autumn: linear-gradient(135deg, #c9a84c, #d4855e);--gradient-night: linear-gradient(135deg, #4a2d6e, #7c4d9f);--gradient-morning: linear-gradient(135deg, #9c7fbf, #e87da0);--color-gradient-blue: var(--gradient-cool);--color-gradient-gold: linear-gradient(135deg, #c9a84c, #d4855e);--color-gradient-dark: linear-gradient(180deg, #f5f0f8, #ede4f5);--color-gradient-red: var(--gradient-warm);--color-gradient-teal: var(--gradient-ocean);--color-gradient-purple: var(--gradient-spring);--color-gradient-coral: var(--gradient-sunset);--color-gradient-indigo: var(--gradient-night);--color-gradient-amber: var(--gradient-autumn);--color-gradient-splash: var(--gradient-soft);--letter-spacing-tight: -.02em;--letter-spacing-wide: .05em;--letter-spacing-wider: .1em}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:calc(100vw / 23.4375);-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-feature-settings:"tnum";width:100%;overscroll-behavior:none;touch-action:manipulation}@media (max-width: 374px){html{font-size:14px}}@media (min-width: 768px){html{font-size:16px}}@media (min-width: 1024px){html{font-size:16px}}body{font-family:var(--font-family-base);font-size:var(--font-size-base);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);color:var(--color-text-primary);background:var(--color-bg-primary);overflow-x:hidden;overflow-y:auto;position:relative;min-height:100vh;overscroll-behavior:none;-webkit-user-select:none;user-select:none}.bg-orb{position:fixed;border-radius:50%;filter:blur(120px);opacity:.3;pointer-events:none;z-index:0;animation:orbFloat 8s ease-in-out infinite alternate;will-change:transform}.bg-orb--1{width:550px;height:550px;background:#7c4d9f1f;top:-120px;left:-100px;animation-delay:0s;animation-duration:9s}.bg-orb--2{width:480px;height:480px;background:#e87da01a;top:55%;right:-130px;animation-delay:-3s;animation-duration:7.5s}.bg-orb--3{width:450px;height:450px;background:#9c7fbf1a;bottom:-100px;left:25%;animation-delay:-6s;animation-duration:8.5s}.bg-orb--4{width:450px;height:450px;background:#c9a84c12;top:20%;left:50%;animation-delay:-1.5s;animation-duration:10s;opacity:.25}.bg-orb--5{width:460px;height:460px;background:#c9a84c0f;top:70%;left:70%;animation-delay:-5s;animation-duration:11s;opacity:.2}@keyframes orbFloat{0%{transform:translate(0) scale(1)}25%{transform:translate(35px,-25px) scale(1.15)}50%{transform:translate(-15px,30px) scale(.95)}75%{transform:translate(-40px,-15px) scale(1.1)}to{transform:translate(20px,20px) scale(.85)}}#app{min-height:100vh;width:100%;overflow:hidden;position:relative;z-index:1}.scrollable{overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}a{color:inherit;text-decoration:none}button{border:none;outline:none;background:none;font-family:inherit;font-size:inherit;color:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit;outline:none;-webkit-appearance:none;border:none;background:none}img,svg{display:block;max-width:100%;height:auto}button svg{pointer-events:none;flex-shrink:0}ul,ol{list-style:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.hidden{display:none!important}.placeholder-page{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-base);width:100%;height:100%;min-height:100vh;color:var(--color-text-secondary);font-size:var(--font-size-base)}.placeholder-btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-sm);font-family:var(--font-family-base);font-weight:var(--font-weight-medium);color:var(--color-text-white);background:var(--color-brand-primary);border:none;border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast);min-width:44px;min-height:44px;touch-action:manipulation}.placeholder-btn:active{background:var(--color-brand-secondary);transform:scale(.95)}.canvas-bg{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0}.liquid-glass{background:#fff9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(124,77,159,.1);border-radius:var(--radius-md);transition:all .4s cubic-bezier(.25,.1,.25,1);position:relative;z-index:1;box-shadow:0 2px 16px #6432820f}.liquid-glass:after{content:"";position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(124,77,159,.15),transparent);opacity:0;transition:opacity .4s cubic-bezier(.25,.1,.25,1);pointer-events:none;z-index:2}.liquid-glass:hover:after{opacity:1}.liquid-glass:hover{background:#ffffffd9;border-color:#7c4d9f33;box-shadow:0 8px 32px #6432821f,0 0 0 1px #7c4d9f14;transform:translateY(-4px)}.liquid-glass:active{transform:scale(.97);transition:transform .1s ease}.glass-gradient-border{position:relative;background:#fff9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:var(--radius-lg);overflow:hidden}.glass-gradient-border:before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:linear-gradient(135deg,#7c4d9f80,#b388eb4d,#e87da080);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;z-index:1}.splash-container{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#f5f0f8;z-index:1000;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden}.splash-container--exiting{animation:splashFadeOut .5s ease forwards}.splash-canvas-layer{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1}.splash-canvas-layer canvas{display:block;width:100%;height:100%}.splash-overlay{position:absolute;bottom:max(22vh,calc(env(safe-area-inset-bottom,0px) + 8rem));left:50%;transform:translate(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.splash-subtitle{font-family:var(--font-family-base);font-size:var(--font-size-md);font-weight:var(--font-weight-light);color:var(--color-text-secondary);letter-spacing:var(--letter-spacing-wide);text-align:center;opacity:0;transform:translate3d(0,.75rem,0);animation:splashFadeInUp .6s cubic-bezier(.16,1,.3,1) .8s forwards;will-change:opacity,transform}.splash-progress-area{position:absolute;bottom:max(14vh,calc(env(safe-area-inset-bottom,0px) + 1rem));left:50%;transform:translate(-50%);width:min(60vw,16rem);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);opacity:0;animation:splashFadeInUp .6s cubic-bezier(.16,1,.3,1) .4s forwards;will-change:opacity}.splash-progress-track{width:100%;height:.1875rem;background-color:#7c4d9f1f;border-radius:var(--radius-full);overflow:hidden}.splash-progress-fill{height:100%;width:0%;border-radius:var(--radius-full);background:linear-gradient(90deg,var(--color-brand-primary),var(--color-brand-accent));box-shadow:0 0 10px #7c4d9f4d;transition:width .3s ease}.splash-version{position:absolute;bottom:max(4vh,var(--safe-area-bottom));left:50%;transform:translate(-50%);font-family:var(--font-family-mono);font-size:var(--font-size-xs);color:var(--color-text-hint);letter-spacing:var(--letter-spacing-wide);opacity:0;animation:splashFadeInUp .6s cubic-bezier(.16,1,.3,1) 1s forwards;will-change:opacity;padding-bottom:var(--spacing-sm)}@keyframes splashFadeInUp{0%{opacity:0;transform:translate3d(0,.75rem,0)}to{opacity:1;transform:translateZ(0)}}@keyframes splashFadeOut{0%{opacity:1;transform:translateZ(0) scale(1)}to{opacity:0;transform:translate3d(0,-.5rem,0) scale(1.05)}}.splash-container--css-fallback{background:linear-gradient(135deg,#f5f0f8,#7c4d9f0d,#f5f0f8);background-size:200% 200%;animation:splashGradientShift 6s ease-in-out infinite}@keyframes splashGradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@media (min-width: 768px){.splash-subtitle{font-size:var(--font-size-lg)}.splash-progress-area{max-width:480px}}@media (max-width: 374px){.splash-subtitle{font-size:var(--font-size-sm)}.splash-progress-area{width:70vw}}.home-page{width:100%;min-height:100vh;display:flex;flex-direction:column;position:relative;padding-bottom:calc(60px + var(--safe-area-bottom))}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.playlist-scroll-card{animation:cardFadeIn .5s ease-out both}.playlist-scroll-card:nth-child(1){animation-delay:.05s}.playlist-scroll-card:nth-child(2){animation-delay:.1s}.playlist-scroll-card:nth-child(3){animation-delay:.15s}.playlist-scroll-card:nth-child(4){animation-delay:.2s}.playlist-scroll-card:nth-child(5){animation-delay:.25s}.playlist-scroll-card:nth-child(6){animation-delay:.3s}.playlist-scroll-card:nth-child(7){animation-delay:.35s}.playlist-scroll-card:nth-child(8){animation-delay:.4s}.playlist-scroll-card:nth-child(9){animation-delay:.45s}.playlist-scroll-card:nth-child(10){animation-delay:.5s}.hot-list-card{animation:cardFadeIn .5s ease-out both}.hot-list-card:nth-child(1){animation-delay:.3s}.hot-list-card:nth-child(2){animation-delay:.35s}.hot-list-card:nth-child(3){animation-delay:.4s}.hot-list-card:nth-child(4){animation-delay:.45s}.hot-list-card:nth-child(5){animation-delay:.5s}.hot-list-card:nth-child(6){animation-delay:.55s}.daily-banner{animation:cardFadeIn .6s ease-out .02s both}.tag-chips{animation:cardFadeIn .4s ease-out .1s both}.section-header{animation:cardFadeIn .4s ease-out both}.top-bar{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);padding-top:calc(var(--safe-area-top) + var(--spacing-sm));height:56px;background:#ffffffbf;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(124,77,159,.1);position:sticky;top:0;z-index:100;flex-shrink:0}.top-bar-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;font-size:var(--font-size-lg);color:var(--color-text-primary);border-radius:var(--radius-full);transition:background var(--transition-fast)}.top-bar-btn:active{background:#7c4d9f14}.top-bar-logo{font-size:var(--font-size-2xl);font-weight:var(--font-weight-heavy);color:var(--color-brand-primary);letter-spacing:-.5px;font-family:var(--font-family-display);white-space:nowrap;overflow:visible;flex-shrink:0}.home-scroll{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.daily-banner{margin:var(--spacing-md);border-radius:20px;overflow:hidden;position:relative;height:180px;background:linear-gradient(135deg,#7c4d9f,#b388eb);box-shadow:0 8px 40px #7c4d9f33,0 0 0 1px #7c4d9f14;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-base)}.daily-banner:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%,rgba(124,77,159,.15) 50%,rgba(124,77,159,.55) 100%);z-index:1;pointer-events:none}.daily-banner:hover{transform:translateY(-2px);box-shadow:0 12px 48px #7c4d9f40,0 0 0 1px #7c4d9f26}.daily-banner:active{transform:scale(.98)}.daily-banner-img{width:100%;height:100%;object-fit:cover;display:block;position:absolute;top:0;left:0;z-index:0}.banner-content{position:absolute;bottom:0;left:0;right:0;padding:var(--spacing-xl) var(--spacing-lg) var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-sm);z-index:2;align-items:flex-start}.banner-tag{display:inline-flex;align-items:center;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-white);background:#7c4d9f4d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-full);padding:3px 12px;white-space:nowrap;letter-spacing:.5px}.banner-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-white);line-height:var(--line-height-tight);text-shadow:0 2px 8px rgba(0,0,0,.25);margin:0;letter-spacing:-.01em}.banner-desc{font-size:var(--font-size-sm);color:#ffffffd9;text-shadow:0 1px 4px rgba(0,0,0,.15);margin:0;line-height:1.3}.section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-md) var(--spacing-sm);flex-shrink:0}.section-title{font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--color-text-primary);padding-left:10px;border-left:3px solid var(--color-brand-primary);line-height:1.2;letter-spacing:.5px}.section-more{font-size:var(--font-size-xs);color:var(--color-text-hint);display:flex;align-items:center;gap:2px;cursor:pointer;padding:6px 4px;border-radius:var(--radius-full);transition:color var(--transition-fast)}.section-more:hover{color:var(--color-brand-primary)}.section-more:active{color:var(--color-brand-secondary)}.tag-chips{display:flex;gap:var(--spacing-sm);padding:0 var(--spacing-md) var(--spacing-base);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;flex-shrink:0}.tag-chips::-webkit-scrollbar{display:none}.tag-chip{flex-shrink:0;padding:7px 16px;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;transition:all .3s cubic-bezier(.25,.1,.25,1);white-space:nowrap}.tag-chip:hover{background:#7c4d9f0d;border-color:#7c4d9f33;color:var(--color-text-primary)}.tag-chip.active{color:var(--color-text-white);background:var(--color-brand-primary);border-color:var(--color-brand-primary);box-shadow:0 0 20px #7c4d9f40}.tag-chip:active{transform:scale(.95);transition:transform .1s ease}.playlist-scroll{display:flex;gap:var(--spacing-sm);padding:0 var(--spacing-md) var(--spacing-base);overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;scroll-snap-type:x proximity}.playlist-scroll::-webkit-scrollbar{display:none}.playlist-scroll-card{flex-shrink:0;width:120px;display:flex;flex-direction:column;gap:8px;cursor:pointer;scroll-snap-align:start;padding:var(--spacing-sm);border-radius:14px;opacity:0;background:var(--color-bg-card);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light)}.playlist-scroll-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.playlist-scroll-card:active{transform:scale(.95)}.playlist-scroll-cover{width:100%;aspect-ratio:1 / 1;border-radius:12px;overflow:hidden;background:linear-gradient(135deg,#d4c4e8,#ede4f5);position:relative;transition:transform .4s cubic-bezier(.25,.1,.25,1)}.playlist-scroll-card:hover .playlist-scroll-cover{transform:scale(1.05)}.playlist-scroll-cover img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s cubic-bezier(.25,.1,.25,1)}.playlist-scroll-card:hover .playlist-scroll-cover img{transform:scale(1.08)}.playlist-scroll-playcount{position:absolute;top:6px;right:6px;font-size:10px;color:var(--color-text-white);background:#00000073;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-full);padding:2px 8px;white-space:nowrap;z-index:2;font-weight:var(--font-weight-medium)}.playlist-scroll-title{font-size:var(--font-size-xs);color:var(--color-text-primary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:var(--line-height-tight);padding:0 4px;font-weight:var(--font-weight-medium)}.hot-list{display:flex;flex-direction:column;gap:2px;padding:0 var(--spacing-md) var(--spacing-md)}.hot-list-card{display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm);cursor:pointer;border-radius:14px;opacity:0;transition:all .3s cubic-bezier(.25,.1,.25,1)}.hot-list-card:hover{transform:translateY(-2px)}.hot-list-card:active{transform:scale(.98)}.hot-list-card+.hot-list-card{border-top:1px solid var(--color-border-light)}.hot-list-cover{width:66px;height:66px;border-radius:10px;overflow:hidden;flex-shrink:0;background:linear-gradient(135deg,#d4c4e8,#ede4f5)}.hot-list-cover img{width:100%;height:100%;object-fit:cover;display:block}.hot-list-info{flex:1;display:flex;flex-direction:column;justify-content:center;gap:3px;min-width:0}.hot-list-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hot-list-desc{font-size:var(--font-size-xs);color:var(--color-text-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:var(--line-height-tight)}.hot-list-meta{font-size:10px;color:var(--color-text-hint);display:flex;align-items:center;gap:4px}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:stretch;justify-content:space-around;background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(124,77,159,.1);z-index:200;padding-bottom:var(--safe-area-bottom)}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:7px 0 5px;min-height:50px;cursor:pointer;position:relative;color:var(--color-text-secondary);transition:color .25s cubic-bezier(.25,.1,.25,1)}.bottom-nav-item.active{color:var(--color-brand-primary)}.bottom-nav-item.active:before{content:"";position:absolute;top:0;left:30%;right:30%;height:3px;background:var(--color-brand-primary);border-radius:0 0 3px 3px;box-shadow:0 0 12px #7c4d9f4d}.bottom-nav-item:active{opacity:.6}.bottom-nav-icon-wrap{position:relative;display:flex;align-items:center;justify-content:center;width:24px;height:24px}.bottom-nav-dot{position:absolute;top:-1px;right:-5px;width:7px;height:7px;border-radius:var(--radius-full);background:var(--color-brand-primary);box-shadow:0 0 8px #7c4d9f4d;opacity:0;transform:scale(0);transition:opacity .25s cubic-bezier(.25,.1,.25,1),transform .25s cubic-bezier(.25,.1,.25,1)}.bottom-nav-item.active .bottom-nav-dot{opacity:1;transform:scale(1)}.bottom-nav-icon{flex-shrink:0}.bottom-nav-label{font-size:10px;font-weight:var(--font-weight-medium);line-height:1}@media (max-width: 374px){.daily-banner{margin:var(--spacing-sm);height:150px}.banner-content{padding:var(--spacing-lg) var(--spacing-md) var(--spacing-md)}.section-header{padding:var(--spacing-sm) var(--spacing-sm) var(--spacing-xs)}.playlist-scroll{padding:0 var(--spacing-sm)}.playlist-scroll-card{width:105px}.hot-list{padding:0 var(--spacing-sm) var(--spacing-sm)}.hot-list-cover{width:56px;height:56px}}@media (min-width: 768px){.playlist-scroll-card{width:150px}.hot-list-cover{width:80px;height:80px}.daily-banner{max-width:720px;margin-left:auto;margin-right:auto;height:220px}.banner-content{padding:var(--spacing-2xl) var(--spacing-xl) var(--spacing-xl);gap:var(--spacing-md)}.banner-title{font-size:var(--font-size-2xl)}.banner-desc{font-size:var(--font-size-md)}.home-scroll,.top-bar{max-width:720px;margin:0 auto}.bottom-nav{max-width:720px;left:50%;transform:translate(-50%)}}@media (min-width: 1024px){.home-page{align-items:center}.playlist-scroll-card{width:160px}.hot-list-cover{width:90px;height:90px}.daily-banner{max-width:880px;height:260px}.home-scroll,.top-bar,.bottom-nav{max-width:960px}.hot-list{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm);padding:0 var(--spacing-md) var(--spacing-md)}.hot-list-card+.hot-list-card{border-top:none}.hot-list-card{border-radius:var(--radius-md);background:var(--color-bg-card);border:1px solid var(--color-border-light)}.hot-list-cover{width:100px;height:100px}}.search-page{width:100%;min-height:100vh;display:flex;flex-direction:column;position:relative}.search-top-bar{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);padding-top:calc(var(--safe-area-top) + var(--spacing-sm));background:#ffffffbf;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(124,77,159,.1);position:sticky;top:0;z-index:100;flex-shrink:0}.search-back-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;font-size:var(--font-size-lg);color:var(--color-text-primary);border-radius:var(--radius-full);flex-shrink:0;transition:background var(--transition-fast);cursor:pointer;border:none;background:none}.search-back-btn:active{background:#7c4d9f14}.search-input-wrap{flex:1;position:relative;display:flex;align-items:center}.search-input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:var(--font-size-md);color:var(--color-text-hint);pointer-events:none;z-index:1;transition:color var(--transition-base);display:flex;align-items:center}.search-input-icon svg{display:block}.search-input{width:100%;height:36px;padding:0 12px 0 36px;font-size:var(--font-size-sm);font-weight:var(--font-weight-normal);color:var(--color-text-primary);background:#7c4d9f0d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(124,77,159,.1);border-radius:var(--radius-full);outline:none;transition:all var(--transition-base);-webkit-appearance:none}.search-input::placeholder{color:var(--color-text-hint)}.search-input:focus{background:#7c4d9f14;border-color:#7c4d9f66;box-shadow:0 0 20px #7c4d9f26,0 0 40px #7c4d9f0f}.search-input-wrap:focus-within .search-input-icon{color:var(--color-brand-primary)}.search-clear-btn{position:absolute;right:4px;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:28px;height:28px;font-size:var(--font-size-sm);color:var(--color-text-hint);border-radius:var(--radius-full);cursor:pointer;border:none;background:none;transition:color var(--transition-fast),background var(--transition-fast);z-index:1;opacity:0;pointer-events:none}.search-clear-btn svg{display:block;flex-shrink:0}.search-clear-btn.visible{opacity:1;pointer-events:auto}.search-clear-btn:active{color:var(--color-text-primary);background:#7c4d9f1a}.search-content{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding:var(--spacing-md)}.search-section-title{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) 0 var(--spacing-base);flex-shrink:0}.search-section-heading{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);display:flex;align-items:center;gap:6px}.search-section-icon{font-size:var(--font-size-base);display:flex;align-items:center}.search-section-icon svg{display:block;flex-shrink:0}.search-clear-history{font-size:var(--font-size-xs);color:var(--color-text-hint);padding:4px 8px;border-radius:var(--radius-sm);cursor:pointer;border:none;background:none;transition:color var(--transition-fast)}.search-clear-history:hover,.search-clear-history:active{color:var(--color-brand-red)}.hot-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);padding-bottom:var(--spacing-lg)}.hot-tag{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-card);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);min-width:72px;flex-shrink:0}.hot-tag:hover{background:#7c4d9f14;border-color:#7c4d9f40;box-shadow:0 0 20px #7c4d9f1a;transform:translateY(-2px)}.hot-tag:active{transform:scale(.95);transition:transform .1s ease}.hot-tag-keyword{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.hot-tag-count{font-size:var(--font-size-xs);color:var(--color-text-hint)}.search-history-list{display:flex;flex-direction:column;gap:1px}.search-history-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-base);background:#7c4d9f08;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--color-border-light);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.search-history-item:hover{background:#7c4d9f0f;border-color:#7c4d9f26}.search-history-item:active{background:#7c4d9f1a}.search-history-icon{font-size:var(--font-size-sm);color:var(--color-text-hint);flex-shrink:0;display:flex;align-items:center}.search-history-icon svg{display:block;flex-shrink:0}.search-history-text{flex:1;font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.search-history-delete{display:flex;align-items:center;justify-content:center;width:28px;height:28px;font-size:var(--font-size-sm);color:var(--color-text-hint);border-radius:var(--radius-full);cursor:pointer;border:none;background:none;flex-shrink:0;transition:color var(--transition-fast),background var(--transition-fast)}.search-history-delete svg{display:block;flex-shrink:0}.search-history-delete:hover{color:var(--color-brand-red);background:#d4556e14}.search-history-delete:active{transform:scale(.85)}.search-suggestions{display:flex;flex-direction:column;gap:1px}.search-suggestion-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);display:flex;align-items:center;gap:6px;padding:var(--spacing-sm) 0 var(--spacing-base)}.search-suggestion-icon{font-size:var(--font-size-base);display:flex;align-items:center}.search-suggestion-icon svg{display:block;flex-shrink:0}.search-suggestion-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-base);background:#7c4d9f08;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--color-border-light);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.search-suggestion-item:hover{background:#7c4d9f14;border-color:#7c4d9f33}.search-suggestion-item:active{background:#7c4d9f1a;transform:scale(.99)}.search-suggestion-text{flex:1;font-size:var(--font-size-sm);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.search-suggestion-artist{font-size:var(--font-size-xs);color:var(--color-text-secondary);flex-shrink:0;max-width:40%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.match-highlight{color:var(--color-brand-primary);font-weight:var(--font-weight-medium)}.search-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl) var(--spacing-md);gap:var(--spacing-sm);text-align:center}.search-empty-icon{font-size:var(--font-size-3xl);opacity:.3;display:flex;align-items:center;justify-content:center}.search-empty-icon svg{display:block}.search-empty-text{font-size:var(--font-size-sm);color:var(--color-text-hint)}@keyframes searchFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.search-history-item{animation:searchFadeIn .3s ease-out both}.search-history-item:nth-child(1){animation-delay:.02s}.search-history-item:nth-child(2){animation-delay:.06s}.search-history-item:nth-child(3){animation-delay:.1s}.search-history-item:nth-child(4){animation-delay:.14s}.search-history-item:nth-child(5){animation-delay:.18s}.search-history-item:nth-child(6){animation-delay:.22s}.search-history-item:nth-child(7){animation-delay:.26s}.search-history-item:nth-child(8){animation-delay:.3s}.search-suggestion-item{animation:searchFadeIn .25s ease-out both}.search-suggestion-item:nth-child(2){animation-delay:.02s}.search-suggestion-item:nth-child(3){animation-delay:.04s}.search-suggestion-item:nth-child(4){animation-delay:.06s}.search-suggestion-item:nth-child(5){animation-delay:.08s}.search-suggestion-item:nth-child(6){animation-delay:.1s}.search-suggestion-item:nth-child(7){animation-delay:.12s}.search-suggestion-item:nth-child(8){animation-delay:.14s}@media (max-width: 374px){.search-content{padding:var(--spacing-sm)}.hot-tag{padding:var(--spacing-xs) var(--spacing-sm);min-width:64px;border-radius:var(--radius-sm)}.hot-tag-keyword{font-size:var(--font-size-xs)}.hot-tag-count{font-size:10px}.search-input{height:32px;font-size:var(--font-size-xs)}}@media (min-width: 768px){.search-content{max-width:720px;margin:0 auto}.search-top-bar{max-width:720px;margin:0 auto;padding-left:0;padding-right:0}.hot-tags{justify-content:flex-start}}@media (min-width: 1024px){.search-content,.search-top-bar{max-width:960px}}.player-container{width:100vw;height:100vh;display:flex;flex-direction:column;background:var(--color-bg-primary);overflow:hidden;position:relative}.player-container:before{content:"";position:absolute;top:10%;left:50%;transform:translate(-50%);width:80vw;height:60vh;background:radial-gradient(ellipse at center,rgba(124,77,159,.08) 0%,transparent 70%);pointer-events:none;z-index:0}.player-top-bar{width:100%;height:52px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;padding-top:calc(var(--safe-area-top, 0px) + 0px);flex-shrink:0;z-index:10;background:transparent;box-sizing:border-box}.player-back-btn,.player-more-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;font-size:1.25rem;color:var(--color-text-primary);background:#7c4d9f0f;border:1px solid rgba(124,77,159,.1);border-radius:var(--radius-full);cursor:pointer;transition:all .2s ease}.player-back-btn:hover,.player-more-btn:hover{background:#7c4d9f1a;border-color:#7c4d9f33;box-shadow:0 0 16px #7c4d9f26}.player-top-title{font-size:.875rem;color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.player-main{flex:1;display:flex;flex-direction:column;min-height:0;z-index:1;padding:0 24px}.player-left{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:0;padding:8px 16px 4px}.player-canvas-area{width:min(70vw,320px);height:min(70vw,320px);position:relative;overflow:hidden;flex-shrink:0}.player-canvas-area canvas{display:block;width:100%!important;height:100%!important}.player-song-info{text-align:center;margin-top:8px;flex-shrink:0;z-index:1}.player-song-title{font-size:1.125rem;font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1.25;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:320px;font-family:var(--font-family-display)}.player-song-artist{font-size:.8rem;color:var(--color-text-secondary);font-weight:var(--font-weight-normal)}.player-right{flex:1 1 auto;display:flex;flex-direction:column;min-height:0;position:relative;overflow:hidden}.player-lyrics{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;scroll-behavior:smooth;scroll-snap-type:y proximity;padding:40px 24px;position:relative;-webkit-mask-image:linear-gradient(to bottom,transparent 0%,black 12%,black 88%,transparent 100%);mask-image:linear-gradient(to bottom,transparent 0%,black 12%,black 88%,transparent 100%)}.player-lyrics::-webkit-scrollbar{width:0;display:none}.lyric-line{font-size:1rem;color:#1a1a1a33;text-align:center;padding:16px 24px;transition:all .5s cubic-bezier(.25,.1,.25,1);line-height:1.8;cursor:default;border-radius:12px;margin:8px 0;scroll-snap-align:center;font-family:var(--font-family-display)}.lyric-line--played{color:#1a1a1a59}.lyric-line--active{font-size:2.5rem;font-weight:700;color:var(--color-text-primary);text-shadow:0 0 20px rgba(124,77,159,.35),0 0 60px rgba(124,77,159,.15),0 0 100px rgba(179,136,235,.1);letter-spacing:.02em;padding:24px 16px;transform:scale(1.05);scroll-snap-align:center}.player-controls-bar{position:fixed;bottom:0;left:0;right:0;display:flex;flex-direction:row;align-items:center;padding:16px 32px;padding-bottom:calc(var(--safe-area-bottom, 0px) + 16px);z-index:10;background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(124,77,159,.1);gap:24px}.player-progress-wrap{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0}.player-progress-bar{width:100%;height:4px;background:#7c4d9f1a;border-radius:var(--radius-full);cursor:pointer;position:relative;overflow:visible;touch-action:manipulation}.player-progress-fill{height:100%;width:0%;background:var(--color-brand-primary);border-radius:var(--radius-full);transition:width .18s linear;position:relative;box-shadow:0 0 8px #7c4d9f4d}.player-progress-thumb{position:absolute;right:-6px;top:50%;transform:translateY(-50%);width:12px;height:12px;background:var(--color-brand-primary);border-radius:50%;box-shadow:0 0 12px #7c4d9f66,0 0 24px #7c4d9f33;opacity:0;transition:opacity .15s ease;pointer-events:none}.player-progress-bar:hover .player-progress-thumb,.player-progress-bar:active .player-progress-thumb{opacity:1}.player-time-row{display:flex;justify-content:space-between;align-items:center}.player-time-current,.player-time-total{font-size:10px;color:var(--color-text-hint);font-family:var(--font-family-mono);font-variant-numeric:tabular-nums}.player-controls-btns{display:flex;align-items:center;gap:8px;flex-shrink:0}.ctrl-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;font-size:1.125rem;color:var(--color-text-primary);background:#7c4d9f0f;border:1px solid rgba(124,77,159,.1);border-radius:50%;cursor:pointer;transition:all .2s ease;flex-shrink:0;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.ctrl-btn svg{display:block;flex-shrink:0;pointer-events:none}.ctrl-btn:hover{background:#7c4d9f1a;border-color:#7c4d9f33;box-shadow:0 0 20px #7c4d9f26}.ctrl-btn:active{transform:scale(.9)}.ctrl-btn--play{width:56px;height:56px;font-size:1.375rem;color:#fff;background:var(--gradient-primary);border:none;box-shadow:0 0 30px #7c4d9f59,0 0 60px #b388eb33}.ctrl-btn--play:hover{box-shadow:0 0 44px #7c4d9f80,0 0 80px #b388eb4d}.ctrl-btn--play:active{transform:scale(.88);box-shadow:0 0 56px #7c4d9f99,0 0 100px #b388eb59}.ctrl-btn--active{color:var(--color-brand-primary);text-shadow:0 0 8px rgba(124,77,159,.3)}.ctrl-btn--repeat-one{position:relative}.ctrl-btn--repeat-one:after{content:"1";position:absolute;top:-2px;right:-4px;font-size:8px;font-weight:var(--font-weight-bold);color:var(--color-brand-primary);font-family:var(--font-family-mono)}.ctrl-btn[data-action=shuffle]{font-size:1rem}@media (max-width: 767px){.player-top-bar{height:44px;padding:0 16px;padding-top:calc(var(--safe-area-top, 0px) + 0px);background:#ffffffbf;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(124,77,159,.1)}.player-main{padding:0 12px}.player-left{padding:4px 8px 2px}.player-canvas-area{width:min(55vw,240px);height:min(55vw,240px);max-height:240px}.player-song-info{margin-top:4px}.player-song-title{font-size:1rem;max-width:220px}.player-song-artist{font-size:.7rem}.player-right{flex:1;min-height:0}.player-lyrics{padding:24px 12px;-webkit-mask-image:linear-gradient(to bottom,transparent 0%,black 8%,black 92%,transparent 100%);mask-image:linear-gradient(to bottom,transparent 0%,black 8%,black 92%,transparent 100%)}.lyric-line{font-size:.85rem;text-align:center;padding:12px 16px;margin:6px 0}.lyric-line--active{font-size:1.6rem;padding:18px 12px;text-shadow:0 0 14px rgba(124,77,159,.3),0 0 40px rgba(124,77,159,.15),0 0 70px rgba(179,136,235,.1)}.player-controls-bar{flex-direction:column;gap:12px;padding:12px 20px;padding-bottom:calc(var(--safe-area-bottom, 0px) + 12px)}.player-progress-wrap{width:100%}.player-controls-btns{width:100%;justify-content:space-around}.ctrl-btn{width:40px;height:40px;font-size:1rem}.ctrl-btn--play{width:52px;height:52px;font-size:1.25rem}}@media (max-width: 383px){.player-canvas-area{width:min(50vw,180px);height:min(50vw,180px)}.lyric-line--active{font-size:1.35rem}.player-controls-btns{gap:4px}.ctrl-btn{width:36px;height:36px;font-size:.875rem}.ctrl-btn--play{width:46px;height:46px;font-size:1.125rem}}@media (min-width: 768px){.player-main{flex-direction:row;padding:0 32px;gap:24px}.player-left{flex:0 0 38%;padding:24px 8px 12px}.player-right{flex:1 1 62%}.player-canvas-area{width:min(38vw,380px);height:min(38vw,380px)}.player-lyrics{padding:48px 24px}.player-song-title{font-size:1.25rem}.player-song-artist{font-size:.875rem}}@media (min-width: 1200px){.player-main{max-width:900px;margin:0 auto;width:100%}.player-canvas-area{width:340px;height:340px}.player-controls-bar{justify-content:center}.player-progress-wrap{max-width:500px}}.playlist-detail-page{width:100%;min-height:100vh;display:flex;flex-direction:column;position:relative;padding-bottom:calc(var(--safe-area-bottom) + var(--spacing-xl))}.playlist-detail-topbar{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);padding-top:calc(var(--safe-area-top) + var(--spacing-sm));height:56px;background:#ffffffbf;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(124,77,159,.1);position:sticky;top:0;z-index:100;flex-shrink:0}.playlist-detail-back-btn,.playlist-detail-more-btn{display:flex;align-items:center;justify-content:center;width:38px;height:38px;font-size:var(--font-size-xl);color:var(--color-text-primary);border-radius:var(--radius-full);background:#7c4d9f0f;border:1px solid rgba(124,77,159,.1);cursor:pointer;transition:all var(--transition-fast)}.playlist-detail-back-btn:active,.playlist-detail-more-btn:active{background:#7c4d9f1f;transform:scale(.92)}.playlist-detail-topbar-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);letter-spacing:.5px}.playlist-detail-scroll{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding:0 var(--spacing-md)}.playlist-detail-cover-wrap{display:flex;justify-content:center;padding:var(--spacing-lg) 0 var(--spacing-md)}.playlist-detail-cover{width:100%;max-width:320px;aspect-ratio:1 / 1;border-radius:var(--radius-xl);overflow:hidden;background:var(--color-bg-card);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(124,77,159,.1);box-shadow:0 8px 32px #6432821f,0 0 0 1px #7c4d9f0a;position:relative;transition:transform var(--transition-base)}.playlist-detail-cover:after{content:"";position:absolute;top:0;left:10%;right:10%;height:2px;background:linear-gradient(90deg,transparent,rgba(124,77,159,.2),transparent);opacity:.7;pointer-events:none;z-index:2}.playlist-detail-cover img{width:100%;height:100%;object-fit:cover;display:block;z-index:0;position:relative}.playlist-detail-cover-shine{position:absolute;inset:0;background:linear-gradient(135deg,rgba(124,77,159,.1) 0%,transparent 40%,transparent 60%,rgba(179,136,235,.08) 100%);pointer-events:none;z-index:1;border-radius:inherit}.playlist-detail-meta{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:0 0 var(--spacing-md);text-align:center}.playlist-detail-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight);padding:0 var(--spacing-md);font-family:var(--font-family-display)}.playlist-detail-info{font-size:var(--font-size-xs);color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;justify-content:center}.playlist-detail-info-dot{width:3px;height:3px;border-radius:50%;background:var(--color-text-hint);flex-shrink:0}.playlist-detail-actions{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);padding:0 0 var(--spacing-lg)}.playlist-detail-btn-play{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 36px;font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-white);background:var(--gradient-primary);border:none;border-radius:var(--radius-full);cursor:pointer;box-shadow:0 4px 24px #7c4d9f4d;transition:all var(--transition-base);position:relative;overflow:hidden}.playlist-detail-btn-play:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#b388eb,#7c4d9f);opacity:0;transition:opacity var(--transition-base)}.playlist-detail-btn-play:hover:before{opacity:1}.playlist-detail-btn-play span{position:relative;z-index:1}.playlist-detail-btn-play:active{transform:scale(.95);box-shadow:0 2px 12px #7c4d9f66}.playlist-detail-btn-fav{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:12px 28px;font-size:var(--font-size-md);font-weight:var(--font-weight-medium);color:var(--color-text-primary);background:#7c4d9f0f;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(124,77,159,.15);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-base)}.playlist-detail-btn-fav:hover{background:#7c4d9f1a;border-color:#b388eb66;color:var(--color-brand-accent)}.playlist-detail-btn-fav:active{transform:scale(.95)}.playlist-detail-songlist{border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--spacing-xl)}.playlist-detail-songlist-header{display:flex;align-items:center;padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-border-light);font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:var(--font-weight-medium);letter-spacing:.5px}.playlist-detail-songlist-header-idx{width:36px;flex-shrink:0;text-align:center}.playlist-detail-songlist-header-title{flex:1;min-width:0}.playlist-detail-songlist-header-dur{width:52px;flex-shrink:0;text-align:right}.playlist-detail-song{display:flex;align-items:center;padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;transition:all var(--transition-fast);position:relative;border-bottom:1px solid var(--color-border-light)}.playlist-detail-song:last-child{border-bottom:none}.playlist-detail-song:hover{background:#7c4d9f0a}.playlist-detail-song:active{background:#7c4d9f14;transform:scale(.99)}.playlist-detail-song-idx{width:36px;flex-shrink:0;text-align:center;font-size:var(--font-size-sm);color:var(--color-text-hint);font-weight:var(--font-weight-medium);font-family:var(--font-family-mono);font-variant-numeric:tabular-nums}.playlist-detail-song-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.playlist-detail-song-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:var(--line-height-tight)}.playlist-detail-song-artist{font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:var(--line-height-tight)}.playlist-detail-song-dur{width:52px;flex-shrink:0;text-align:right;font-size:var(--font-size-xs);color:var(--color-text-hint);font-family:var(--font-family-mono);font-variant-numeric:tabular-nums}.playlist-detail-song--playing{background:#7c4d9f14;border-radius:var(--radius-sm)}.playlist-detail-song--playing:before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:3px;border-radius:0 3px 3px 0;background:linear-gradient(180deg,#7c4d9f,#b388eb);box-shadow:0 0 10px #7c4d9f4d}.playlist-detail-song--playing .playlist-detail-song-title{color:var(--color-brand-primary)}.playlist-detail-song--playing .playlist-detail-song-artist{color:#7c4d9f99}.playlist-detail-song-playing-indicator{display:none;width:14px;height:14px;position:relative;margin-right:4px}.playlist-detail-song--playing .playlist-detail-song-playing-indicator{display:flex;align-items:flex-end;gap:2px}.playlist-detail-song-playing-indicator span{width:2px;background:var(--color-brand-accent);border-radius:1px;animation:eqBounce .6s ease-in-out infinite alternate}.playlist-detail-song-playing-indicator span:nth-child(1){height:6px;animation-delay:0s}.playlist-detail-song-playing-indicator span:nth-child(2){height:12px;animation-delay:.15s}.playlist-detail-song-playing-indicator span:nth-child(3){height:8px;animation-delay:.3s}@keyframes eqBounce{0%{transform:scaleY(.4)}to{transform:scaleY(1)}}@media (max-width: 374px){.playlist-detail-cover{max-width:260px}.playlist-detail-title{font-size:var(--font-size-xl)}.playlist-detail-scroll{padding:0 var(--spacing-sm)}.playlist-detail-btn-play{padding:10px 28px;font-size:var(--font-size-sm)}.playlist-detail-btn-fav{padding:10px 22px;font-size:var(--font-size-sm)}}@media (max-width: 767px){.playlist-detail-cover{max-width:280px}.playlist-detail-btn-play{padding:11px 32px;font-size:var(--font-size-sm)}.playlist-detail-btn-fav{padding:11px 24px;font-size:var(--font-size-sm)}.playlist-detail-song{padding:var(--spacing-sm) var(--spacing-sm)}.playlist-detail-song-idx{width:30px;font-size:var(--font-size-xs)}.playlist-detail-song-dur{width:44px;font-size:var(--font-size-xs)}}@media (min-width: 768px){.playlist-detail-scroll{max-width:720px;margin:0 auto}.playlist-detail-topbar{max-width:720px;margin:0 auto;left:50%;transform:translate(-50%);width:100%}.playlist-detail-cover{max-width:360px}.playlist-detail-title{font-size:var(--font-size-3xl)}.playlist-detail-song{padding:var(--spacing-md) var(--spacing-md)}.playlist-detail-song-title{font-size:var(--font-size-md)}.playlist-detail-song-artist{font-size:var(--font-size-sm)}.playlist-detail-song-idx{width:42px;font-size:var(--font-size-sm)}.playlist-detail-song-dur{width:56px;font-size:var(--font-size-sm)}.playlist-detail-songlist-header-idx{width:42px}.playlist-detail-songlist-header-dur{width:56px}}@media (min-width: 1024px){.playlist-detail-scroll,.playlist-detail-topbar{max-width:880px}.playlist-detail-page{align-items:center}.playlist-detail-cover{max-width:400px}.playlist-detail-song{padding:var(--spacing-md) var(--spacing-lg)}.playlist-detail-song-title{font-size:var(--font-size-md)}.playlist-detail-song-artist{font-size:var(--font-size-sm)}.playlist-detail-song-idx{width:48px;font-size:var(--font-size-base)}.playlist-detail-song-dur{width:64px;font-size:var(--font-size-sm)}.playlist-detail-songlist-header-idx{width:48px}.playlist-detail-songlist-header-dur{width:64px}.playlist-detail-actions{gap:var(--spacing-lg)}.playlist-detail-btn-play{padding:14px 42px;font-size:var(--font-size-md)}.playlist-detail-btn-fav{padding:14px 32px;font-size:var(--font-size-md)}}.charts-page{width:100%;min-height:100vh;display:flex;flex-direction:column;position:relative;padding-bottom:calc(60px + var(--safe-area-bottom))}.charts-top-bar{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);padding-top:calc(var(--safe-area-top) + var(--spacing-sm));height:56px;background:#ffffffbf;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(124,77,159,.1);position:sticky;top:0;z-index:100;flex-shrink:0}.charts-back-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;font-size:var(--font-size-lg);color:var(--color-text-primary);border-radius:var(--radius-full);flex-shrink:0;transition:background var(--transition-fast);cursor:pointer;border:none;background:none}.charts-back-btn:active{background:#7c4d9f14}.charts-top-title{flex:1;font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--color-text-primary);letter-spacing:.5px}.charts-sub-tabs{display:flex;gap:var(--spacing-sm);padding:var(--spacing-base) var(--spacing-md);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;flex-shrink:0}.charts-sub-tabs::-webkit-scrollbar{display:none}.charts-sub-tab{flex-shrink:0;padding:7px 20px;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;transition:all .3s cubic-bezier(.25,.1,.25,1);white-space:nowrap}.charts-sub-tab:hover{background:#7c4d9f0d;border-color:#7c4d9f33;color:var(--color-text-primary)}.charts-sub-tab.active{color:var(--color-text-white);background:var(--color-brand-primary);border-color:var(--color-brand-primary);box-shadow:0 0 20px #7c4d9f40}.charts-sub-tab:active{transform:scale(.95);transition:transform .1s ease}.charts-scroll{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.chart-section{padding:0 var(--spacing-md) var(--spacing-md)}.chart-section-header{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-base) 0 var(--spacing-sm)}.chart-section-icon{font-size:var(--font-size-lg);display:flex;align-items:center}.chart-section-icon svg{display:block;flex-shrink:0}.chart-section-name{font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--color-text-primary);padding-left:10px;border-left:3px solid var(--color-brand-primary);line-height:1.2}.chart-card{border-radius:var(--radius-md);overflow:hidden;animation:chartCardIn .45s ease-out both;background:var(--color-bg-card);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light)}.chart-card:nth-child(1){animation-delay:.05s}.chart-card:nth-child(2){animation-delay:.15s}.chart-card:nth-child(3){animation-delay:.25s}@keyframes chartCardIn{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.chart-song-row{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-base);cursor:pointer;transition:background var(--transition-fast);border-radius:var(--radius-sm)}.chart-song-row:hover{background:#7c4d9f0a}.chart-song-row:active{background:#7c4d9f14;transform:scale(.99)}.chart-song-row+.chart-song-row{border-top:1px solid var(--color-border-light)}.chart-song-rank{width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);flex-shrink:0;font-variant-numeric:tabular-nums}.chart-song-rank--gold{color:#c9a84c;font-size:var(--font-size-lg);text-shadow:0 0 12px rgba(201,168,76,.4)}.chart-song-rank--silver{color:#90a4ae;font-size:var(--font-size-lg);text-shadow:0 0 12px rgba(144,164,174,.4)}.chart-song-rank--bronze{color:#d4855e;font-size:var(--font-size-lg);text-shadow:0 0 12px rgba(212,133,94,.4)}.chart-song-cover{width:44px;height:44px;border-radius:8px;overflow:hidden;flex-shrink:0;background:linear-gradient(135deg,#d4c4e8,#ede4f5)}.chart-song-cover img{width:100%;height:100%;object-fit:cover;display:block}.chart-song-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.chart-song-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chart-song-artist{font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chart-song-trend{font-size:var(--font-size-base);flex-shrink:0;width:24px;text-align:center}.chart-song-trend--up{color:#5cbfb5}.chart-song-trend--down{color:#d4556e}.chart-song-trend--same{color:var(--color-text-hint)}.charts-bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:stretch;justify-content:space-around;background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(124,77,159,.1);z-index:200;padding-bottom:var(--safe-area-bottom)}.charts-bottom-nav .bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:7px 0 5px;min-height:50px;cursor:pointer;position:relative;color:var(--color-text-secondary);transition:color .25s cubic-bezier(.25,.1,.25,1)}.charts-bottom-nav .bottom-nav-item.active{color:var(--color-brand-primary)}.charts-bottom-nav .bottom-nav-item.active:before{content:"";position:absolute;top:0;left:30%;right:30%;height:3px;background:var(--color-brand-primary);border-radius:0 0 3px 3px;box-shadow:0 0 12px #7c4d9f4d}.charts-bottom-nav .bottom-nav-item:active{opacity:.6}@media (max-width: 374px){.charts-sub-tabs{padding:var(--spacing-sm) var(--spacing-sm)}.chart-section{padding:0 var(--spacing-sm) var(--spacing-sm)}.chart-song-rank{width:24px;height:24px;font-size:var(--font-size-xs)}.chart-song-cover{width:38px;height:38px;border-radius:6px}}@media (min-width: 768px){.charts-scroll,.charts-top-bar,.charts-sub-tabs{max-width:720px;margin:0 auto}.charts-bottom-nav{max-width:720px;left:50%;transform:translate(-50%)}}@media (min-width: 1024px){.charts-page{align-items:center}.charts-scroll,.charts-top-bar,.charts-sub-tabs,.charts-bottom-nav{max-width:960px}.charts-scroll{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);align-content:start}.chart-section{padding:0}.chart-song-cover{width:48px;height:48px}}.radio-page{width:100%;min-height:100vh;display:flex;flex-direction:column;position:relative;padding-bottom:calc(60px + var(--safe-area-bottom))}.radio-top-bar{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);padding-top:calc(var(--safe-area-top) + var(--spacing-sm));height:56px;background:#ffffffbf;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(124,77,159,.1);position:sticky;top:0;z-index:100;flex-shrink:0}.radio-back-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;font-size:var(--font-size-lg);color:var(--color-text-primary);border-radius:var(--radius-full);flex-shrink:0;transition:background var(--transition-fast);cursor:pointer;border:none;background:none}.radio-back-btn:active{background:#7c4d9f14}.radio-top-title{flex:1;font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--color-text-primary);letter-spacing:.5px}.radio-scroll{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.radio-live-banner{margin:var(--spacing-md);border-radius:var(--radius-lg);padding:var(--spacing-lg);position:relative;overflow:hidden;cursor:pointer;background:linear-gradient(135deg,#d4556e1a,#d4556e0f);border:1px solid rgba(212,85,110,.2);transition:all .4s cubic-bezier(.25,.1,.25,1);animation:radioBannerIn .5s ease-out both}.radio-live-banner:hover{border-color:#d4556e66;box-shadow:0 0 48px #d4556e26;transform:translateY(-2px)}.radio-live-banner:active{transform:scale(.98)}@keyframes radioBannerIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.radio-live-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.radio-live-dot{width:10px;height:10px;border-radius:50%;background:#d4556e;box-shadow:0 0 12px #d4556e80,0 0 24px #d4556e40;animation:radioPulse 1.5s ease-in-out infinite}@keyframes radioPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.6);opacity:.5;box-shadow:0 0 24px #d4556eb3,0 0 48px #d4556e66}}.radio-live-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:#d4556e;text-transform:uppercase;letter-spacing:1px}.radio-live-dj{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:4px}.radio-live-subtitle{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.radio-live-listeners{display:inline-flex;align-items:center;gap:4px;margin-top:var(--spacing-sm);font-size:var(--font-size-xs);color:var(--color-text-hint);background:#7c4d9f0f;border:1px solid rgba(124,77,159,.1);border-radius:var(--radius-full);padding:4px 12px}.radio-section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-md) var(--spacing-sm);flex-shrink:0}.radio-section-title{font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--color-text-primary);padding-left:10px;border-left:3px solid var(--color-brand-primary);line-height:1.2;letter-spacing:.5px}.radio-section-more{font-size:var(--font-size-xs);color:var(--color-text-hint);display:flex;align-items:center;gap:2px;cursor:pointer;padding:6px 4px;border-radius:var(--radius-full);transition:color var(--transition-fast)}.radio-section-more:hover{color:var(--color-brand-primary)}.radio-section-more:active{color:var(--color-brand-secondary)}.radio-dj-scroll{display:flex;gap:var(--spacing-sm);padding:0 var(--spacing-md) var(--spacing-md);overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;scroll-snap-type:x proximity}.radio-dj-scroll::-webkit-scrollbar{display:none}.radio-dj-card{flex-shrink:0;width:130px;display:flex;flex-direction:column;align-items:center;gap:8px;padding:var(--spacing-base);cursor:pointer;scroll-snap-align:start;border-radius:var(--radius-md);transition:all .3s cubic-bezier(.25,.1,.25,1);animation:radioCardIn .4s ease-out both;background:var(--color-bg-card);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light)}.radio-dj-card:nth-child(1){animation-delay:.2s}.radio-dj-card:nth-child(2){animation-delay:.26s}.radio-dj-card:nth-child(3){animation-delay:.32s}.radio-dj-card:nth-child(4){animation-delay:.38s}.radio-dj-card:nth-child(5){animation-delay:.44s}.radio-dj-card:nth-child(6){animation-delay:.5s}.radio-dj-card:nth-child(7){animation-delay:.56s}.radio-dj-card:nth-child(8){animation-delay:.62s}@keyframes radioCardIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.radio-dj-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.radio-dj-card:active{transform:scale(.95)}.radio-dj-avatar{width:76px;height:76px;border-radius:50%;overflow:hidden;background:linear-gradient(135deg,#d4c4e8,#b388eb);border:2px solid rgba(124,77,159,.15);position:relative}.radio-dj-avatar img{width:100%;height:100%;object-fit:cover;display:block}.radio-dj-avatar-live{position:absolute;bottom:1px;right:1px;width:16px;height:16px;border-radius:50%;background:#d4556e;border:2px solid rgba(255,255,255,.9);box-shadow:0 0 8px #d4556e66}.radio-dj-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.radio-dj-desc{font-size:var(--font-size-xs);color:var(--color-text-hint);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.radio-program-list{display:flex;flex-direction:column;gap:2px;padding:0 var(--spacing-md) var(--spacing-lg)}.radio-program-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-base);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);animation:radioProgramIn .35s ease-out both}.radio-program-item:nth-child(1){animation-delay:.35s}.radio-program-item:nth-child(2){animation-delay:.4s}.radio-program-item:nth-child(3){animation-delay:.45s}.radio-program-item:nth-child(4){animation-delay:.5s}.radio-program-item:nth-child(5){animation-delay:.55s}.radio-program-item:nth-child(6){animation-delay:.6s}@keyframes radioProgramIn{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.radio-program-item:hover{background:#7c4d9f0a}.radio-program-item:active{background:#7c4d9f14;transform:scale(.99)}.radio-program-item+.radio-program-item{border-top:1px solid var(--color-border-light)}.radio-program-cover{width:48px;height:48px;border-radius:10px;overflow:hidden;flex-shrink:0;background:linear-gradient(135deg,#d4c4e8,#ede4f5)}.radio-program-cover img{width:100%;height:100%;object-fit:cover;display:block}.radio-program-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.radio-program-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.radio-program-meta{font-size:var(--font-size-xs);color:var(--color-text-hint);display:flex;align-items:center;gap:6px}.radio-program-duration{font-size:var(--font-size-xs);color:var(--color-text-hint);flex-shrink:0;font-variant-numeric:tabular-nums}.radio-bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:stretch;justify-content:space-around;background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(124,77,159,.1);z-index:200;padding-bottom:var(--safe-area-bottom)}.radio-bottom-nav .bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:7px 0 5px;min-height:50px;cursor:pointer;position:relative;color:var(--color-text-secondary);transition:color .25s cubic-bezier(.25,.1,.25,1)}.radio-bottom-nav .bottom-nav-item.active{color:var(--color-brand-primary)}.radio-bottom-nav .bottom-nav-item.active:before{content:"";position:absolute;top:0;left:30%;right:30%;height:3px;background:var(--color-brand-primary);border-radius:0 0 3px 3px;box-shadow:0 0 12px #7c4d9f4d}.radio-bottom-nav .bottom-nav-item:active{opacity:.6}@media (max-width: 374px){.radio-dj-card{width:110px}.radio-dj-avatar{width:62px;height:62px}.radio-live-banner{margin:var(--spacing-sm);padding:var(--spacing-md)}.radio-program-cover{width:42px;height:42px}}@media (min-width: 768px){.radio-scroll,.radio-top-bar{max-width:720px;margin:0 auto}.radio-bottom-nav{max-width:720px;left:50%;transform:translate(-50%)}}@media (min-width: 1024px){.radio-page{align-items:center}.radio-scroll,.radio-top-bar,.radio-bottom-nav{max-width:960px}.radio-live-banner{padding:var(--spacing-xl)}.radio-dj-card{width:150px}.radio-dj-avatar{width:88px;height:88px}.radio-program-cover{width:56px;height:56px}}.podcast-page{width:100%;min-height:100vh;display:flex;flex-direction:column;position:relative;padding-bottom:calc(60px + var(--safe-area-bottom))}.podcast-top-bar{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);padding-top:calc(var(--safe-area-top) + var(--spacing-sm));height:56px;background:#ffffffbf;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(124,77,159,.1);position:sticky;top:0;z-index:100;flex-shrink:0}.podcast-menu-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;font-size:var(--font-size-lg);color:var(--color-text-primary);border-radius:var(--radius-full);flex-shrink:0;transition:background var(--transition-fast);cursor:pointer;border:none;background:none}.podcast-menu-btn:active{background:#7c4d9f14}.podcast-top-title{flex:1;font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--color-text-primary);letter-spacing:.5px}.podcast-scroll{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.podcast-daily-banner{margin:var(--spacing-md);border-radius:var(--radius-lg);overflow:hidden;position:relative;height:170px;background:linear-gradient(135deg,#7c4d9f,#b388eb);box-shadow:0 8px 40px #7c4d9f33,0 0 0 1px #7c4d9f14;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-base);animation:podcastBannerIn .5s ease-out both}@keyframes podcastBannerIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.podcast-daily-banner:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%,rgba(124,77,159,.2) 60%,rgba(124,77,159,.6) 100%);z-index:1;pointer-events:none}.podcast-daily-banner:hover{transform:translateY(-2px);box-shadow:0 12px 48px #7c4d9f40,0 0 0 1px #7c4d9f26}.podcast-daily-banner:active{transform:scale(.98)}.podcast-daily-banner-img{width:100%;height:100%;object-fit:cover;display:block;position:absolute;top:0;left:0;z-index:0}.podcast-daily-banner-overlay{position:absolute;bottom:0;left:0;right:0;padding:var(--spacing-md);display:flex;flex-direction:column;gap:4px;z-index:2}.podcast-daily-banner-tag{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:var(--font-weight-medium);color:var(--color-text-white);background:#ffffff26;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-full);padding:2px 12px;width:fit-content;white-space:nowrap;position:absolute;top:var(--spacing-md);right:var(--spacing-md);z-index:3;letter-spacing:.5px}.podcast-daily-banner-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-white);line-height:var(--line-height-tight);text-shadow:0 2px 8px rgba(0,0,0,.2)}.podcast-daily-banner-sub{font-size:var(--font-size-xs);color:#ffffffd9;text-shadow:0 1px 4px rgba(0,0,0,.15)}.podcast-section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-md) var(--spacing-sm);flex-shrink:0}.podcast-section-title{font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--color-text-primary);padding-left:10px;border-left:3px solid var(--color-brand-accent);line-height:1.2;letter-spacing:.5px}.podcast-section-more{font-size:var(--font-size-xs);color:var(--color-text-hint);display:flex;align-items:center;gap:2px;cursor:pointer;padding:6px 4px;border-radius:var(--radius-full);transition:color var(--transition-fast)}.podcast-section-more:hover{color:var(--color-brand-primary)}.podcast-section-more:active{color:var(--color-brand-secondary)}.podcast-sub-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm);padding:0 var(--spacing-md) var(--spacing-md)}.podcast-sub-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:var(--spacing-sm);cursor:pointer;border-radius:var(--radius-md);transition:all .3s cubic-bezier(.25,.1,.25,1);animation:podcastSubIn .4s ease-out both;background:var(--color-bg-card);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light)}.podcast-sub-card:nth-child(1){animation-delay:.2s}.podcast-sub-card:nth-child(2){animation-delay:.26s}.podcast-sub-card:nth-child(3){animation-delay:.32s}.podcast-sub-card:nth-child(4){animation-delay:.38s}.podcast-sub-card:nth-child(5){animation-delay:.44s}.podcast-sub-card:nth-child(6){animation-delay:.5s}@keyframes podcastSubIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.podcast-sub-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.podcast-sub-card:active{transform:scale(.95)}.podcast-sub-cover{width:80px;height:80px;border-radius:16px;overflow:hidden;background:linear-gradient(135deg,#d4c4e8,#ede4f5);position:relative}.podcast-sub-cover img{width:100%;height:100%;object-fit:cover;display:block}.podcast-sub-name{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-primary);text-align:center;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:var(--line-height-tight)}.podcast-sub-status{font-size:10px;color:var(--color-text-hint);font-weight:var(--font-weight-normal)}.podcast-sub-status--live{color:#5cbfb5}.podcast-sub-status--updated{color:var(--color-brand-accent)}.podcast-episode-list{display:flex;flex-direction:column;gap:2px;padding:0 var(--spacing-md) var(--spacing-lg)}.podcast-episode-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-base);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);animation:podcastEpisodeIn .35s ease-out both}.podcast-episode-item:nth-child(1){animation-delay:.35s}.podcast-episode-item:nth-child(2){animation-delay:.4s}.podcast-episode-item:nth-child(3){animation-delay:.45s}.podcast-episode-item:nth-child(4){animation-delay:.5s}.podcast-episode-item:nth-child(5){animation-delay:.55s}.podcast-episode-item:nth-child(6){animation-delay:.6s}.podcast-episode-item:nth-child(7){animation-delay:.65s}.podcast-episode-item:nth-child(8){animation-delay:.7s}@keyframes podcastEpisodeIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.podcast-episode-item:hover{background:#7c4d9f0a}.podcast-episode-item:active{background:#7c4d9f14;transform:scale(.99)}.podcast-episode-item+.podcast-episode-item{border-top:1px solid var(--color-border-light)}.podcast-episode-cover{width:48px;height:48px;border-radius:10px;overflow:hidden;flex-shrink:0;background:linear-gradient(135deg,#d4c4e8,#ede4f5)}.podcast-episode-cover img{width:100%;height:100%;object-fit:cover;display:block}.podcast-episode-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.podcast-episode-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.podcast-episode-show{font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.podcast-episode-duration{font-size:var(--font-size-xs);color:var(--color-text-hint);flex-shrink:0;font-variant-numeric:tabular-nums;margin-left:var(--spacing-sm)}.podcast-episode-play{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:#7c4d9f1f;color:var(--color-brand-primary);font-size:var(--font-size-sm);flex-shrink:0;transition:all var(--transition-fast);cursor:pointer;border:none}.podcast-episode-play:hover{background:#7c4d9f33;box-shadow:0 0 16px #7c4d9f33}.podcast-episode-play:active{transform:scale(.9)}.podcast-bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:stretch;justify-content:space-around;background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(124,77,159,.1);z-index:200;padding-bottom:var(--safe-area-bottom)}.podcast-bottom-nav .bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:7px 0 5px;min-height:50px;cursor:pointer;position:relative;color:var(--color-text-secondary);transition:color .25s cubic-bezier(.25,.1,.25,1)}.podcast-bottom-nav .bottom-nav-item.active{color:var(--color-brand-primary)}.podcast-bottom-nav .bottom-nav-item.active:before{content:"";position:absolute;top:0;left:30%;right:30%;height:3px;background:var(--color-brand-primary);border-radius:0 0 3px 3px;box-shadow:0 0 12px #7c4d9f4d}.podcast-bottom-nav .bottom-nav-item:active{opacity:.6}@media (max-width: 374px){.podcast-sub-cover{width:64px;height:64px;border-radius:12px}.podcast-daily-banner{margin:var(--spacing-sm);height:140px}.podcast-episode-cover{width:42px;height:42px}}@media (min-width: 768px){.podcast-page{align-items:center}.podcast-scroll,.podcast-top-bar{max-width:720px;margin:0 auto;width:100%}.podcast-bottom-nav{max-width:720px;left:50%;transform:translate(-50%)}.podcast-sub-grid{grid-template-columns:repeat(3,1fr)}.podcast-sub-cover{width:100px;height:100px}.podcast-daily-banner{height:210px}.podcast-episode-item{padding:12px var(--spacing-md)}.podcast-episode-cover{width:56px;height:56px}}@media (min-width: 1024px){.podcast-scroll,.podcast-top-bar,.podcast-bottom-nav{max-width:960px}.podcast-sub-grid{grid-template-columns:repeat(4,1fr)}.podcast-daily-banner{height:250px}.podcast-episode-cover{width:64px;height:64px}}.discover-page{width:100%;min-height:100vh;display:flex;flex-direction:column;position:relative;padding-bottom:calc(60px + var(--safe-area-bottom))}@keyframes discoverFadeIn{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.discover-banner{animation:discoverFadeIn .6s ease-out .02s both}.topic-tags{animation:discoverFadeIn .4s ease-out .1s both}.mv-scroll-card{animation:discoverFadeIn .5s ease-out both}.mv-scroll-card:nth-child(1){animation-delay:.05s}.mv-scroll-card:nth-child(2){animation-delay:.1s}.mv-scroll-card:nth-child(3){animation-delay:.15s}.mv-scroll-card:nth-child(4){animation-delay:.2s}.mv-scroll-card:nth-child(5){animation-delay:.25s}.mv-scroll-card:nth-child(6){animation-delay:.3s}.new-song-item{animation:discoverFadeIn .4s ease-out both}.new-song-item:nth-child(1){animation-delay:.05s}.new-song-item:nth-child(2){animation-delay:.1s}.new-song-item:nth-child(3){animation-delay:.15s}.new-song-item:nth-child(4){animation-delay:.2s}.new-song-item:nth-child(5){animation-delay:.25s}.new-song-item:nth-child(6){animation-delay:.3s}.new-song-item:nth-child(7){animation-delay:.35s}.new-song-item:nth-child(8){animation-delay:.4s}.playlist-grid-card{animation:discoverFadeIn .5s ease-out both}.playlist-grid-card:nth-child(1){animation-delay:.05s}.playlist-grid-card:nth-child(2){animation-delay:.1s}.playlist-grid-card:nth-child(3){animation-delay:.15s}.playlist-grid-card:nth-child(4){animation-delay:.2s}.playlist-grid-card:nth-child(5){animation-delay:.25s}.playlist-grid-card:nth-child(6){animation-delay:.3s}.discover-section-header{animation:discoverFadeIn .4s ease-out both}.discover-top-bar{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);padding-top:calc(var(--safe-area-top) + var(--spacing-sm));height:56px;background:#ffffffbf;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(124,77,159,.1);position:sticky;top:0;z-index:100;flex-shrink:0}.discover-top-bar-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;font-size:var(--font-size-lg);color:var(--color-text-primary);border-radius:var(--radius-full);transition:background var(--transition-fast)}.discover-top-bar-btn:active{background:#7c4d9f14}.discover-search-btn--large{flex:1;max-width:480px;width:auto;height:40px;margin:0 var(--spacing-md);border-radius:var(--radius-full);background:#7c4d9f0f;border:1px solid rgba(124,77,159,.12);justify-content:flex-start;padding:0 var(--spacing-md);gap:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-text-hint)}.discover-search-btn--large:active{background:#7c4d9f1f}.discover-scroll{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.discover-banner{margin:var(--spacing-md);border-radius:20px;overflow:hidden;position:relative;height:200px;background:linear-gradient(135deg,#7c4d9f,#b388eb);box-shadow:0 8px 40px #7c4d9f33,0 0 0 1px #7c4d9f14;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-base)}.discover-banner:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#7c4d9f80,#b388eb40,#7c4d9f99);z-index:1;pointer-events:none}.discover-banner:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%,rgba(124,77,159,.3) 60%,rgba(124,77,159,.7) 100%);z-index:1;pointer-events:none}.discover-banner:hover{transform:translateY(-2px);box-shadow:0 12px 48px #7c4d9f4d,0 0 0 1px #7c4d9f26}.discover-banner:active{transform:scale(.98)}.discover-banner-img{width:100%;height:100%;object-fit:cover;display:block;position:absolute;top:0;left:0;z-index:0}.discover-banner-overlay{position:absolute;bottom:0;left:0;right:0;padding:var(--spacing-lg) var(--spacing-md) var(--spacing-md);display:flex;flex-direction:column;gap:6px;z-index:2}.discover-banner-icon{font-size:var(--font-size-2xl);margin-bottom:2px;display:flex;align-items:center}.discover-banner-icon svg{display:block}.discover-banner-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-white);line-height:var(--line-height-tight);text-shadow:0 2px 8px rgba(0,0,0,.2)}.discover-banner-sub{font-size:var(--font-size-sm);color:#ffffffd9;text-shadow:0 1px 4px rgba(0,0,0,.15)}.discover-banner-tag{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:var(--font-weight-medium);color:var(--color-text-white);background:#b388eb4d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(179,136,235,.3);border-radius:var(--radius-full);padding:2px 12px;width:fit-content;white-space:nowrap;position:absolute;top:var(--spacing-md);right:var(--spacing-md);z-index:3;letter-spacing:.5px}.discover-section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-md) var(--spacing-sm);flex-shrink:0}.discover-section-title{font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--color-text-primary);padding-left:10px;border-left:3px solid var(--color-brand-accent);line-height:1.2;letter-spacing:.5px}.discover-section-more{font-size:var(--font-size-xs);color:var(--color-text-hint);display:flex;align-items:center;gap:2px;cursor:pointer;padding:6px 4px;border-radius:var(--radius-full);transition:color var(--transition-fast)}.discover-section-more:hover{color:var(--color-brand-primary)}.discover-section-more:active{color:var(--color-brand-secondary)}.topic-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);padding:0 var(--spacing-md) var(--spacing-base);flex-shrink:0}.topic-tag{flex-shrink:0;padding:8px 18px;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:var(--color-bg-card);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;transition:all .3s cubic-bezier(.25,.1,.25,1);white-space:nowrap;position:relative;overflow:hidden}.topic-tag:before{content:"";position:absolute;inset:0;border-radius:inherit;opacity:0;transition:opacity .3s ease;pointer-events:none;z-index:-1}.topic-tag:hover{background:#7c4d9f0d;border-color:#7c4d9f33;color:var(--color-text-primary);transform:translateY(-2px);box-shadow:0 4px 16px #7c4d9f1a}.topic-tag:hover:before{opacity:1;background:radial-gradient(circle at 30% 30%,rgba(124,77,159,.1),transparent 70%)}.topic-tag:active{transform:scale(.95);transition:transform .1s ease}.topic-tag:nth-child(1){border-color:#7c4d9f33}.topic-tag:nth-child(2){border-color:#e87da033}.topic-tag:nth-child(3){border-color:#5cbfb533}.topic-tag:nth-child(4){border-color:#7eb8da33}.topic-tag:nth-child(5){border-color:#c9a84c33}.topic-tag:nth-child(6){border-color:#9c7fbf33}.topic-tag:nth-child(7){border-color:#d4556e33}.topic-tag:nth-child(8){border-color:#7c4d9f33}.mv-scroll{display:flex;gap:var(--spacing-sm);padding:0 var(--spacing-md) var(--spacing-base);overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;scroll-snap-type:x proximity}.mv-scroll::-webkit-scrollbar{display:none}.mv-scroll-card{flex-shrink:0;width:200px;display:flex;flex-direction:column;gap:8px;cursor:pointer;scroll-snap-align:start;padding:var(--spacing-sm);border-radius:14px;opacity:0;background:var(--color-bg-card);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light)}.mv-scroll-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.mv-scroll-card:active{transform:scale(.95)}.mv-scroll-cover{width:100%;aspect-ratio:16 / 9;border-radius:10px;overflow:hidden;background:linear-gradient(135deg,#d4c4e8,#ede4f5);position:relative;transition:transform .4s cubic-bezier(.25,.1,.25,1)}.mv-scroll-card:hover .mv-scroll-cover{transform:scale(1.03)}.mv-scroll-cover img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s cubic-bezier(.25,.1,.25,1)}.mv-scroll-card:hover .mv-scroll-cover img{transform:scale(1.06)}.mv-scroll-play-btn{position:absolute;bottom:8px;left:8px;width:32px;height:32px;border-radius:var(--radius-full);background:#7c4d9fcc;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--color-text-white);z-index:2;transition:all var(--transition-fast)}.mv-scroll-card:hover .mv-scroll-play-btn{background:var(--color-brand-primary);box-shadow:0 0 20px #7c4d9f59;transform:scale(1.1)}.mv-scroll-info{display:flex;flex-direction:column;gap:2px}.mv-scroll-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:var(--line-height-tight)}.mv-scroll-artist{font-size:10px;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.new-song-list{display:flex;flex-direction:column;gap:2px;padding:0 var(--spacing-md) var(--spacing-md)}.new-song-list-card{padding:var(--spacing-sm);border-radius:12px}.new-song-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:10px var(--spacing-sm);cursor:pointer;border-radius:10px;transition:all .3s cubic-bezier(.25,.1,.25,1)}.new-song-item:hover{background:#7c4d9f0a}.new-song-item:active{background:#7c4d9f14;transform:scale(.98)}.new-song-index{width:24px;text-align:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);flex-shrink:0}.new-song-item:nth-child(1) .new-song-index,.new-song-item:nth-child(2) .new-song-index,.new-song-item:nth-child(3) .new-song-index{color:var(--color-brand-accent)}.new-song-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.new-song-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.new-song-artist{font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.new-song-play-btn{width:32px;height:32px;border-radius:var(--radius-full);background:#7c4d9f0f;border:1px solid rgba(124,77,159,.1);display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;transition:all var(--transition-fast);color:var(--color-text-secondary)}.new-song-item:hover .new-song-play-btn{background:#7c4d9f26;border-color:#7c4d9f4d;color:var(--color-brand-primary);box-shadow:0 0 12px #7c4d9f26}.playlist-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm);padding:0 var(--spacing-md) var(--spacing-md)}.playlist-grid-card{display:flex;flex-direction:column;gap:6px;cursor:pointer;padding:var(--spacing-sm);border-radius:14px;opacity:0;background:var(--color-bg-card);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light)}.playlist-grid-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.playlist-grid-card:active{transform:scale(.95)}.playlist-grid-cover{width:100%;aspect-ratio:1 / 1;border-radius:10px;overflow:hidden;background:linear-gradient(135deg,#d4c4e8,#ede4f5);position:relative;transition:transform .4s cubic-bezier(.25,.1,.25,1)}.playlist-grid-card:hover .playlist-grid-cover{transform:scale(1.05)}.playlist-grid-cover img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s cubic-bezier(.25,.1,.25,1)}.playlist-grid-card:hover .playlist-grid-cover img{transform:scale(1.08)}.playlist-grid-playcount{position:absolute;top:6px;right:6px;font-size:10px;color:var(--color-text-white);background:#00000073;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-full);padding:2px 8px;white-space:nowrap;z-index:2;font-weight:var(--font-weight-medium)}.playlist-grid-title{font-size:var(--font-size-xs);color:var(--color-text-primary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:var(--line-height-tight);padding:0 2px;font-weight:var(--font-weight-medium)}.playlist-grid-plays{font-size:10px;color:var(--color-text-hint);padding:0 2px;display:flex;align-items:center;gap:3px}.discover-bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:stretch;justify-content:space-around;background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(124,77,159,.1);z-index:200;padding-bottom:var(--safe-area-bottom)}.discover-bottom-nav .bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:7px 0 5px;min-height:50px;cursor:pointer;position:relative;color:var(--color-text-secondary);transition:color .25s cubic-bezier(.25,.1,.25,1)}.discover-bottom-nav .bottom-nav-item.active{color:var(--color-brand-primary)}.discover-bottom-nav .bottom-nav-item.active:before{content:"";position:absolute;top:0;left:30%;right:30%;height:3px;background:var(--color-brand-primary);border-radius:0 0 3px 3px;box-shadow:0 0 12px #7c4d9f4d}.discover-bottom-nav .bottom-nav-item:active{opacity:.6}.discover-bottom-nav .bottom-nav-icon-wrap{position:relative;display:flex;align-items:center;justify-content:center;width:24px;height:24px}.discover-bottom-nav .bottom-nav-dot{position:absolute;top:-1px;right:-5px;width:7px;height:7px;border-radius:var(--radius-full);background:var(--color-brand-primary);box-shadow:0 0 8px #7c4d9f4d;opacity:0;transform:scale(0);transition:opacity .25s cubic-bezier(.25,.1,.25,1),transform .25s cubic-bezier(.25,.1,.25,1)}.discover-bottom-nav .bottom-nav-item.active .bottom-nav-dot{opacity:1;transform:scale(1)}.discover-bottom-nav .bottom-nav-icon{flex-shrink:0}.discover-bottom-nav .bottom-nav-label{font-size:10px;font-weight:var(--font-weight-medium);line-height:1}@media (max-width: 374px){.discover-banner{margin:var(--spacing-sm);height:160px}.discover-section-header{padding:var(--spacing-sm) var(--spacing-sm) var(--spacing-xs)}.topic-tags{padding:0 var(--spacing-sm) var(--spacing-xs)}.topic-tag{padding:6px 14px;font-size:var(--font-size-xs)}.mv-scroll{padding:0 var(--spacing-sm) var(--spacing-xs)}.mv-scroll-card{width:160px}.new-song-list{padding:0 var(--spacing-sm) var(--spacing-sm)}.playlist-grid{grid-template-columns:repeat(2,1fr);padding:0 var(--spacing-sm) var(--spacing-sm)}.new-song-item{padding:8px var(--spacing-xs)}}@media (min-width: 768px){.discover-banner{max-width:720px;margin-left:auto;margin-right:auto;height:240px}.discover-scroll,.discover-top-bar{max-width:720px;margin:0 auto}.discover-bottom-nav{max-width:720px;left:50%;transform:translate(-50%)}.mv-scroll-card{width:240px}.playlist-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1024px){.discover-page{align-items:center}.discover-scroll,.discover-top-bar,.discover-bottom-nav{max-width:960px}.mv-scroll-card{width:260px}.playlist-grid{grid-template-columns:repeat(4,1fr)}.discover-banner{height:280px}}.discover-song-item{transition:all .4s cubic-bezier(.25,.1,.25,1);transform:scale(.92);opacity:.5}.discover-song-item.in-view{transform:scale(1);opacity:1}.discover-playlist-card{transition:all .4s cubic-bezier(.25,.1,.25,1);transform:scale(.95);opacity:.6}.discover-playlist-card.in-view{transform:scale(1.05);opacity:1}.topic-tag-scroll-reveal{transition:all .35s cubic-bezier(.25,.1,.25,1);transform:scale(.85);opacity:.4}.topic-tag-scroll-reveal.in-view{transform:scale(1);opacity:1}.profile-page{width:100%;min-height:100vh;display:flex;flex-direction:column;position:relative;padding-bottom:calc(60px + var(--safe-area-bottom))}@keyframes profileCardFadeIn{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.profile-user-card{animation:profileCardFadeIn .5s ease-out .05s both}.profile-quick-entry{animation:profileCardFadeIn .5s ease-out .12s both}.profile-playlist-grid-item{animation:profileCardFadeIn .5s ease-out both}.profile-playlist-grid-item:nth-child(1){animation-delay:.18s}.profile-playlist-grid-item:nth-child(2){animation-delay:.22s}.profile-playlist-grid-item:nth-child(3){animation-delay:.26s}.profile-playlist-grid-item:nth-child(4){animation-delay:.3s}.profile-recent-card{animation:profileCardFadeIn .5s ease-out .34s both}.profile-topbar{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);padding-top:calc(var(--safe-area-top) + var(--spacing-sm));height:56px;background:#ffffffbf;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(124,77,159,.1);position:sticky;top:0;z-index:100;flex-shrink:0}.profile-topbar-btn{display:flex;align-items:center;justify-content:center;width:38px;height:38px;font-size:var(--font-size-xl);color:var(--color-text-primary);border-radius:var(--radius-full);background:#7c4d9f0f;border:1px solid rgba(124,77,159,.1);cursor:pointer;transition:all var(--transition-fast)}.profile-topbar-btn:active{background:#7c4d9f1f;transform:scale(.92)}.profile-scroll{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding:0 var(--spacing-md);padding-top:var(--spacing-md)}.profile-user-card{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xl) var(--spacing-md);margin-bottom:var(--spacing-md);border-radius:var(--radius-lg)}.profile-avatar-wrap{position:relative;width:84px;height:84px;border-radius:50%;padding:3px;background:linear-gradient(135deg,#7c4d9f,#b388eb,#e87da0);z-index:0}.profile-avatar-wrap:before{content:"";position:absolute;inset:0;border-radius:50%;padding:3px;background:linear-gradient(135deg,#7c4d9f,#b388eb,#e87da0);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;z-index:2}.profile-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block;position:relative;z-index:1}.profile-avatar-glow{position:absolute;inset:-8px;border-radius:50%;background:transparent;box-shadow:0 0 30px #7c4d9f4d,0 0 60px #7c4d9f26;pointer-events:none;z-index:0}.profile-username{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);letter-spacing:.5px;margin-top:var(--spacing-xs);font-family:var(--font-family-display)}.profile-stats{display:flex;align-items:center;gap:var(--spacing-base);font-size:var(--font-size-xs);color:var(--color-text-secondary)}.profile-stats-dot{width:3px;height:3px;border-radius:50%;background:var(--color-text-hint);flex-shrink:0}.profile-stats-highlight{color:var(--color-brand-primary);font-weight:var(--font-weight-semibold)}.profile-quick-entry{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.profile-quick-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-md) var(--spacing-sm);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);min-height:72px}.profile-quick-item:hover{transform:translateY(-2px);box-shadow:0 8px 32px #7c4d9f26,0 0 0 1px #7c4d9f1a}.profile-quick-item:active{transform:scale(.95);transition:transform .1s ease}.profile-quick-icon{font-size:var(--font-size-2xl);line-height:1;position:relative;z-index:1;display:flex;align-items:center;justify-content:center}.profile-quick-icon svg{display:block;flex-shrink:0}.profile-quick-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);letter-spacing:.5px}.profile-section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) 0 var(--spacing-base);flex-shrink:0}.profile-section-title{font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--color-text-primary);padding-left:10px;border-left:3px solid var(--color-brand-primary);line-height:1.2;letter-spacing:.5px}.profile-playlist-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.profile-playlist-grid-item{display:flex;flex-direction:column;gap:var(--spacing-sm);cursor:pointer;padding:var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-base);background:var(--color-bg-card);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light)}.profile-playlist-grid-item:hover{transform:translateY(-2px);box-shadow:0 8px 32px #7c4d9f1f,0 0 0 1px #7c4d9f1a}.profile-playlist-grid-item:active{transform:scale(.96);transition:transform .1s ease}.profile-playlist-grid-cover{width:100%;aspect-ratio:1 / 1;border-radius:var(--radius-sm);overflow:hidden;background:linear-gradient(135deg,#d4c4e8,#ede4f5);position:relative}.profile-playlist-grid-cover img{width:100%;height:100%;object-fit:cover;display:block}.profile-playlist-grid-info{display:flex;flex-direction:column;gap:2px;padding:0 2px}.profile-playlist-grid-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:var(--line-height-tight)}.profile-playlist-grid-meta{font-size:var(--font-size-xs);color:var(--color-text-hint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-recent-card{border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--spacing-xl)}.profile-recent-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-border-light)}.profile-recent-header-title{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:var(--font-weight-medium);letter-spacing:.5px}.profile-recent-header-dur{font-size:var(--font-size-xs);color:var(--color-text-hint)}.profile-recent-item{display:flex;align-items:center;padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;transition:all var(--transition-fast);position:relative;border-bottom:1px solid rgba(124,77,159,.06)}.profile-recent-item:last-child{border-bottom:none}.profile-recent-item:hover{background:#7c4d9f0a}.profile-recent-item:active{background:#7c4d9f14;transform:scale(.99)}.profile-recent-item--playing{background:#7c4d9f14}.profile-recent-item--playing:before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:3px;border-radius:0 3px 3px 0;background:linear-gradient(180deg,#7c4d9f,#b388eb);box-shadow:0 0 10px #7c4d9f4d}.profile-recent-item--playing .profile-recent-title{color:var(--color-brand-primary)}.profile-recent-item--playing .profile-recent-artist{color:#7c4d9f99}.profile-recent-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;padding-left:4px}.profile-recent-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:var(--line-height-tight)}.profile-recent-artist{font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:var(--line-height-tight)}.profile-recent-dur{flex-shrink:0;width:48px;text-align:right;font-size:var(--font-size-xs);color:var(--color-text-hint);font-variant-numeric:tabular-nums;margin-left:var(--spacing-sm)}.profile-toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);background:#1a1a1ad9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);padding:var(--spacing-md) var(--spacing-xl);color:var(--color-text-white);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);z-index:1000;pointer-events:none;opacity:0;transition:all .3s cubic-bezier(.25,.1,.25,1);letter-spacing:.5px;text-align:center;max-width:80vw}.profile-toast--show{opacity:1;transform:translate(-50%,-50%) scale(1)}@media (max-width: 374px){.profile-scroll{padding:0 var(--spacing-sm);padding-top:var(--spacing-sm)}.profile-user-card{padding:var(--spacing-lg) var(--spacing-sm)}.profile-avatar-wrap{width:70px;height:70px}.profile-username{font-size:var(--font-size-lg)}.profile-quick-item{padding:var(--spacing-sm);min-height:64px}.profile-quick-icon{font-size:var(--font-size-xl)}.profile-recent-item{padding:var(--spacing-sm) var(--spacing-sm)}.profile-recent-dur{width:40px}}@media (min-width: 768px){.profile-scroll{max-width:720px;margin:0 auto}.profile-topbar{max-width:720px;margin:0 auto;left:50%;transform:translate(-50%);width:100%}.profile-playlist-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1024px){.profile-page{align-items:center}.profile-scroll,.profile-topbar{max-width:960px}.profile-playlist-grid,.profile-quick-entry{grid-template-columns:repeat(4,1fr)}.profile-user-card{padding:var(--spacing-2xl) var(--spacing-xl)}}.profile-bottom-nav .bottom-nav-item[data-nav=profile].active:before{content:"";position:absolute;top:0;left:30%;right:30%;height:3px;background:var(--color-brand-primary);border-radius:0 0 3px 3px;box-shadow:0 0 12px #7c4d9f4d}.profile-bottom-nav .bottom-nav-item[data-nav=profile].active .bottom-nav-dot{opacity:1;transform:scale(1)}
