:root{font-family:Pretendard,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#1a1a2e;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#f8f9fa}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{box-sizing:border-box;margin:0;padding:0}:root{--primary: #ad2bee;--primary-light: rgba(173, 43, 238, .2);--primary-glow: rgba(173, 43, 238, .4);--bg-dark: #0a050d;--bg-surface: #1c1022;--bg-card: rgba(255, 255, 255, .03);--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .7);--text-muted: rgba(255, 255, 255, .4);--border-subtle: rgba(255, 255, 255, .1);--blue-accent: #3b82f6;--pink-accent: #ec4899}html{overscroll-behavior:none}body{font-family:Spline Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-dark);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased;overscroll-behavior:contain}.app-container{min-height:100vh;max-width:480px;margin:0 auto;display:flex;flex-direction:column;position:relative;overflow-x:hidden}.top-nav{position:fixed;top:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#0a050dcc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle)}.nav-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:flex-start}.equalizer-icon{width:24px;height:24px;color:var(--primary)}.nav-title{position:absolute;left:50%;transform:translate(-50%);font-size:1.5rem;font-weight:700;letter-spacing:-.015em;text-align:center;pointer-events:none}.nav-account{display:flex;align-items:center;justify-content:flex-end;gap:.5rem}.account-btn{width:36px;height:36px;border-radius:50%;background:#ffffff0d;border:none;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.account-btn:hover{background:#ffffff1a}.account-btn svg{width:22px;height:22px}.lang-toggle{padding:.25rem .6rem;border-radius:12px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);color:var(--text-secondary);font-size:.7rem;font-weight:600;letter-spacing:.02em;cursor:pointer;transition:all .2s;white-space:nowrap}.lang-toggle:hover{background:#ffffff24;color:var(--text-primary)}.hero-section{position:relative;min-height:calc(100vh - 56px);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1.5rem 4rem;margin-top:56px}.bg-effects{position:absolute;inset:0;overflow:hidden;pointer-events:none}.bg-blob{position:absolute;border-radius:50%;filter:blur(120px)}.bg-blob-1{top:-10%;left:-20%;width:80%;height:60%;background:var(--primary-light)}.bg-blob-2{bottom:10%;right:-10%;width:60%;height:50%;background:#3b82f61a}.featured-card{width:100%;max-width:260px;margin-bottom:2rem;position:relative;z-index:10}.card-image{position:relative;aspect-ratio:1;width:100%;background:linear-gradient(180deg,#2a1f3d,#1a1025 40%,#ff7b4d 85%,#ffa07a);background-size:cover;border-radius:1rem;overflow:hidden;box-shadow:0 25px 50px -12px #00000080;border:1px solid var(--border-subtle);display:flex;flex-direction:column;justify-content:flex-end}.card-image:before{content:"";position:absolute;top:20%;left:10%;right:10%;height:40%;background:repeating-linear-gradient(90deg,rgba(255,255,255,.1) 0px,rgba(255,255,255,.3) 1px,transparent 1px,transparent 4px);-webkit-mask-image:linear-gradient(180deg,transparent,white 20%,white 80%,transparent);mask-image:linear-gradient(180deg,transparent,white 20%,white 80%,transparent);animation:audioWave 2s ease-in-out infinite}@keyframes audioWave{0%,to{opacity:.5;transform:scaleY(1)}50%{opacity:.8;transform:scaleY(1.1)}}.card-overlay{position:absolute;inset:0;background:linear-gradient(to top,var(--bg-dark),transparent);opacity:.6}.card-content{position:relative;z-index:20;padding:1.5rem}.card-bars{display:flex;flex-direction:column;gap:.25rem}.bar{height:4px;border-radius:9999px;background:var(--primary)}.bar-1{width:6rem}.bar-2{width:3rem;opacity:.4}.landing-vinyl-container{position:relative;z-index:10;display:flex;align-items:center;justify-content:center;margin-bottom:2rem}.landing-vinyl{position:relative;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle at center,#111 0% 27%,#1a1a1a 27.5%,#111 28% 44%,#1a1a1a 44.5%,#111 45% 61%,#1a1a1a 61.5%,#111 62%,#0d0d0d);box-shadow:0 0 0 10px #ffffff0d,0 0 50px var(--primary-glow),0 25px 70px #00000080;display:flex;align-items:center;justify-content:center;animation:landingVinylSpin 8s linear infinite}@keyframes landingVinylSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.landing-vinyl-grooves{position:absolute;inset:0;border-radius:50%;background:linear-gradient(135deg,transparent 0%,transparent 40%,rgba(255,255,255,.08) 45%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.08) 55%,transparent 60%,transparent 100%);pointer-events:none}.landing-vinyl:before{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(-45deg,transparent 0%,transparent 35%,rgba(173,43,238,.1) 45%,rgba(173,43,238,.2) 50%,rgba(173,43,238,.1) 55%,transparent 65%,transparent 100%);pointer-events:none}.landing-vinyl-center{position:relative;z-index:10;width:198px;height:198px;border-radius:50%;overflow:hidden;box-shadow:0 0 0 5px #0009,0 0 25px #ad2bee80;animation:landingVinylSpinReverse 8s linear infinite}@keyframes landingVinylSpinReverse{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}.landing-vinyl-image{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .8s ease-in-out}.landing-vinyl-image.active{opacity:1}.headline-section{position:relative;z-index:10;text-align:center}.main-headline{font-size:1.5rem;font-weight:700;line-height:1.2;letter-spacing:-.02em;padding:0 1rem .75rem;margin:0 auto}.sub-headline{font-size:.875rem;font-weight:400;line-height:1.6;color:var(--text-secondary);padding:0 1.5rem 1.5rem;margin:0 auto}.cta-button{display:flex;align-items:center;justify-content:center;gap:.6rem;width:calc(100% - 2rem);max-width:280px;height:3.5rem;padding:0 1.5rem;background:var(--primary);color:var(--text-primary);border:none;border-radius:9999px;font-size:1rem;font-weight:700;letter-spacing:.02em;cursor:pointer;box-shadow:0 0 20px var(--primary-glow),0 0 40px #ad2bee33;transition:transform .2s,box-shadow .2s;position:relative;z-index:10}.cta-button:hover{transform:scale(1.02);box-shadow:0 0 30px var(--primary-glow),0 0 60px #ad2bee4d}.cta-button:active{transform:scale(.98)}.sparkle-icon{width:24px;height:24px}.scroll-indicator{position:absolute;bottom:2rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;opacity:.4}.scroll-text{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase}.scroll-arrow{width:24px;height:24px;animation:bounce 2s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(8px)}}.how-it-works{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1.5rem 1.5rem 0}.step{display:flex;flex-direction:column;align-items:center;gap:.5rem}.step-icon{font-size:2.5rem;line-height:1}.step-label{font-size:.85rem;font-weight:600;letter-spacing:.05em;color:var(--text-muted)}.step-connector{font-size:1.25rem;font-weight:700;color:var(--text-muted);margin-bottom:1rem}.app-footer{padding:2.5rem 2.5rem 6rem;text-align:center;border-top:1px solid var(--border-subtle);opacity:.5}.app-footer p{font-size:.7rem}.footer-links{margin-top:.5rem;display:flex;justify-content:center;align-items:center;gap:.5rem}.footer-link{background:none;border:none;color:var(--text-secondary);font-size:.7rem;cursor:pointer;text-decoration:underline;font-family:inherit;padding:0}.footer-link:hover{color:var(--text-primary)}.footer-separator{color:var(--text-muted);font-size:.7rem}.legal-page{min-height:100vh}.legal-header{position:fixed;top:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;z-index:60;display:grid;grid-template-columns:52px 1fr 52px;align-items:center;gap:.5rem;padding:1rem;background:#1c1022eb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle)}.legal-back-btn{width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:#0c0810b8;border:1px solid rgba(255,255,255,.32);border-radius:14px;color:#fff;cursor:pointer;box-shadow:0 10px 28px #0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:background .2s,border-color .2s,transform .2s}.legal-back-btn:hover{background:#1a1022e6;border-color:#ffffff75;transform:translateY(-1px)}.legal-back-btn:active{transform:translateY(0);opacity:.92}.legal-back-btn svg{width:28px;height:28px}.legal-title{text-align:center;font-size:1.5rem;font-weight:700;color:#fff;margin:0;min-width:0}.legal-header-spacer{width:52px;height:52px}.legal-content{padding:5.5rem 1.5rem 6rem;max-width:480px;margin:0 auto}.legal-updated{font-size:.8rem;color:var(--text-muted);margin-bottom:1.5rem}.legal-section{margin-bottom:1.5rem}.legal-section h2{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.legal-section p{font-size:.85rem;color:var(--text-secondary);line-height:1.6;margin-bottom:.5rem}.legal-section ul{list-style:disc;padding-left:1.25rem;margin-bottom:.5rem}.legal-section li{font-size:.85rem;color:var(--text-secondary);line-height:1.6;margin-bottom:.25rem}.legal-section a{color:var(--primary);text-decoration:underline}.legal-section a:hover{color:var(--text-primary)}.legal-inline-link{background:none;border:none;color:var(--primary);text-decoration:underline;cursor:pointer;font-size:inherit;font-family:inherit;padding:0}.legal-inline-link:hover{color:var(--text-primary)}.legal-nav-links{display:flex;gap:.75rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-subtle)}.legal-nav-link{flex:1;padding:.75rem;background:#ffffff0d;border:1px solid var(--border-subtle);border-radius:12px;color:var(--text-secondary);font-size:.8rem;font-family:inherit;cursor:pointer;transition:all .2s;text-align:center}.legal-nav-link:hover{background:#ffffff1a;color:var(--text-primary);border-color:var(--primary)}.create-header{position:relative;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:1rem;background:#0a050dcc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.create-header .lang-toggle{width:40px;text-align:center;padding:.25rem 0;flex-shrink:0}.back-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-primary);cursor:pointer;transition:opacity .2s}.back-btn:active{opacity:.6}.back-btn svg{width:24px;height:24px}.create-title{position:absolute;left:50%;transform:translate(-50%);font-size:1.5rem;font-weight:700;letter-spacing:-.01em;pointer-events:none;max-width:85%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.create-main{flex:1;display:flex;flex-direction:column;gap:3rem;padding:.5rem 1.25rem 1rem;overflow-y:auto}.upload-section{padding-top:.25rem}.upload-box{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:1.5rem 1rem;border:1px dashed rgba(173,43,238,.4);border-radius:1rem;background:#ad2bee0d;cursor:pointer;transition:all .2s;height:240px;position:relative;overflow:hidden}.upload-box:hover{background:#ad2bee1a}.upload-box:active:not(.has-image){transform:scale(.98)}.upload-box.dragging{border-color:var(--primary);background:#ad2bee26}.upload-box.has-image{padding:0;border-style:solid;border-color:var(--primary);cursor:default}.preview-image{width:100%;height:240px;object-fit:cover;border-radius:.875rem}.image-change-btn{position:absolute;bottom:8px;right:8px;width:32px;height:32px;border-radius:50%;background:#0009;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:5}.image-change-btn:hover{background:#000c}.upload-icon-wrapper{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#ad2bee33;border-radius:50%}.camera-icon{width:24px;height:24px;color:var(--primary)}.upload-title{font-size:.875rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em}.upload-subtitle{font-size:.7rem;color:var(--text-muted);margin-top:-.25rem}.file-input{display:none}.context-section{display:flex;flex-direction:column;gap:1rem}.context-header{display:flex;align-items:center;justify-content:space-between;padding:0 .25rem}.context-label{font-size:.875rem;font-weight:700;color:#fff9;letter-spacing:.05em}.mode-toggle{display:flex;padding:.25rem;background:#ffffff0d;border-radius:9999px;border:1px solid var(--border-subtle)}.mode-btn{padding:.375rem .75rem;border:none;border-radius:9999px;font-size:.8rem;font-weight:700;letter-spacing:.05em;cursor:pointer;transition:all .2s;background:transparent;color:#fff6}.mode-btn.active{background:var(--primary);color:#fff}.mode-btn:not(.active):hover{color:#ffffffb3}.keywords-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.keyword-wrapper{position:relative}.keyword-label{position:absolute;top:-8px;left:12px;padding:0 6px;background:var(--bg-dark);font-size:.8rem;font-weight:700;color:var(--primary);letter-spacing:.05em;text-transform:uppercase;z-index:1}.keyword-field{width:100%;padding:.75rem .75rem .625rem;background:#ffffff0d;border:1px solid var(--border-subtle);border-radius:.75rem;font-size:.8rem;color:var(--text-primary);outline:none;transition:border-color .2s}.keyword-field:focus{border-color:var(--primary)}.keyword-field::placeholder{color:#fff6;font-style:italic}.sentence-field{width:100%;min-height:100px;padding:1rem;background:#ffffff0d;border:1px solid var(--border-subtle);border-radius:.75rem;font-size:.875rem;color:var(--text-primary);outline:none;resize:none;font-family:inherit;transition:border-color .2s}.sentence-field:focus{border-color:var(--primary)}.sentence-field::placeholder{color:#ffffff4d}.style-section{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-top:-1.5rem}.genre-carousel{align-self:stretch;display:flex;gap:.5rem;overflow-x:auto;overflow-y:visible;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;touch-action:pan-x;padding:1.5rem;scrollbar-width:none;cursor:grab}.genre-carousel.dragging{cursor:grabbing;scroll-snap-type:none;-webkit-user-select:none;user-select:none}.genre-carousel::-webkit-scrollbar{display:none}.genre-chip{position:relative;scroll-snap-align:center;flex-shrink:0;padding:.5rem 1rem;border-radius:20px;border:1.5px solid rgba(255,255,255,.15);background:#ffffff0d;color:#ffffffb3;font-size:.8rem;font-weight:700;letter-spacing:.05em;cursor:pointer;transition:all .2s;white-space:nowrap;outline:none}.genre-chip:hover{background:#ad2bee4d;border-color:#ad2bee80}.genre-chip.active{background:transparent;border:1.5px solid transparent;color:transparent;min-width:80px;padding:.5rem 1rem;display:flex;align-items:center;justify-content:center}.genre-chip.active:focus,.genre-chip.active:focus-visible{outline:none;box-shadow:none}.mini-vinyl{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:64px;height:64px;border-radius:50%;background:radial-gradient(circle at center,#111 0% 27%,#1a1a1a 27.5%,#111 28% 44%,#1a1a1a 44.5%,#111 45% 61%,#1a1a1a 61.5%,#111 62%,#0d0d0d);box-shadow:0 0 0 4px #ffffff0d,0 0 30px var(--primary-glow),0 0 60px #ad2bee40,0 8px 20px #00000080;display:flex;align-items:center;justify-content:center;will-change:transform;contain:layout style paint;animation:miniVinylSpin 4s linear .05s infinite}@keyframes miniVinylSpin{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}.mini-vinyl-grooves{position:absolute;inset:0;border-radius:50%;background:linear-gradient(135deg,transparent 0%,transparent 40%,rgba(255,255,255,.08) 45%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.08) 55%,transparent 60%,transparent 100%);pointer-events:none}.mini-vinyl-shine{position:absolute;inset:0;border-radius:50%;background:linear-gradient(-45deg,transparent 0%,transparent 35%,rgba(173,43,238,.1) 45%,rgba(173,43,238,.2) 50%,rgba(173,43,238,.1) 55%,transparent 65%,transparent 100%);pointer-events:none}.mini-vinyl-center{position:relative;z-index:2;width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary) 0%,#8b1bc0 100%);border:2px solid rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;box-shadow:inset 0 1px 5px #00000080,0 0 15px #ad2bee99;will-change:transform;animation:miniVinylCenterSpin 4s linear .05s infinite}@keyframes miniVinylCenterSpin{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}.mini-vinyl-text{font-size:.5rem;font-weight:900;letter-spacing:.05em;color:#fff;text-align:center;line-height:1}.error-message{padding:.75rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:.75rem;color:#f87171;font-size:.8rem;text-align:center}.generate-section{position:sticky;bottom:0;margin-top:-1.5rem;padding:1.5rem 1.25rem calc(2rem + env(safe-area-inset-bottom,0px));background:linear-gradient(to top,#0a0a0a 70%,rgba(10,10,10,.95) 85%,rgba(10,10,10,.8) 95%,transparent 100%);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:100}.generate-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;height:3.5rem;background:linear-gradient(90deg,var(--primary) 0%,#d236f7 50%,#ff4ef1 100%);border:1px solid rgba(255,255,255,.2);border-radius:1rem;color:#fff;font-size:1rem;font-weight:700;cursor:pointer;box-shadow:0 8px 30px -10px #ad2bee99,0 -4px 16px #0000004d;transition:transform .2s,box-shadow .2s}.generate-btn:active{transform:scale(.96)}.generate-btn:disabled{opacity:.5;cursor:not-allowed}.generate-btn .sparkle{width:20px;height:20px}.generating-hint{margin-top:8px;text-align:center;font-size:.75rem;color:var(--text-secondary)}.loading-spinner{width:20px;height:20px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spinner .8s linear infinite}@keyframes spinner{to{transform:rotate(360deg)}}.result-container{position:relative;min-height:100vh;max-width:480px;margin:0 auto;display:flex;flex-direction:column;overflow:hidden}.result-bg{position:fixed;inset:0;z-index:0}.result-bg-overlay{position:absolute;inset:0;background:#0009;z-index:1}.result-bg-image{width:100%;height:100%;background-size:cover;background-position:center;transform:scale(1.1);filter:blur(40px);opacity:.5}.result-header{position:relative;z-index:20;display:grid;grid-template-columns:52px 1fr 52px;align-items:center;gap:.5rem;padding:1rem;background:transparent}.result-back-btn{width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:#0c0810b8;border:1px solid rgba(255,255,255,.32);border-radius:14px;color:#fff;cursor:pointer;box-shadow:0 10px 28px #0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:background .2s,border-color .2s,transform .2s}.result-back-btn:hover{background:#1a1022e6;border-color:#ffffff75;transform:translateY(-1px)}.result-back-btn:active{transform:translateY(0);opacity:.92}.result-back-btn svg{width:28px;height:28px}.result-title{font-size:1.5rem;font-weight:700;color:#fff;letter-spacing:-.015em;text-align:center;margin:0;min-width:0}.result-header-spacer{width:52px;height:52px}.result-share-btn{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;border-radius:50%;color:#fff;cursor:pointer;transition:background .2s}.result-share-btn:hover{background:#fff3}.result-share-btn svg{width:22px;height:22px}.result-content{position:relative;z-index:20;flex:1;overflow-y:auto;padding:0 1rem 10rem}.result-vinyl-section{display:flex;flex-direction:column;align-items:center;gap:1.5rem;margin-bottom:2rem;padding-top:1rem}.result-vinyl{position:relative;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle at center,#111 0% 27%,#1a1a1a 27.5%,#111 28% 44%,#1a1a1a 44.5%,#111 45% 61%,#1a1a1a 61.5%,#111 62%,#0d0d0d);box-shadow:0 0 0 8px #ffffff0d,0 0 40px var(--primary-glow),0 20px 50px #00000080;display:flex;align-items:center;justify-content:center;animation:resultVinylRotate 8s linear infinite}@keyframes resultVinylRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.result-vinyl-grooves{position:absolute;inset:0;border-radius:50%;background:repeating-radial-gradient(circle at center,transparent 0,transparent 2px,rgba(255,255,255,.03) 2.5px,rgba(255,255,255,.03) 3px)}.result-vinyl-shine{position:absolute;inset:0;border-radius:50%;background:linear-gradient(135deg,transparent 0%,transparent 40%,rgba(255,255,255,.1) 45%,rgba(255,255,255,.2) 50%,rgba(255,255,255,.1) 55%,transparent 60%,transparent 100%);pointer-events:none}.result-vinyl:before{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(-45deg,transparent 0%,transparent 35%,rgba(173,43,238,.15) 45%,rgba(173,43,238,.25) 50%,rgba(173,43,238,.15) 55%,transparent 65%,transparent 100%);pointer-events:none}.result-vinyl-center{position:relative;z-index:10;width:198px;height:198px;border-radius:50%;overflow:hidden;box-shadow:0 0 0 4px #0009,0 0 20px #ad2bee66;animation:resultVinylCenterRotate 8s linear infinite}@keyframes resultVinylCenterRotate{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}.result-vinyl-image{width:100%;height:100%;object-fit:cover}.result-song-title{font-size:1.75rem;font-weight:700;color:#fff;line-height:1.2;letter-spacing:-.02em;text-align:center;max-width:300px}.lyrics-sections{display:flex;flex-direction:column;gap:1.5rem}.lyrics-section{display:flex;flex-direction:column;gap:.5rem}.lyrics-section-label{font-size:.75rem;font-weight:700;color:#ad2beecc;text-transform:uppercase;letter-spacing:.15em;padding-left:.25rem}.lyrics-section-card{background:#ffffff0d;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:1rem;padding:1rem 1.25rem}.lyrics-section-card.chorus{background:#ad2bee1a;border-color:#ad2bee33;padding:1.25rem 1.5rem}.lyrics-section-text{font-size:.95rem;font-style:italic;line-height:1.7;color:#ffffffe6;margin:0}.lyrics-section-card.chorus .lyrics-section-text{font-size:1.05rem;font-weight:700;color:#fff}.result-cta-container{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;padding:1.5rem;background:linear-gradient(to top,var(--bg-dark),rgba(28,16,34,.9),transparent);z-index:30}.result-cta-button{width:100%;height:4rem;display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;background:var(--primary);border:none;border-radius:9999px;cursor:pointer;box-shadow:0 0 30px #ad2bee80;transition:transform .2s}.result-cta-button:active{transform:scale(.95)}.result-cta-button:disabled{justify-content:center;gap:.5rem}.result-cta-vinyl{position:relative;width:36px;height:36px;border-radius:50%;background:radial-gradient(circle at center,#111 0% 25%,#222 26%,#111 27% 45%,#222 46%,#111 47%,#0d0d0d);display:flex;align-items:center;justify-content:center;animation:resultVinylSpin 4s linear infinite;box-shadow:0 0 10px #ad2bee4d}.result-cta-vinyl:before{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.1) 50%,transparent 60%)}.result-cta-vinyl-inner{position:relative;z-index:1;width:12px;height:12px;border-radius:50%;background:var(--primary);box-shadow:0 0 8px #ad2bee80}@keyframes resultVinylSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.result-cta-text{font-size:1rem;font-weight:700;color:#fff;letter-spacing:-.01em}.result-cta-arrow{width:24px;height:24px;color:#fff}.result-cta-price{background:#ffffff40;padding:.35rem .85rem;border-radius:999px;font-size:1.1rem;font-weight:800;color:#fff;flex-shrink:0;letter-spacing:.02em}.result-cta-price--two-line{display:flex;flex-direction:column;align-items:center;padding:.2rem .75rem;gap:.05rem;font-size:unset}.result-cta-price-main{font-size:1rem;font-weight:800;line-height:1.1}.result-cta-price-sub{font-size:.6rem;font-weight:600;opacity:.85;letter-spacing:.03em;line-height:1}.payment-overlay{position:fixed;inset:0;z-index:100;display:flex;flex-direction:column;max-width:480px;margin:0 auto;background:var(--bg-dark);animation:fadeIn .3s ease;overflow-y:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.payment-bg{flex:1;display:flex;flex-direction:column;padding:1rem}.payment-header{display:grid;grid-template-columns:40px 1fr 40px;align-items:center;gap:.5rem;margin-bottom:2rem}.payment-close-btn{width:40px;height:40px;border-radius:50%;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.payment-close-btn svg{width:20px;height:20px}.payment-header-title{text-align:center;font-size:1.5rem;font-weight:700;color:#fff;margin:0;min-width:0}.payment-header-spacer{width:40px;height:40px}.payment-lp-section{display:flex;flex-direction:column;align-items:center;gap:2rem}.payment-lp-ring{position:relative;width:240px;height:240px;border-radius:50%;padding:6px;background:conic-gradient(var(--primary) 0deg,rgba(58,26,77,.5) 0deg);box-shadow:0 0 30px #ad2bee66;display:flex;align-items:center;justify-content:center}.payment-lp{width:100%;height:100%;border-radius:50%;background:var(--bg-dark);overflow:hidden;display:flex;align-items:center;justify-content:center}.payment-lp.spinning{animation:vinylSpin 4s linear infinite}.payment-lp-image{width:100%;height:100%;object-fit:cover;opacity:.8}.payment-progress-badge{position:absolute;bottom:-12px;left:50%;transform:translate(-50%);background:var(--primary);padding:.375rem 1rem;border-radius:9999px;font-size:.875rem;font-weight:700;color:#fff;box-shadow:0 4px 15px #ad2bee80;border:2px solid rgba(255,255,255,.2)}.payment-status-icons{display:flex;justify-content:space-between;width:100%;max-width:280px}.payment-status-item{display:flex;flex-direction:column;align-items:center;gap:.5rem}.payment-status-item span{font-size:.625rem;font-weight:500;text-transform:uppercase;letter-spacing:.15em;color:#fff6}.payment-status-item.completed span,.payment-status-item.active span{color:var(--primary)}.payment-status-item.active span{color:#fff}.payment-status-icon{width:48px;height:48px;border-radius:50%;background:#ffffff1a;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:#fff6}.payment-status-icon svg{width:22px;height:22px}.payment-status-item.completed .payment-status-icon{background:#ad2bee4d;border-color:#ad2bee80;color:var(--primary)}.payment-status-item.active .payment-status-icon{background:var(--primary);border-color:#fff3;color:#fff;box-shadow:0 0 20px #ad2bee80}.payment-status-text{text-align:center;margin-top:1rem}.payment-status-text h3{font-size:1.125rem;font-weight:700;color:#fff;margin-bottom:.5rem}.payment-status-text p{font-size:.875rem;color:#ffffff80}.payment-sheet{background:#1c1022f2;border-top:1px solid rgba(255,255,255,.1);border-radius:1.5rem 1.5rem 0 0;padding:.75rem 1.5rem 2rem;animation:slideUp .4s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.payment-sheet-handle{width:48px;height:5px;background:#fff3;border-radius:9999px;margin:0 auto 1.25rem}.payment-title{font-size:1.375rem;font-weight:700;color:#fff;text-align:center;margin-bottom:.25rem}.payment-subtitle{font-size:.75rem;color:#fff6;text-align:center;margin-bottom:1.25rem}.payment-options{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.payment-option{position:relative;cursor:pointer}.payment-option input{position:absolute;opacity:0}.payment-option-content{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:.75rem;transition:all .2s}.payment-option input:checked+.payment-option-content{background:#ad2bee26;border-color:var(--primary)}.payment-option.recommended .payment-option-content{border-color:var(--primary)}.payment-option-badge{position:absolute;top:-8px;right:12px;background:var(--primary);color:#fff;font-size:.625rem;font-weight:700;padding:.25rem .5rem;border-radius:4px;letter-spacing:.05em}.payment-option-info{display:flex;flex-direction:column;gap:.25rem}.payment-option-name{font-size:.9rem;font-weight:600;color:#fff}.payment-option-desc{font-size:.7rem;color:#fff6}.payment-option-price{font-size:1.125rem;font-weight:700;color:#fff}.payment-option-price small{font-size:.75rem;font-weight:400;color:#ffffff80}.payment-total{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;border-top:1px solid rgba(255,255,255,.05);margin-bottom:1rem}.payment-total span:first-child{font-size:1rem;font-weight:700;color:#fff}.payment-total-price{font-size:1.25rem;font-weight:900;color:var(--primary)}.payment-methods{display:flex;gap:.75rem;margin-bottom:1.25rem}.payment-method{display:flex;align-items:center;gap:.5rem;padding:.625rem .875rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:.5rem;color:#ffffffb3;font-size:.75rem;cursor:pointer;transition:all .2s}.payment-method svg{width:16px;height:16px}.payment-method.active{background:#ad2bee26;border-color:var(--primary);color:#fff}.payment-confirm-btn{width:100%;height:3.5rem;background:linear-gradient(90deg,var(--primary) 0%,#d448ff 50%,var(--primary) 100%);border:none;border-radius:9999px;color:#fff;font-size:1rem;font-weight:700;cursor:pointer;box-shadow:0 0 25px #ad2bee80;transition:transform .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.payment-confirm-btn:active{transform:scale(.95)}.payment-confirm-btn:disabled{opacity:.7;cursor:not-allowed}.payment-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:.75rem;padding:.75rem 1rem;margin-bottom:1rem;color:#ef4444;font-size:.875rem;text-align:center}.player-container{min-height:100vh;max-width:480px;margin:0 auto;display:flex;flex-direction:column;background:linear-gradient(180deg,var(--bg-dark) 0%,#2b1933 50%,var(--bg-dark) 100%)}.player-header{display:flex;align-items:center;justify-content:space-between;padding:1rem}.player-back-btn{width:48px;height:48px;display:flex;align-items:center;justify-content:flex-start;background:none;border:none;color:#fff;cursor:pointer}.player-back-btn svg{width:24px;height:24px}.player-title{font-size:1.5rem;font-weight:700;color:#fff}.player-menu-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;border-radius:50%;color:#fff;cursor:pointer}.player-menu-btn svg{width:20px;height:20px}.player-main{flex:1;display:flex;flex-direction:column;align-items:center;padding:0 1.5rem 1.5rem;overflow-y:auto}.player-main.has-nav{padding-bottom:5rem}.player-vinyl-wrapper{margin:1.5rem 0;display:flex;justify-content:center}.player-vinyl{position:relative;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle at center,#111 0% 27%,#1a1a1a 27.5%,#111 28% 44%,#1a1a1a 44.5%,#111 45% 61%,#1a1a1a 61.5%,#111 62%,#0d0d0d);box-shadow:0 0 0 8px #ffffff0d,0 0 40px var(--primary-glow),0 20px 50px #00000080;display:flex;align-items:center;justify-content:center;animation:playerVinylRotate 8s linear infinite}@keyframes playerVinylRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.player-vinyl-grooves{position:absolute;inset:0;border-radius:50%;background:repeating-radial-gradient(circle at center,transparent 0,transparent 2px,rgba(255,255,255,.03) 2.5px,rgba(255,255,255,.03) 3px)}.player-vinyl-shine{position:absolute;inset:0;border-radius:50%;background:linear-gradient(135deg,transparent 0%,transparent 40%,rgba(255,255,255,.1) 45%,rgba(255,255,255,.2) 50%,rgba(255,255,255,.1) 55%,transparent 60%,transparent 100%);pointer-events:none}.player-vinyl:before{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(-45deg,transparent 0%,transparent 35%,rgba(173,43,238,.15) 45%,rgba(173,43,238,.25) 50%,rgba(173,43,238,.15) 55%,transparent 65%,transparent 100%);pointer-events:none}.player-vinyl-center{position:relative;z-index:10;width:198px;height:198px;border-radius:50%;overflow:hidden;box-shadow:0 0 0 4px #0009,0 0 20px #ad2bee66;animation:playerVinylCenterRotate 8s linear infinite}@keyframes playerVinylCenterRotate{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}.player-vinyl-image{width:100%;height:100%;object-fit:cover;transition:opacity .3s ease}.player-song-info{text-align:center;margin-bottom:1rem}.player-song-title{font-size:1.5rem;font-weight:700;color:#fff;margin-bottom:.25rem}.player-song-meta{font-size:.75rem;font-weight:500;color:var(--primary);text-transform:uppercase;letter-spacing:.15em}.player-card{width:100%;background:#3c234866;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:1.5rem;padding:1rem;margin-bottom:1rem}.player-card-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.player-card-thumb{width:56px;height:56px;border-radius:.5rem;overflow:hidden;flex-shrink:0;box-shadow:0 4px 12px #0000004d}.player-card-thumb img{width:100%;height:100%;object-fit:cover}.player-card-info{flex:1;min-width:0}.player-card-title{font-size:1rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-card-subtitle{font-size:.875rem;color:#ad2beeb3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-play-btn{width:48px;height:48px;border-radius:50%;background:var(--primary);border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 0 15px #ad2bee80;flex-shrink:0}.player-play-btn svg{width:30px;height:30px}.player-progress{margin-bottom:.75rem}.player-progress-bar{position:relative;height:6px;display:flex;align-items:center;margin-bottom:.5rem;cursor:pointer;touch-action:none;-webkit-user-select:none;user-select:none}.player-progress-fill{height:100%;width:0%;background:var(--primary);border-radius:9999px;z-index:1}.player-progress-dot{position:absolute;left:0%;transform:translate(-50%);width:14px;height:14px;border-radius:50%;background:#fff;box-shadow:0 2px 6px #0000004d;z-index:2}.player-progress-bar:after{content:"";position:absolute;left:0%;right:0;height:100%;background:#fff3;border-radius:9999px}.player-progress-time{display:flex;justify-content:space-between}.player-progress-time span{font-size:.75rem;font-weight:600;color:#ffffff80}.player-controls{display:flex;align-items:center;justify-content:space-between}.player-volume{display:flex;align-items:center;gap:.5rem;max-width:120px;flex:1}.player-volume svg{width:18px;height:18px;color:#fff6;flex-shrink:0}.player-volume-bar{flex:1;height:4px;background:#ffffff1a;border-radius:9999px;cursor:pointer;position:relative}.player-volume-fill{height:100%;background:#fff6;border-radius:9999px;transition:width .1s}.player-lyrics-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:9999px;color:#fffc;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;cursor:pointer;transition:background .2s}.player-lyrics-btn:hover{background:#ffffff1a}.player-lyrics-btn svg{width:18px;height:18px}.player-actions{width:100%;display:flex;flex-direction:column;gap:.5rem}.player-save-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;height:3.5rem;background:var(--primary);border:none;border-radius:9999px;color:#fff;font-size:1rem;font-weight:700;cursor:pointer;box-shadow:0 4px 20px #ad2bee4d;transition:transform .2s}.player-save-btn:active{transform:scale(.98)}.player-save-btn svg{width:22px;height:22px}.player-secondary-actions{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.player-action-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;height:3.5rem;background:#ffffff1a;border:none;border-radius:9999px;color:#fff;font-size:1rem;font-weight:700;cursor:pointer;transition:background .2s}.player-action-btn:hover{background:#ffffff26}.player-action-btn svg{width:22px;height:22px}.shared-cta-section{width:100%;margin-top:1rem}.player-home-indicator{width:128px;height:6px;background:#fff3;border-radius:9999px;margin:1.5rem auto}.library-container{min-height:100vh;max-width:480px;margin:0 auto;display:flex;flex-direction:column;background:#120a16}.library-header{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:1rem;background:#120a16cc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.library-settings-btn,.library-search-btn{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:#fff;cursor:pointer;border-radius:50%;transition:background .2s}.library-settings-btn:hover,.library-search-btn:hover{background:#ffffff1a}.library-settings-btn svg,.library-search-btn svg{width:24px;height:24px}.library-title{font-size:1.5rem;font-weight:700;color:#fff}.library-categories{display:flex;gap:.75rem;padding:.75rem 1rem;overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none}.library-categories::-webkit-scrollbar{display:none}.library-category-wrapper{flex-shrink:0}.library-category{height:36px;padding:0 1.25rem;border-radius:9999px;background:#ffffff1a;border:1px solid rgba(255,255,255,.05);color:#fffc;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.library-category:hover{background:#ffffff26}.library-category.active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600}.library-grid{flex:1;display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;padding:1rem 1rem 6rem}.library-empty{grid-column:span 2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:4rem 2rem;text-align:center}.library-empty svg{width:64px;height:64px;color:#fff3}.library-empty p{font-size:1rem;font-weight:600;color:#fff9}.library-empty span{font-size:.875rem;color:#fff6}.library-card{position:relative;aspect-ratio:1;display:flex;align-items:center;justify-content:center;padding:.5rem}.library-card-image{position:relative;width:100%;height:100%;border-radius:50%;background:radial-gradient(circle at center,#111 0% 25%,#1a1a1a 25.5%,#111 26% 42%,#1a1a1a 42.5%,#111 43% 58%,#1a1a1a 58.5%,#111 59%,#0d0d0d);box-shadow:0 0 0 4px #ffffff0d,0 8px 30px #0006,0 0 20px #ad2bee26;display:flex;align-items:center;justify-content:center;overflow:hidden}.library-card-image:before{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(135deg,transparent 0%,transparent 40%,rgba(255,255,255,.08) 45%,rgba(255,255,255,.12) 50%,rgba(255,255,255,.08) 55%,transparent 60%,transparent 100%);pointer-events:none;z-index:5}.library-card-image:after{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(-45deg,transparent 0%,transparent 35%,rgba(173,43,238,.1) 45%,rgba(173,43,238,.15) 50%,rgba(173,43,238,.1) 55%,transparent 65%,transparent 100%);pointer-events:none;z-index:5}.library-card-center{position:relative;width:55%;height:55%;border-radius:50%;overflow:hidden;box-shadow:0 0 0 3px #00000080,0 0 15px #ad2bee4d;z-index:2}.library-card-center img{width:100%;height:100%;object-fit:cover}.library-card-overlay{position:absolute;bottom:0;left:0;right:0;display:flex;flex-direction:column;align-items:center;padding:.5rem;background:linear-gradient(to top,rgba(18,10,22,.95),transparent);opacity:0;transition:opacity .3s;z-index:10}.library-card:hover .library-card-overlay{opacity:1}.library-card-title{font-size:.75rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:center;max-width:100%}.library-card-date{font-size:.5rem;font-weight:500;color:#fff9;margin-top:.125rem}.library-albums{flex:1;display:flex;flex-direction:column;gap:.5rem;padding:1rem 1rem 6rem;overflow-y:auto}.library-album-wrapper{background:#ffffff08;border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,.06)}.library-album-header{display:flex;align-items:center;gap:1rem;padding:.875rem 1rem;cursor:pointer;transition:background .2s}.library-album-header:hover{background:#ffffff0d}.library-album-header.expanded{background:#ad2bee1a;border-bottom:1px solid rgba(173,43,238,.2)}.library-album-cover{width:56px;height:56px;border-radius:8px;overflow:hidden;flex-shrink:0;box-shadow:0 4px 12px #0000004d}.library-album-cover img{width:100%;height:100%;object-fit:cover}.library-album-info{flex:1;min-width:0}.library-album-name{font-size:1rem;font-weight:600;color:#fff;margin:0 0 .25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.library-album-count{font-size:.8rem;color:#ffffff80;margin:0}.library-album-arrow{width:28px;height:28px;display:flex;align-items:center;justify-content:center;color:#fff6;transition:transform .3s ease}.library-album-arrow svg{width:24px;height:24px}.library-album-arrow.expanded{transform:rotate(180deg);color:var(--primary)}.library-track-list{max-height:0;overflow:hidden;transition:max-height .4s ease-out;background:#0003}.library-track-list.expanded{max-height:1000px;transition:max-height .5s ease-in}.library-track-empty{padding:1.5rem;text-align:center;color:#fff6;font-size:.875rem}.library-track-item{display:flex;align-items:center;gap:.625rem;padding:.75rem 1rem;cursor:pointer;transition:background .2s;border-bottom:1px solid rgba(255,255,255,.04)}.library-track-item:last-child{border-bottom:none}.library-track-item:hover{background:#ffffff0d}.library-track-item:active{background:#ad2bee26}.library-track-number{width:24px;font-size:.8rem;color:#fff6;text-align:center;flex-shrink:0;display:flex;align-items:center;justify-content:center}.library-equalizer{display:flex;align-items:flex-end;gap:2px;height:14px}.library-eq-bar{width:3px;background:var(--primary);border-radius:1px;animation:eqBounce .8s ease-in-out infinite}.library-eq-bar:nth-child(1){animation-delay:0s}.library-eq-bar:nth-child(2){animation-delay:.2s}.library-eq-bar:nth-child(3){animation-delay:.4s}.library-eq-bar:nth-child(4){animation-delay:.1s}.library-equalizer.paused .library-eq-bar{animation:none}.library-equalizer.paused .library-eq-bar:nth-child(1){height:10px}.library-equalizer.paused .library-eq-bar:nth-child(2){height:5px}.library-equalizer.paused .library-eq-bar:nth-child(3){height:13px}.library-equalizer.paused .library-eq-bar:nth-child(4){height:7px}@keyframes eqBounce{0%,to{height:4px}50%{height:14px}}.library-track-thumb{width:44px;height:44px;border-radius:6px;overflow:hidden;flex-shrink:0;box-shadow:0 2px 8px #0003}.library-track-thumb img{width:100%;height:100%;object-fit:cover}.library-track-info{flex:1;min-width:0;margin-right:.15rem}.library-track-actions{display:flex;align-items:center;gap:.45rem;flex-shrink:0;margin-left:.1rem}.library-track-title{font-size:.9rem;font-weight:500;color:#fff;margin:0 0 .2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.library-track-meta{font-size:.75rem;color:#fff6;margin:0}.library-track-play{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--primary);border-radius:50%;color:#fff;flex-shrink:0;box-shadow:0 2px 8px #ad2bee66;transition:transform .2s,box-shadow .2s}.library-track-play:hover{transform:scale(1.05);box-shadow:0 4px 12px #ad2bee80}.library-track-play svg{width:18px;height:18px;margin-left:2px}.lyrics-modal-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease}.lyrics-modal{width:100%;max-width:480px;max-height:85vh;background:linear-gradient(180deg,#1c1022,#0a050d);border-radius:1.5rem 1.5rem 0 0;display:flex;flex-direction:column;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.lyrics-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.lyrics-modal-title{font-size:1.125rem;font-weight:700;color:var(--text-primary)}.lyrics-modal-close{width:32px;height:32px;border-radius:50%;background:#ffffff1a;border:none;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.lyrics-modal-close:hover{background:#fff3}.lyrics-modal-close svg{width:20px;height:20px}.lyrics-modal-content{flex:1;overflow-y:auto;padding:1.5rem 1.5rem 2rem}.lyrics-modal-content .lyrics-section{margin-bottom:1.5rem}.lyrics-modal-content .lyrics-section-label{font-size:.75rem;color:var(--primary);margin-bottom:.5rem;font-weight:600}.lyrics-modal-content .lyrics-section-card{background:#ffffff08;border-radius:.75rem;padding:1rem;border:1px solid var(--border-subtle)}.lyrics-modal-content .lyrics-section-card.chorus{background:#ad2bee1a;border-color:#ad2bee4d}.lyrics-modal-content .lyrics-section-text{font-size:.9375rem;line-height:1.8;color:var(--text-primary)}.library-card{cursor:pointer;transition:transform .2s}.library-card:hover{transform:scale(1.02)}.library-card-image{position:relative}.library-card-play-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0006;border-radius:inherit;opacity:0;transition:opacity .2s}.library-card:hover .library-card-play-icon{opacity:1}.library-card-play-icon svg{width:40px;height:40px;color:#fff;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.toast-container{position:fixed;bottom:90px;left:50%;transform:translate(-50%);z-index:9999;pointer-events:none}.toast-message{background:#ffffff26;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);color:var(--text-primary);padding:.625rem 1.25rem;border-radius:999px;font-size:.825rem;font-weight:500;border:1px solid rgba(255,255,255,.1);animation:none;white-space:nowrap}@keyframes toastIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.producing-lyrics-scroll-container{width:100%;min-height:100px;max-height:28vh;overflow:hidden;position:relative;margin-top:1rem;flex:1}.producing-lyrics-scroll-container:before,.producing-lyrics-scroll-container:after{content:"";position:absolute;left:0;right:0;height:30px;z-index:1;pointer-events:none}.producing-lyrics-scroll-container:before{top:0;background:linear-gradient(to bottom,var(--bg-primary, #0a0a0a),transparent)}.producing-lyrics-scroll-container:after{bottom:0;background:linear-gradient(to top,var(--bg-primary, #0a0a0a),transparent)}.producing-lyrics-scroll{animation:lyricsScrollUp 30s linear infinite;display:flex;flex-direction:column;gap:.75rem;padding:30px 0}@keyframes lyricsScrollUp{0%{transform:translateY(0)}to{transform:translateY(-50%)}}.producing-lyrics-section{text-align:center}.producing-lyrics-tag{font-size:.7rem;font-weight:600;color:#ffffff59;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.producing-lyrics-line{font-size:.8rem;color:#ffffff8c;line-height:1.6}.free-gen-banner{margin-top:auto;padding:.5rem 1.25rem;background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:999px;font-size:.825rem;font-weight:500;color:var(--text-primary);text-align:center;animation:freeGenPulse 4s ease-in-out infinite;flex-shrink:0}@keyframes freeGenPulse{0%,to{opacity:1}50%{opacity:.3}}.library-search-bar{display:flex;align-items:center;padding:0 1rem .75rem;gap:.5rem;position:relative}.library-search-icon{position:absolute;left:1.75rem;width:18px;height:18px;color:var(--text-muted);pointer-events:none}.library-search-input{flex:1;background:#ffffff0f;border:1px solid var(--border-subtle);border-radius:12px;padding:.625rem 1rem .625rem 2.5rem;color:var(--text-primary);font-size:.875rem;outline:none;transition:border-color .2s}.library-search-input:focus{border-color:var(--primary)}.library-search-input::placeholder{color:var(--text-muted)}.library-search-clear{width:32px;height:32px;background:#ffffff0f;border:none;border-radius:50%;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.library-search-clear svg{width:16px;height:16px}.library-track-move,.library-track-delete{width:34px;height:34px;border:1px solid rgba(255,255,255,.15);border-radius:8px;background:#ffffff0f;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:0;transition:color .2s,background .2s,border-color .2s}.library-track-move svg,.library-track-delete svg{width:17px;height:17px}.library-track-move:hover{color:var(--blue-accent);background:#3b82f626;border-color:#3b82f64d}.library-track-delete:hover{color:#ef4444;background:#ef444426;border-color:#ef44444d}.library-album-actions{display:flex;gap:4px;margin-right:4px;flex-shrink:0}.library-album-edit-btn,.library-album-delete-btn{width:28px;height:28px;border:none;border-radius:50%;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .2s,background .2s;opacity:0}.library-album-header:hover .library-album-edit-btn,.library-album-header:hover .library-album-delete-btn{opacity:1}.library-album-edit-btn svg,.library-album-delete-btn svg{width:16px;height:16px}.library-album-edit-btn:hover{color:var(--primary);background:var(--primary-light)}.library-album-delete-btn:hover{color:#ef4444;background:#ef44441a}.library-album-name-input{background:#ffffff0f;border:1px solid var(--primary);border-radius:8px;padding:.25rem .5rem;color:var(--text-primary);font-size:.875rem;font-weight:600;outline:none;width:100%}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1.5rem}.modal-content{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:20px;padding:1.5rem;width:100%;max-width:320px;animation:modalIn .2s ease}@keyframes modalIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-title{font-size:1.125rem;font-weight:700;margin-bottom:.75rem;color:var(--text-primary)}.modal-desc{font-size:.825rem;color:var(--text-secondary);margin-bottom:1.25rem;line-height:1.5}.modal-input{width:100%;background:#ffffff0f;border:1px solid var(--border-subtle);border-radius:12px;padding:.75rem 1rem;color:var(--text-primary);font-size:.875rem;outline:none;margin-bottom:1.25rem;transition:border-color .2s}.modal-input:focus{border-color:var(--primary)}.modal-input::placeholder{color:var(--text-muted)}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.modal-btn-cancel{padding:.5rem 1rem;border:1px solid var(--border-subtle);border-radius:10px;background:transparent;color:var(--text-secondary);font-size:.825rem;font-weight:500;cursor:pointer;transition:background .2s}.modal-btn-cancel:hover{background:#ffffff0d}.modal-btn-confirm{padding:.5rem 1rem;border:none;border-radius:10px;background:var(--primary);color:#fff;font-size:.825rem;font-weight:600;cursor:pointer;transition:opacity .2s}.modal-btn-confirm:hover{opacity:.9}.modal-btn-danger{padding:.5rem 1rem;border:none;border-radius:10px;background:#ef4444;color:#fff;font-size:.825rem;font-weight:600;cursor:pointer;transition:opacity .2s}.modal-btn-danger:hover{opacity:.9}.modal-album-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem;max-height:240px;overflow-y:auto}.modal-album-option{display:block;width:100%;text-align:left;padding:.75rem 1rem;background:#ffffff0a;border:1px solid var(--border-subtle);border-radius:12px;color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:background .2s,border-color .2s}.modal-album-option:hover{background:#ffffff14;border-color:var(--primary)}.modal-album-option.unsorted{color:var(--text-secondary);border-style:dashed}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;display:flex;justify-content:space-around;align-items:center;padding:.5rem 0 calc(.5rem + env(safe-area-inset-bottom,0px));background:#0a050de6;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid var(--border-subtle);z-index:50}.nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:.25rem 1rem;border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:color .2s;font-size:.625rem;font-weight:600;letter-spacing:.05em}.nav-item svg{width:22px;height:22px}.nav-item.active{color:var(--primary)}.nav-item:hover:not(.active){color:var(--text-secondary)}.player-inline-lyrics{width:100%;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.player-lyrics-block{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:12px;overflow:hidden;transition:all .3s ease}.player-lyrics-block.chorus{background:#ad2bee0d;border-color:#ad2bee26}.player-lyrics-block-header{display:flex;align-items:center;justify-content:space-between;padding:.625rem 1rem;cursor:pointer;transition:background .2s}.player-lyrics-block-header:hover{background:#ffffff08}.player-lyrics-block-label{font-size:.7rem;font-weight:600;color:var(--primary);text-transform:uppercase;letter-spacing:.1em}.player-lyrics-block-arrow{width:16px;height:16px;color:var(--text-muted);transition:transform .3s ease}.player-lyrics-block-arrow.expanded{transform:rotate(180deg);color:var(--primary)}.player-lyrics-block-content{max-height:0;overflow:hidden;transition:max-height .3s ease-out}.player-lyrics-block-content.expanded{max-height:300px;transition:max-height .4s ease-in}.player-lyrics-block-text{padding:0 1rem .75rem;font-size:.8rem;line-height:1.7;color:#ffffffb3;font-style:italic;margin:0}.player-lyrics-block.chorus .player-lyrics-block-text{color:#ffffffd9;font-weight:500}.library-toolbar{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;padding:.5rem 1rem}.library-toolbar-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;padding:0;background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;cursor:pointer;transition:background .2s}.library-toolbar-btn:hover{background:#ffffff26;border-color:var(--primary)}.library-toolbar-btn svg{width:20px;height:20px}.library-album-cover.genre-cover{background:linear-gradient(135deg,var(--primary) 0%,#8b1bc0 100%);display:flex;align-items:center;justify-content:center}.library-album-cover.genre-cover span{font-size:.6rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.05em}.library-album-cover.genre-cover img{display:none}.auth-main{flex:1;display:flex;flex-direction:column;align-items:center;padding:1.5rem 1.5rem 6rem;margin-top:56px;gap:1.25rem;max-width:400px;margin-left:auto;margin-right:auto;width:100%}.auth-tabs{display:flex;width:100%;background:#ffffff0d;border-radius:12px;padding:4px;gap:4px}.auth-tab{flex:1;padding:.6rem 0;border:none;border-radius:10px;background:transparent;color:var(--text-secondary);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.auth-tab.active{background:var(--primary);color:#fff}.auth-error{width:100%;padding:.75rem 1rem;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:10px;color:#f87171;font-size:.8rem;text-align:center}.auth-confirmation{display:flex;flex-direction:column;align-items:center;text-align:center;gap:1rem;padding:2rem 0;width:100%}.auth-confirmation-icon{width:64px;height:64px;border-radius:50%;background:#a855f726;display:flex;align-items:center;justify-content:center;color:var(--primary)}.auth-confirmation-icon svg{width:32px;height:32px}.auth-confirmation-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.auth-confirmation-email{font-size:.9rem;color:var(--primary);font-weight:600;margin:0}.auth-confirmation-desc{font-size:.85rem;color:var(--text-secondary);line-height:1.6;margin:0;white-space:pre-line}.auth-form{width:100%;display:flex;flex-direction:column;gap:.75rem}.auth-input{width:100%;padding:.85rem 1rem;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:12px;color:var(--text-primary);font-size:.9rem;outline:none;transition:border-color .2s}.auth-input:focus{border-color:var(--primary)}.auth-input::placeholder{color:var(--text-muted)}.auth-forgot-btn{align-self:flex-end;background:none;border:none;color:var(--primary);font-size:.75rem;cursor:pointer;padding:0;margin-top:-.25rem}.auth-forgot-btn:hover{text-decoration:underline}.auth-submit{width:100%;padding:.85rem;background:linear-gradient(135deg,var(--primary),#8b1bc0);border:none;border-radius:12px;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:opacity .2s;display:flex;align-items:center;justify-content:center;gap:.5rem;min-height:48px}.auth-submit:hover{opacity:.9}.auth-submit:disabled{opacity:.5;cursor:not-allowed}.auth-divider{width:100%;display:flex;align-items:center;gap:1rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border-subtle)}.auth-divider span{color:var(--text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.auth-social{width:100%;display:flex;flex-direction:column;gap:.6rem}.auth-social-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.75rem;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:12px;color:var(--text-primary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.auth-social-btn:hover{background:#ffffff1a;border-color:#fff3}.auth-social-btn:disabled{opacity:.5;cursor:not-allowed}.auth-social-btn svg{width:20px;height:20px;flex-shrink:0}.auth-inapp-notice{width:100%;display:flex;flex-direction:column;gap:.75rem}.auth-inapp-notice p{font-size:.8rem;color:var(--text-secondary);text-align:center;line-height:1.5;margin:0}.auth-switch{display:flex;align-items:center;gap:.4rem;font-size:.8rem;color:var(--text-secondary)}.auth-switch-btn{background:none;border:none;color:var(--primary);font-size:.8rem;font-weight:600;cursor:pointer;padding:0}.auth-switch-btn:hover{text-decoration:underline}.auth-guest-btn{width:100%;padding:.7rem;background:transparent;border:1px dashed rgba(255,255,255,.2);border-radius:12px;color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all .2s}.auth-guest-btn:hover{border-color:#fff6;color:var(--text-primary)}.mypage-container{flex:1;padding:1rem 1rem 2rem;margin-top:56px;padding-bottom:80px;display:flex;flex-direction:column;gap:1.25rem}.mypage-profile-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:16px}.mypage-avatar{width:56px;height:56px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid var(--primary)}.mypage-avatar-placeholder{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#8b1bc0);display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:700;color:#fff;flex-shrink:0}.mypage-profile-info{overflow:hidden;flex:1}.mypage-profile-name{font-size:1rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mypage-profile-email{font-size:.8rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:.15rem}.mypage-menu{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:16px;overflow:hidden}.mypage-menu-item{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:none;border:none;border-bottom:1px solid var(--border-subtle);color:var(--text-primary);font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s;text-align:left}.mypage-menu-item:last-child{border-bottom:none}.mypage-menu-item:hover{background:#ffffff08}.mypage-menu-item-left{display:flex;align-items:center;gap:.75rem}.mypage-menu-item-left svg{width:20px;height:20px;color:var(--text-secondary);flex-shrink:0}.mypage-menu-item-desc{font-size:.75rem;color:var(--text-muted);margin-top:.15rem}.mypage-menu-item-right{display:flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.8rem}.mypage-menu-item-right svg{width:18px;height:18px}.mypage-lang-badge{padding:.2rem .5rem;border-radius:8px;background:#ffffff14;font-size:.75rem;font-weight:600;color:var(--text-secondary)}.mypage-logout-item{color:#f87171}.mypage-logout-item svg{color:#f87171!important}.mypage-delete-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.85rem;background:none;border:1px solid rgba(239,68,68,.2);border-radius:12px;color:var(--text-muted);font-size:.8rem;cursor:pointer;transition:all .2s}.mypage-delete-btn:hover{background:#ef444414;border-color:#ef444466;color:#f87171}.mypage-modal-backdrop{position:fixed;inset:0;width:100vw;height:100vh;background:#000000b3;z-index:9999;display:flex;align-items:center;justify-content:center;padding:1.5rem}.mypage-modal{width:100%;max-width:340px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:20px;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;text-align:center}.mypage-modal h3{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.mypage-modal p{font-size:.85rem;color:var(--text-secondary);line-height:1.5}.mypage-modal-actions{display:flex;flex-direction:column;gap:.5rem;margin-top:.25rem}.mypage-modal-delete-btn{padding:.75rem;background:#dc2626;border:none;border-radius:12px;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s}.mypage-modal-delete-btn:hover{background:#b91c1c}.mypage-modal-delete-btn:disabled{opacity:.6;cursor:not-allowed}.mypage-modal-cancel-btn{padding:.75rem;background:#ffffff0f;border:1px solid var(--border-subtle);border-radius:12px;color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.mypage-modal-cancel-btn:hover{background:#ffffff1a}.nav-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover;border:2px solid var(--primary)}.account-avatar{width:22px;height:22px;border-radius:50%;object-fit:cover;border:2px solid var(--primary)}.account-initial-btn{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#8b1bc0);border:none;color:#fff;font-size:.8rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .2s}.account-initial-btn:hover{opacity:.85}.auth-generate-btn{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.5rem .75rem;background:#ffffff0f;border:1px dashed rgba(255,255,255,.2);border-radius:10px;color:var(--text-secondary);font-size:.75rem;cursor:pointer;transition:all .2s;align-self:flex-start;margin-top:-.25rem}.auth-generate-btn:hover{border-color:var(--primary);color:var(--primary)}.auth-generate-btn svg{width:16px;height:16px}.nav-login-btn{padding:.3rem .75rem;border-radius:12px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);color:var(--text-secondary);font-size:.7rem;font-weight:600;letter-spacing:.02em;cursor:pointer;transition:all .2s;white-space:nowrap;align-self:center}.image-toggle-hint{position:absolute;bottom:8px;left:50%;transform:translate(-50%);background:#0009;color:#fffc;font-size:.6rem;padding:2px 8px;border-radius:8px;white-space:nowrap;pointer-events:none;opacity:.7;transition:opacity .3s;z-index:20}.player-vinyl-center:hover .image-toggle-hint{opacity:1}.library-track-thumb{cursor:pointer}@supports (-webkit-touch-callout: none){@media(max-width:768px){.keyword-field,.sentence-field,.library-search-input,.library-album-name-input,.modal-input,.auth-input{font-size:16px}}}
