*,*:before,*:after{box-sizing:border-box}body{margin:0;overflow-x:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;background:radial-gradient(circle at top left,rgba(56,189,248,.16),transparent 55%),radial-gradient(circle at bottom right,rgba(129,140,248,.18),transparent 55%),#020617;color:#e5e7eb;-webkit-tap-highlight-color:rgba(255,255,255,.1)}#app{min-height:100vh;display:flex;flex-direction:column}.app-container{max-width:1040px;margin:0 auto;padding:32px 16px 24px;flex:1;display:flex;flex-direction:column;min-height:0}.app-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.header-auth{display:flex;align-items:center;gap:12px}.title{font-size:24px;font-weight:600}.subtitle{font-size:13px;color:#9ca3af}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:12px;background:#0f172ae6;color:#9ca3af;box-shadow:0 0 0 1px #94a3b829}.badge-dot{width:8px;height:8px;border-radius:999px;margin-right:6px}.badge-dot.green{background:#22c55e}.badge-dot.red{background:#ef4444}.btn{border:none;border-radius:999px;padding:6px 14px;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;background:#020617;color:#e5e7eb;box-shadow:0 0 0 1px #94a3b840;transition:background .15s ease,box-shadow .15s ease,transform .08s ease}.btn:hover{background:#020617;box-shadow:0 0 0 1px #94a3b866,0 10px 18px #0f172ab3;transform:translateY(-1px)}.btn-primary{background:#3b82f6;color:#f9fafb}.btn-primary:hover{background:#2563eb}.btn-text{background:transparent;color:#94a3b8;box-shadow:none}.btn-text:hover{background:#94a3b81f;color:#e5e7eb;box-shadow:none;transform:none}.card{background:radial-gradient(circle at top left,rgba(248,250,252,.02),transparent 60%) border-box,linear-gradient(to bottom right,#94a3b880,#1e40afa6) border-box;border-radius:18px;padding:14px;border:1px solid transparent;box-shadow:0 18px 45px #0f172ae6,0 0 0 1px #0f172a99;-webkit-backdrop-filter:blur(22px) saturate(140%);backdrop-filter:blur(22px) saturate(140%)}.layout-main{display:flex;flex:1;min-height:0}.audio-panel{width:100%;flex:1;display:flex;flex-direction:column;min-height:0}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:4px 4px 10px;border-bottom:1px solid rgba(30,64,175,.35);margin-bottom:6px}.panel-title{font-size:14px;font-weight:500}.panel-subtitle{margin-top:2px}.panel-actions{display:flex;gap:8px;align-items:center}.panel-body{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(260px,1fr);gap:8px;align-items:stretch;margin-top:4px;flex:1;min-height:0}.panel-left{min-width:0}.playlist-toggle{display:none}.panel-right{min-width:0;display:flex;flex-direction:column;flex:1;min-height:0}.panel-right>.vinyl-player{display:flex;flex-direction:column;align-items:center;justify-content:flex-start}.audio-list{margin-top:8px;max-height:440px;overflow-y:auto}.audio-list::-webkit-scrollbar{width:6px}.audio-list::-webkit-scrollbar-thumb{background:#94a3b866;border-radius:999px}.audio-list::-webkit-scrollbar-track{background:transparent}.audio-row{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:8px;cursor:pointer;font-size:13px}.audio-row:hover{background:#0f172ae6}.audio-row.active{background:linear-gradient(to right,#3b82f62e,#818cf833);border:1px solid rgba(96,165,250,.85);box-shadow:0 0 0 1px #0f172ae6}.audio-name{font-weight:500;color:#e5e7eb}.audio-meta{font-size:12px;color:#9ca3af}.player-bar{padding:12px 0 0}.player-bar.is-compact .player-inner{max-width:none;width:100%;justify-content:center}.player-bar.is-compact .player-controls{width:100%;min-width:0;gap:12px}.player-bar.is-compact .player-buttons{justify-content:center;gap:16px}.player-bar.is-compact .btn-icon{width:44px;height:44px;font-size:18px}.player-bar.is-compact .btn-icon-ghost{background:transparent;color:#f1f5f9;box-shadow:none}.player-bar.is-compact .btn-icon-ghost:hover:not(:disabled){background:#ffffff14;color:#fff}.player-bar.is-compact .btn-icon-seek{width:46px;height:46px;background:#1e293bd9;color:#e2e8f0;box-shadow:0 0 0 1px #94a3b833,0 2px 8px #0f172a66;transition:transform .2s ease,box-shadow .2s ease,background .2s ease,color .2s ease}.player-bar.is-compact .btn-icon-svg{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;color:inherit}.player-bar.is-compact .btn-icon-svg svg{width:100%;height:100%}.player-bar.is-compact .btn-icon-seek:hover:not(:disabled){background:#334155f2;color:#f8fafc;box-shadow:0 0 0 1px #94a3b859,0 4px 14px #0f172a80,0 0 20px #3b82f61f}.player-bar.is-compact .btn-icon-seek:active:not(:disabled){transform:scale(.95);box-shadow:0 0 0 1px #94a3b840}.player-bar.is-compact .btn-icon-seek:disabled{background:#1e293b80;color:#64748b;box-shadow:0 0 0 1px #47556933;opacity:.75}.player-bar.is-compact .btn-icon-text{font-size:18px;font-weight:600;letter-spacing:-.04em}.player-bar.is-compact .btn-icon-play{width:58px;height:58px;font-size:0;background:linear-gradient(155deg,#60a5fa,#3b82f6 45%,#2563eb);color:#fff;box-shadow:0 0 0 1px #ffffff1f inset,0 1px #fff3,0 4px 20px #3b82f673,0 8px 32px #2563eb40;transition:transform .2s ease,box-shadow .25s ease,background .2s ease}.player-bar.is-compact .btn-icon-play .btn-icon-play-icon{width:26px;height:26px}.player-bar.is-compact .btn-icon-play:hover:not(:disabled){background:linear-gradient(155deg,#93c5fd,#60a5fa 45%,#3b82f6);box-shadow:0 0 0 1px #ffffff2e inset,0 2px #ffffff40,0 6px 24px #3b82f680,0 12px 40px #2563eb4d;transform:scale(1.05)}.player-bar.is-compact .btn-icon-play:active:not(:disabled){transform:scale(.96);box-shadow:0 0 0 1px #0000001a inset,0 2px 12px #3b82f666}.player-bar.is-compact .btn-icon-play:disabled{background:linear-gradient(155deg,#475569,#334155);box-shadow:0 2px 8px #0f172a80;opacity:.7}.player-inner{max-width:960px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px}.player-info{min-width:0;max-width:420px}.player-title{font-size:13px;font-weight:500}.player-subtitle{font-size:11px;color:#9ca3af}.player-audio{flex:1;max-width:520px;filter:drop-shadow(0 10px 18px rgba(15,23,42,.9))}.player-audio-native{display:none}.player-visualizer{margin-top:6px;display:flex;align-items:flex-end;gap:3px;height:14px}.player-visualizer-bar{width:3px;border-radius:999px;background:linear-gradient(to top,#f97316,#fde68a);transform-origin:bottom;animation:equalizer 1s infinite ease-in-out;opacity:.9}.player-visualizer-bar:nth-child(2){animation-delay:.1s}.player-visualizer-bar:nth-child(3){animation-delay:.2s}.player-visualizer-bar:nth-child(4){animation-delay:.3s}.player-visualizer-bar:nth-child(5){animation-delay:.4s}@keyframes equalizer{0%,to{transform:scaleY(.4)}50%{transform:scaleY(1)}}.player-controls{flex:1;display:flex;flex-direction:column;gap:4px}.player-buttons{display:flex;align-items:center;gap:8px}.btn-icon{width:28px;height:28px;border-radius:999px;border:none;display:inline-flex;align-items:center;justify-content:center;background:#111827;color:#e5e7eb;cursor:pointer;transition:background .2s ease,transform .15s ease,box-shadow .2s ease}.btn-icon:hover:not(:disabled){background:#1f2937}.btn-icon:disabled{opacity:.45;cursor:not-allowed}.time-text{font-size:11px;color:#9ca3af}.progress,.progress input[type=range]{width:100%}.player-timeline{display:flex;align-items:center;gap:8px}.empty-tip{font-size:13px;color:#6b7280;padding:12px}.vinyl-player{position:relative;width:100%;min-width:0;padding:18px 12px 14px;border-radius:18px;background:radial-gradient(circle at top left,rgba(248,250,252,.04),transparent 60%),linear-gradient(135deg,#1e40af99,#0f172afa);box-shadow:0 16px 32px #0f172ae6,0 0 0 1px #0f172af2;display:flex;align-items:center;justify-content:center;overflow:visible}.vinyl-record{position:relative;z-index:0;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle at 28% 28%,rgba(248,250,252,.28),transparent 48%),radial-gradient(circle at center,#0f172a 0,#020617 52%,#020617 58%,#000);box-shadow:0 18px 30px #0f172ae6,0 0 0 1px #0f172a,inset 0 1px #ffffff0f;display:flex;align-items:center;justify-content:center;transform-origin:center}.vinyl-player.is-playing .vinyl-record{animation:vinyl-spin 9s linear infinite}.vinyl-grooves{position:absolute;top:18%;right:18%;bottom:18%;left:18%;border-radius:50%;background-image:repeating-radial-gradient(circle at center,rgba(15,23,42,.12) 0,rgba(15,23,42,.12) 1px,transparent 1px,transparent 2.8px);opacity:.85}.vinyl-label{position:relative;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle at 35% 25%,#fef3c7,#fcd34d 35%,#f59e0b 70%,#ea580c);box-shadow:0 0 0 3px #020617,0 4px 12px #00000059,inset 0 1px #ffffff59;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:10px 8px}.vinyl-label:after{content:"";position:absolute;top:32%;right:32%;bottom:32%;left:32%;border-radius:50%;background:#020617}.vinyl-label-title{position:relative;z-index:1;font-size:13px;font-weight:700;color:#0c0a09;max-height:2.4em;overflow:hidden;text-shadow:0 0 1px rgba(255,255,255,.5),0 1px 2px rgba(0,0,0,.25),0 2px 4px rgba(0,0,0,.15);letter-spacing:.02em;line-height:1.3}.vinyl-label-subtitle{position:relative;z-index:1;margin-top:4px;font-size:10px;font-weight:500;color:#1c1917;max-height:1.9em;overflow:hidden;text-shadow:0 0 1px rgba(255,255,255,.4),0 1px 2px rgba(0,0,0,.2);opacity:.92}.vinyl-arm{position:absolute;right:6px;top:8px;width:110px;height:110px;transform-origin:16% 18%;transform:rotate(18deg);z-index:10;pointer-events:none;isolation:isolate}.vinyl-player.is-playing .vinyl-arm{transform:rotate(34deg);transition:transform .35s ease-out}.vinyl-arm-pivot{position:absolute;left:4px;top:10px;width:14px;height:14px;border-radius:50%;background:transparent;border:1px solid rgba(226,232,240,.95);display:block}.vinyl-arm-pivot:after{content:none}.vinyl-arm-rod{position:absolute;left:11px;top:19px;width:78px;height:2px;border-radius:999px;background:#e2e8f0f2;display:block}.vinyl-arm-rod:before{content:none}.vinyl-arm-rod:after{content:none}.vinyl-arm-head{position:absolute;right:4px;bottom:10px;width:13px;height:18px;border-radius:6px 6px 10px 10px;background:transparent;border:1px solid rgba(226,232,240,.95);display:block}.vinyl-arm-head:before{content:"";position:absolute;left:2px;right:2px;top:7px;height:2px;border-radius:999px;background:#e2e8f0f2}.vinyl-arm-head:after{content:"";position:absolute;left:50%;bottom:-8px;width:2px;height:8px;border-radius:999px;background:#e2e8f0f2;transform:translate(-50%)}.page-test .vinyl-player{overflow:visible}.page-test .vinyl-arm{z-index:999;visibility:visible;opacity:1}.vinyl-empty{background:radial-gradient(circle at top left,rgba(148,163,184,.16),transparent 55%),linear-gradient(135deg,#0f172af5,#0f172afc);box-shadow:0 12px 28px #0f172acc,0 0 0 1px #1f2937e6}.vinyl-empty-text{font-size:11px;color:#e5e7eb;text-align:center;max-width:200px}@keyframes vinyl-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.now-playing-card{position:relative;padding:14px 14px 12px;border-radius:14px;background:radial-gradient(circle at top left,rgba(248,250,252,.04),transparent 60%),linear-gradient(135deg,#3b82f642,#818cf852);box-shadow:0 16px 32px #0f172ad9,0 0 0 1px #0f172ae6;overflow:hidden}.now-playing-card:before{content:"";position:absolute;top:-40%;right:-40%;bottom:-40%;left:-40%;opacity:.5;background-image:radial-gradient(circle at 20% 0%,rgba(248,250,252,.38),transparent 55%);mix-blend-mode:soft-light;pointer-events:none}.now-playing-card>*{position:relative;z-index:1}.now-playing-label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#d1d5db;margin-bottom:8px;opacity:.9}.now-playing-title{font-size:15px;font-weight:600;margin-bottom:4px;color:#f9fafb}.now-playing-meta{font-size:11px;color:#e5e7eb;opacity:.9;word-break:break-all}.now-playing-empty{background:radial-gradient(circle at top left,rgba(148,163,184,.16),transparent 55%),linear-gradient(135deg,#0f172af2,#0f172afa);box-shadow:0 12px 28px #0f172acc,0 0 0 1px #1f2937e6}@media (max-width: 768px){.app-container{padding:10px 10px 14px;padding-bottom:max(14px,env(safe-area-inset-bottom))}.app-header{flex-wrap:wrap;gap:8px;margin-bottom:8px}.title{font-size:20px}.subtitle{font-size:12px}.card.audio-panel{padding:10px}.panel-header{flex-wrap:wrap;gap:6px;padding:2px 2px 6px;margin-bottom:4px}.panel-title{font-size:13px}.panel-subtitle{margin-top:0}.panel-actions .btn{padding:6px 12px;font-size:13px}.panel-body{grid-template-columns:minmax(0,1fr);gap:4px;margin-top:2px}.panel-right{margin-top:4px}.audio-panel.list-collapsed .panel-body{margin-top:0}.playlist-toggle{display:flex;align-items:center;gap:6px;width:100%;padding:8px 10px;margin-top:4px;border:none;border-radius:10px;background:#0f172ad9;color:#e5e7eb;font-size:13px;cursor:pointer;text-align:left;box-shadow:0 0 0 1px #94a3b833;transition:background .2s ease,box-shadow .2s ease}.playlist-toggle:hover{background:#1e293bf2;box-shadow:0 0 0 1px #94a3b859}.playlist-toggle-label{font-weight:500;flex-shrink:0}.playlist-toggle-dir{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#9ca3af;font-size:12px}.playlist-toggle-icon{flex-shrink:0;font-size:10px;color:#9ca3af;transition:transform .25s ease}.playlist-toggle-icon.expanded{transform:rotate(-180deg)}.panel-left-content{overflow:hidden;max-height:30vh;transition:max-height .3s ease}.audio-panel.list-collapsed .panel-left-content{max-height:0!important;margin-top:0}.audio-list-wrap{margin-top:4px}.audio-list{max-height:30vh;min-height:60px}.audio-row{min-height:44px;padding:8px 10px}.vinyl-player{padding:10px 8px 8px}.player-bar{padding:8px 0 0}.vinyl-record{width:220px;height:220px}.vinyl-label{width:132px;height:132px;padding:8px 6px}.vinyl-label-title{font-size:11px;font-weight:700}.vinyl-label-subtitle{font-size:9px}.vinyl-arm-pivot{width:12px;height:12px;left:2px;top:6px}.vinyl-arm-rod{width:48px;height:6px}.vinyl-arm-head{width:10px;height:18px}.player-bar.is-compact .player-controls{gap:10px}.player-bar.is-compact .btn-icon,.player-bar.is-compact .btn-icon-seek{width:48px;height:48px;min-width:48px;min-height:48px}.player-bar.is-compact .btn-icon-play{width:58px;height:58px;min-width:58px;min-height:58px}.player-timeline{gap:6px}.progress input[type=range]{min-height:28px}.player-inner{flex-direction:column;align-items:stretch}.player-audio{width:100%;max-width:100%}}@media (max-width: 480px){.app-container{padding:8px 8px 12px;padding-bottom:max(12px,env(safe-area-inset-bottom))}.card.audio-panel{padding:8px}.title{font-size:18px}.vinyl-record{width:180px;height:180px}.vinyl-label{width:108px;height:108px;padding:6px 5px}.vinyl-label-title{font-size:10px;font-weight:700}.vinyl-label-subtitle{font-size:8px}.vinyl-empty-text{font-size:12px}}
