@import "https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=Epilogue:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&display=swap";:root{--bg-0:oklch(10% .025 75);--bg-1:oklch(13% .022 75);--bg-2:oklch(17% .02 75);--bg-3:oklch(22% .018 75);--bg-4:oklch(27% .015 75);--border:oklch(100% 0 0/.07);--border-md:oklch(100% 0 0/.12);--border-bright:oklch(82% .17 80/.3);--border-warm:oklch(80% .17 80/.18);--ink:oklch(80% .17 80);--ink-dim:oklch(80% .17 80/.14);--ink-pale:oklch(80% .17 80/.07);--ink-soft:oklch(80% .17 80/.65);--amber:var(--ink);--amber-dim:var(--ink-dim);--amber-soft:var(--ink-soft);--teal:oklch(65% .01 75);--teal-dim:oklch(65% .01 75/.12);--sage:oklch(65% .01 75);--sage-dim:oklch(65% .01 75/.12);--text-0:oklch(97% .006 80);--text-1:oklch(85% .008 75);--text-2:oklch(65% .01 75);--text-3:oklch(50% .008 75);--color-success:oklch(76% .15 162);--color-error:oklch(71% .16 25);--color-info:oklch(72% .12 245);--color-success-bg:oklch(76% .15 162/.1);--color-error-bg:oklch(71% .16 25/.1);--color-info-bg:oklch(72% .12 245/.1);--green:var(--color-success);--red:var(--color-error);--font-display:"Bricolage Grotesque", system-ui, sans-serif;--font-body:"Epilogue", system-ui, sans-serif;--r-xs:4px;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:20px;--r-2xl:28px;--r-full:999px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:24px;--space-6:32px;--space-7:48px;--space-8:64px;--space-9:96px;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-in-out:cubic-bezier(.65, 0, .35, 1);--duration-quick:.15s;--duration-normal:.25s;--duration-smooth:.35s;--duration-slow:.6s;--frame-w:480px;--sidebar-w:260px;--content-max:1400px;--reading-max:720px;--top-nav-h:60px;--player-h:76px;--deletion-banner-h:0px;--nav-h:72px;--mp-h:0px}@media (width>=768px){:root{--nav-h:0px}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;overscroll-behavior:none;scroll-behavior:smooth;height:100%}body{font-family:var(--font-body);background:var(--bg-0);color:var(--text-0);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior:none;min-height:100dvh;font-size:15px;line-height:1.55;position:relative;overflow-x:hidden}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{appearance:none;font:inherit;color:inherit;cursor:pointer;background:0 0;border:none;margin:0;padding:0}input,textarea{font-family:inherit}body:before{content:"";pointer-events:none;z-index:9999;opacity:.045;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:128px;position:fixed;inset:0}#root{flex-direction:column;min-height:100dvh;display:flex}::-webkit-scrollbar{width:3px;height:3px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--bg-4);border-radius:99px}::selection{background:var(--ink-dim);color:var(--ink)}:focus-visible{outline:2px solid var(--ink);outline-offset:3px;border-radius:4px}::placeholder{color:var(--text-3);opacity:1}@keyframes fade-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes scale-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes waveform{0%,to{transform:scaleY(.35)}50%{transform:scaleY(1)}}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.75)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes ocrScan{0%{top:6%}to{top:94%}}@keyframes fieldPulse{0%{box-shadow:0 0 oklch(80% .17 80/.55)}40%{box-shadow:0 0 0 4px oklch(80% .17 80/.25)}to{box-shadow:0 0 oklch(80% .17 80/0)}}@keyframes ob-spin{to{transform:rotate(360deg)}}@keyframes auth-spin{to{transform:rotate(360deg)}}@keyframes ob-wave{0%,to{transform:scaleY(.3)}50%{transform:scaleY(1)}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.waveform-bar,.mp-disc--spinning,.ob-cta-spinner,.practice-spinner,.pending-draft-dot,.card-flipper{transition:none!important;animation:none!important}}.animate-fade-up{animation:fade-up .45s var(--ease-out) both}.animate-fade-in{animation:.3s both fade-in}.animate-scale-in{animation:scale-in .3s var(--ease-out) both}.delay-1{animation-delay:60ms}.delay-2{animation-delay:.12s}.delay-3{animation-delay:.18s}.delay-4{animation-delay:.24s}.delay-5{animation-delay:.3s}.spin{animation:.8s linear infinite spin}.skeleton{background:var(--bg-3);background-image:linear-gradient(90deg, var(--bg-3) 0%, var(--bg-4) 50%, var(--bg-3) 100%);border-radius:var(--r-sm);background-size:200% 100%;animation:1.8s infinite shimmer}.card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-lg);transition:background var(--duration-normal), border-color var(--duration-normal), transform var(--duration-normal) var(--ease-out)}.card:hover{background:var(--bg-3)}.card:active{transform:scale(.985)}.safe-top{padding-top:env(safe-area-inset-top)}.safe-bottom{padding-bottom:env(safe-area-inset-bottom)}.wc-song,.sc-compact-genre,.sh-badge,.lib-tab-count,.sc-meta-pill,.scrubber-times,.hook-num-sub,.moment-chip,.ob-fine,.auth-signup-note,.auth-legal,.settings-version,.loading-elapsed,.card-tap-cue,.proof-sub,.card-counter,.grade-prompt,.he-step,.ps-pl-count,.pl-count,.sc-compact-count,.settings-section-label,.input-label,.review-concepts-label,.review-section-label,.he-label,.card-face-label,.lyrics-section-label,.sc-label,.home-subline,.gen-sub,.review-summary,.auth-tagline,.sc-compact-genre,.auth-card-sub,.hcc-genre,.ccc-sub,.wc-song,.pick-intro-card .pic-body,.auth-resend,.done-subtitle,.done-body,.contact-intro,.auth-legal{color:var(--text-1)}.auth-legal a{color:var(--text-0)}.nav-item.active .nav-label{color:var(--ink);font-weight:600}.sc-compact-title{font-size:14px}.home-subline{color:var(--text-1);font-size:14px}.auth-screen{justify-content:center;align-items:center;min-height:100dvh;padding:24px 20px;display:flex;position:relative}.auth-bg{display:none}.auth-content{flex-direction:column;gap:28px;width:100%;max-width:380px;display:flex;position:relative}.auth-logo{flex-direction:column;align-items:flex-start;gap:10px;display:flex}.auth-logo-link{-webkit-tap-highlight-color:transparent;transition:opacity var(--duration-quick);flex-direction:column;align-items:flex-start;gap:8px;text-decoration:none;display:flex}.auth-logo-link:hover{opacity:.82}.auth-logo-link:before{content:"memembery";font-family:var(--font-display);letter-spacing:.14em;text-transform:uppercase;color:var(--ink);align-items:center;gap:8px;font-size:10px;font-weight:700;display:inline-flex}.auth-brand{font-family:var(--font-display);letter-spacing:-.045em;color:var(--text-0);font-size:52px;font-weight:900;line-height:.9}.auth-tagline{color:var(--text-2);margin-top:8px;font-size:14px;line-height:1.5}.auth-card{background:var(--bg-2);border:1.5px solid var(--border-md);border-radius:var(--r-xl);flex-direction:column;gap:14px;padding:28px 24px;display:flex}.auth-card-title{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.02em;font-size:22px;font-weight:800}.auth-card-sub{color:var(--text-1);font-size:14px;line-height:1.55}.auth-card-sub strong{color:var(--text-0);font-weight:500}.auth-form{flex-direction:column;gap:10px;margin-top:4px;display:flex}.auth-input-wrap{position:relative}.auth-input{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r-md);width:100%;color:var(--text-0);transition:border-color var(--duration-quick), box-shadow var(--duration-quick);outline:none;padding:12px 16px;font-size:15px}.auth-input:focus{border-color:var(--border-bright);box-shadow:0 0 0 3px var(--ink-dim)}.auth-input::placeholder{color:var(--text-3)}.auth-otp-input{font-family:var(--font-display);letter-spacing:8px;text-align:center;font-size:22px}.auth-btn{background:var(--ink);color:oklch(10% .025 75);border-radius:var(--r-md);width:100%;font-size:14px;font-weight:700;font-family:var(--font-display);transition:opacity var(--duration-quick), transform var(--duration-quick) var(--ease-out);justify-content:center;align-items:center;gap:8px;padding:13px;display:flex}.auth-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.auth-btn:active:not(:disabled){transform:translateY(0)}.auth-btn:disabled{opacity:.4;cursor:not-allowed}.auth-error{color:var(--color-error);background:var(--color-error-bg);border-radius:var(--r-sm);border:1px solid oklch(71% .16 25/.22);padding:8px 12px;font-size:13px}.auth-resend{color:var(--text-2);text-align:center;transition:color var(--duration-quick);padding:4px;font-size:13px}.auth-resend:hover:not(:disabled){color:var(--text-1)}.auth-back{color:var(--text-2);transition:color var(--duration-quick);align-items:center;gap:6px;width:fit-content;min-height:44px;margin-bottom:4px;font-size:13px;display:flex}.auth-back:hover{color:var(--text-1)}.auth-share-notice{border-radius:var(--r-md);color:var(--sage);background:oklch(65% .01 75/.08);border:1px solid oklch(65% .01 75/.18);align-items:center;gap:8px;padding:10px 14px;font-size:13px;display:flex}.auth-share-notice svg{flex-shrink:0}.auth-signup-icon,.auth-verified-icon{background:var(--ink-dim);border:1px solid var(--border-bright);width:50px;height:50px;color:var(--ink);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 4px;display:flex}.auth-signup-note{color:var(--text-3);text-align:center;font-size:13px;line-height:1.55}.auth-signup-actions{flex-direction:column;gap:10px;display:flex}.auth-legal{color:var(--text-3);text-align:center;font-size:13px;line-height:1.55}.auth-legal a{color:var(--text-2);text-underline-offset:2px;text-decoration:underline}.auth-legal a:hover{color:var(--ink)}.auth-greeting{align-items:flex-start;gap:13px;display:flex}.auth-greeting-icon{border-radius:var(--r-sm);background:var(--ink-dim);width:36px;height:36px;color:var(--ink);flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;display:flex}.auth-greeting>div{flex-direction:column;gap:5px;display:flex}.auth-signup-row{justify-content:center;align-items:center;gap:6px;padding-top:4px;display:flex}.auth-signup-row-text{color:var(--text-3);font-size:13px}.auth-signup-row-btn{color:var(--ink);text-underline-offset:2px;-webkit-tap-highlight-color:transparent;transition:opacity var(--duration-quick);align-items:center;min-height:44px;font-size:13px;font-weight:600;text-decoration:underline;display:inline-flex}.auth-signup-row-btn:hover{opacity:.75}.auth-help-row{flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;display:flex}.auth-help-divider{color:var(--text-3);font-size:13px;line-height:1}.auth-sms-sent{color:var(--text-2);align-items:center;gap:4px;font-size:13px;display:flex}.sms-modal-backdrop{z-index:200;background:oklch(0% 0 0/.55);justify-content:center;align-items:flex-end;padding:0 16px 24px;display:flex;position:fixed;inset:0}@media (height>=600px){.sms-modal-backdrop{align-items:center}}.sms-modal{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-xl);flex-direction:column;gap:14px;width:100%;max-width:380px;padding:20px;display:flex}.sms-modal-header{align-items:flex-start;gap:12px;display:flex}.sms-modal-icon{border-radius:var(--r-sm);background:var(--ink-dim);width:36px;height:36px;color:var(--ink);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sms-modal-title{font-family:var(--font-display);color:var(--text-0);font-size:16px;font-weight:700;line-height:1.2}.sms-modal-sub{color:var(--text-2);margin-top:3px;font-size:13px;line-height:1.5}.sms-modal-close{width:44px;height:44px;color:var(--text-3);transition:background var(--duration-quick), color var(--duration-quick);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;display:flex}.sms-modal-close:hover{background:var(--bg-3);color:var(--text-1)}.sms-modal-body{flex-direction:column;gap:6px;display:flex}.sms-modal-input-error{border-color:var(--color-error);box-shadow:0 0 0 2px oklch(71% .16 25/.4)}.sms-modal-field-error{color:var(--color-error);padding-left:2px;font-size:12px}.sms-modal-hint{color:var(--text-3);padding-left:2px;font-size:12px}.sms-modal-error{margin:0}.sms-modal-actions{gap:10px;display:flex}.sms-modal-cancel{background:var(--bg-3);border-radius:var(--r-md);color:var(--text-1);transition:background var(--duration-quick);flex:1;padding:11px;font-size:14px;font-weight:500}.sms-modal-cancel:hover:not(:disabled){background:var(--bg-4)}.sms-modal-send{background:var(--ink);color:oklch(10% .025 75);border-radius:var(--r-md);font-size:14px;font-weight:700;font-family:var(--font-display);transition:opacity var(--duration-quick);flex:2;justify-content:center;align-items:center;padding:11px;display:flex}.sms-modal-send:hover:not(:disabled){opacity:.9}.sms-modal-send:disabled{opacity:.4;cursor:not-allowed}.terms-screen{justify-content:center;align-items:center;min-height:100dvh;padding:24px 20px;display:flex;position:relative;overflow:hidden}.terms-bg{pointer-events:none;position:absolute;inset:0}.terms-content{flex-direction:column;gap:14px;width:100%;max-width:380px;display:flex;position:relative}.terms-logo{justify-content:center;margin-bottom:4px;display:flex}.terms-title{font-family:var(--font-display);color:var(--text-0);text-align:center;letter-spacing:-.2px;font-size:22px;font-weight:600}.terms-subtitle{color:var(--text-1);text-align:center;margin-top:-6px;font-size:14px;font-style:italic;line-height:1.55}.terms-docs{flex-direction:column;gap:7px;display:flex}.terms-doc-link{background:var(--bg-2);border-radius:var(--r-md);border:none;align-items:center;gap:12px;padding:12px 13px;text-decoration:none;transition:border-color .2s,background .2s;display:flex}.terms-doc-link:hover{background:var(--bg-3)}.terms-doc-icon{background:var(--ink-dim);width:30px;height:30px;color:var(--ink);border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.terms-doc-info{flex-direction:column;flex:1;gap:2px;display:flex}.terms-doc-name{color:var(--text-0);font-size:14px;font-weight:500}.terms-doc-sub{color:var(--text-2);font-size:13px;font-style:italic}.terms-checkbox-row{cursor:pointer;align-items:flex-start;gap:12px;padding:4px 0;display:flex}.terms-checkbox{border:1.5px solid var(--border-md);background:var(--bg-2);cursor:pointer;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;margin-top:1px;transition:background .15s,border-color .15s;display:flex}.terms-checkbox.checked{background:var(--ink);border-color:var(--ink);color:#fff}.terms-checkbox-label{color:var(--text-1);font-size:13px;line-height:1.55}.terms-error{color:var(--red);border-radius:var(--r-sm);text-align:center;background:#facc1514;padding:8px 12px;font-size:13px}.terms-accept-btn{background:var(--ink);color:#fff;border-radius:var(--r-md);width:100%;font-family:var(--font-display);-webkit-tap-highlight-color:transparent;padding:14px;font-size:14px;font-weight:600;transition:background .15s,opacity .2s}.terms-accept-btn:disabled{opacity:.4;cursor:not-allowed}.terms-accept-btn:not(:disabled):hover{background:var(--ink-soft)}.terms-summary-card{background:var(--bg-2);border-radius:var(--r-lg);flex-direction:column;gap:10px;padding:16px 15px 14px;display:flex}.terms-summary-row{align-items:flex-start;gap:10px;display:flex}.terms-summary-check{background:var(--ink-dim);width:20px;height:20px;color:var(--ink);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;display:flex}.terms-summary-text{color:var(--text-0);font-size:13px;font-weight:500;line-height:1.55}.terms-summary-divider{background:var(--bg-3);height:1px;margin:2px 0}.terms-links-label{letter-spacing:.5px;text-transform:uppercase;color:var(--text-3);font-size:11px;font-weight:600}.terms-links-row{flex-wrap:wrap;gap:6px 14px;display:flex}.terms-policy-link{color:var(--text-2);text-underline-offset:2px;text-decoration:underline;-webkit-text-decoration-color:var(--bg-4);text-decoration-color:var(--bg-4);-webkit-tap-highlight-color:transparent;font-size:12px;transition:color .15s,text-decoration-color .15s}.terms-policy-link:hover{color:var(--ink);-webkit-text-decoration-color:var(--ink-dim);text-decoration-color:var(--ink-dim)}.paywall-overlay.fullscreen{z-index:1000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0a0a0c6b;position:fixed;inset:0}.paywall-sheet.fullscreen{background:var(--panel,#fff);border-radius:0;flex-direction:column;width:100vw;max-width:none;height:100vh;max-height:none;display:flex;position:relative;overflow:hidden}.paywall-close{z-index:3;width:40px;height:40px;color:var(--ink,#111);cursor:pointer;background:#00000014;border:0;border-radius:999px;font-size:26px;line-height:1;position:absolute;top:16px;right:16px}.paywall-close:hover{background:#0000001f}.paywall-loading{z-index:2;color:var(--ink,#111);background:#ffffffeb;border-radius:999px;padding:10px 14px;font-size:14px;font-weight:600;position:absolute;top:16px;left:16px}.paywall-hosted-container.fullscreen{background:0 0;border-radius:0;flex:1;width:100%;height:100%;min-height:100vh;margin:0;overflow:auto}.paywall-hosted-container.fullscreen.has-error{flex:none;min-height:0}.paywall-error-block{text-align:center;max-width:560px;margin:96px auto 24px;padding:0 24px}.paywall-title{color:var(--ink,#111);margin:0 0 10px;font-size:28px;font-weight:700;line-height:1.1}.paywall-subtitle{color:var(--muted,#666);margin:0 0 12px;font-size:15px;line-height:1.5}.paywall-error{color:#c0392b;margin:0;font-size:14px;line-height:1.5}.share-sheet{z-index:201;background:var(--bg-2);border-radius:var(--r-xl) var(--r-xl) 0 0;padding:12px 20px calc(24px + env(safe-area-inset-bottom));border:none;flex-direction:column;gap:13px;max-width:480px;margin:0 auto;display:flex;position:fixed;bottom:0;left:0;right:0}@media (width>=768px){.share-sheet{transform:translateX(calc(-50% + (var(--sidebar-w) / 2)));width:var(--frame-w);max-width:calc(100vw - var(--sidebar-w) - 40px);left:50%;right:auto;bottom:calc(var(--player-h) + 16px);border-radius:var(--r-xl);border:1px solid var(--border-md);margin:0;padding-bottom:24px}}.share-body{flex-direction:column;gap:10px;display:flex}.share-info{background:var(--sage-dim);border-radius:var(--r-sm);color:var(--sage);border:1px solid #5da0b526;align-items:flex-start;gap:8px;padding:10px 12px;font-size:13px;line-height:1.5;display:flex}.share-info svg{flex-shrink:0;margin-top:1px}.share-link-row{background:var(--bg-3);border-radius:var(--r-md);border:none;align-items:center;gap:8px;padding:9px 12px;display:flex}.share-link-text{color:var(--text-2);white-space:nowrap;text-overflow:ellipsis;flex:1;font-family:monospace;font-size:13px;overflow:hidden}.copy-btn{background:var(--ink);color:#fff;-webkit-tap-highlight-color:transparent;border-radius:7px;flex-shrink:0;align-items:center;gap:5px;padding:6px 11px;font-size:14px;font-weight:600;transition:background .15s;display:flex}.copy-btn.copied{background:var(--green);color:#fff}.native-share-btn{background:var(--bg-3);border-radius:var(--r-md);width:100%;color:var(--text-0);border:none;justify-content:center;align-items:center;gap:8px;padding:11px;font-size:14px;font-weight:400;transition:background .2s;display:flex}.native-share-btn:hover{background:var(--bg-4)}.revoke-btn{color:var(--text-3);text-align:center;padding:4px;font-size:14px;transition:color .2s}.revoke-btn:hover{color:var(--red)}.revoke-btn:disabled{opacity:.5}.share-revoked{color:var(--text-2);text-align:center;padding:8px 0;font-size:14px;font-style:italic}.share-no-link{flex-direction:column;gap:10px;display:flex}.share-create-btn{background:var(--ink);color:#fff;border-radius:var(--r-md);width:100%;font-family:var(--font-display);text-align:center;padding:13px;font-size:14px;font-weight:600;transition:opacity .2s}.share-create-btn:disabled{opacity:.5}.share-error{text-align:center;flex-direction:column;gap:10px;display:flex}.share-error p{color:var(--red);border-radius:var(--r-sm);background:#facc1514;padding:10px 12px;font-size:13px}.share-status-row{background:var(--bg-3);border-radius:var(--r-md);align-items:center;gap:8px;padding:9px 12px;display:flex}.share-status-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.share-status-private{background:var(--text-3)}.share-status-reported{background:var(--red)}.share-status-active{background:var(--green);box-shadow:none}.share-status-label{color:var(--text-1);font-size:13px;font-weight:400}.desktop-share-block{background:var(--bg-3);border-radius:var(--r-md);flex-direction:column;align-items:center;gap:10px;padding:16px 14px 14px;display:flex}.desktop-share-qr-wrap{background:#fff;border-radius:10px;padding:8px;line-height:0;box-shadow:0 1px 6px #0000001f}.desktop-share-hint{color:var(--text-3);text-align:center;margin:0;font-size:12px}.desktop-share-link-row{background:var(--bg-2);border-radius:var(--r-sm);align-items:center;gap:8px;width:100%;padding:8px 10px;display:flex}.desktop-share-link-text{color:var(--text-2);white-space:nowrap;text-overflow:ellipsis;flex:1;font-family:monospace;font-size:12px;overflow:hidden}.share-info{color:var(--sage);background:#5da0b517;border-color:#5da0b52e}.share-reported{flex-direction:column;gap:10px;display:flex}.share-reported-msg{color:var(--text-2);border-radius:var(--r-md);background:#f8717112;padding:12px 14px;font-size:14px;line-height:1.6}.referral-nudge{border-radius:var(--r-sm);color:var(--text-1);background:#fbbf2414;border:1px solid #fbbf2433;align-items:flex-start;gap:8px;padding:10px 12px;font-size:13px;line-height:1.5;display:flex}.referral-nudge svg{color:#f59e0b;flex-shrink:0;margin-top:1px}.send-song-btn{background:var(--ink);color:#fff;border-radius:var(--r-md);width:100%;font-family:var(--font-display);justify-content:center;align-items:center;gap:8px;padding:13px;font-size:15px;font-weight:600;transition:opacity .2s;display:flex}.send-song-btn:active{opacity:.85}.copy-btn-full{border-radius:var(--r-md);justify-content:center;width:100%;padding:13px;font-size:14px}.credit-badge{border:1.5px solid var(--ink-dim);background:var(--ink-pale);cursor:pointer;border-radius:20px;align-items:center;gap:5px;padding:6px 12px 6px 10px;transition:border-color .15s,background .15s;display:flex}.credit-badge:hover{background:var(--ink-dim)}.cb-icon{color:var(--ink);flex-shrink:0}.cb-count{font-family:var(--font-body);color:var(--ink);font-variant-numeric:tabular-nums;font-size:13px;font-weight:700;line-height:1}.lv-wrap{flex-direction:column;gap:2px;padding-bottom:24px;display:flex}.lv-timestamped{scrollbar-width:none;border:none;gap:0;max-height:160px;margin:20px 0;padding:14px 0;overflow-y:auto;-webkit-mask-image:linear-gradient(#0000 0%,#000 18% 82%,#0000 100%);mask-image:linear-gradient(#0000 0%,#000 18% 82%,#0000 100%)}.lv-timestamped::-webkit-scrollbar{display:none}.lv-constrained{scrollbar-width:thin;scrollbar-color:var(--border,#ffffff1f) transparent;background:var(--surface-2,#ffffff0a);border-radius:10px;gap:0;max-height:180px;padding:12px 14px;overflow-y:auto}.lv-constrained::-webkit-scrollbar{width:3px}.lv-constrained::-webkit-scrollbar-thumb{background:var(--border,#ffffff26);border-radius:2px}.lv-constrained .lv-line{font-size:13.5px;line-height:1.6}.lv-constrained .lv-section{margin-top:10px;margin-bottom:2px}.lv-section{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.12em;color:var(--ink);text-align:center;margin-top:14px;margin-bottom:4px;font-size:11px;font-style:normal;font-weight:700;line-height:1.6}.lv-line{color:var(--text-1);font-size:14px;line-height:1.9;font-family:var(--font-display);transition:color var(--duration-normal), opacity var(--duration-normal), font-size var(--duration-normal);text-align:center;padding:1px 0;position:relative}.lv-line.lv-anchor{color:var(--text-0);font-weight:600}.lv-playing .lv-line{color:var(--text-3);opacity:.5}.lv-playing .lv-line.lv-past{color:var(--text-3);opacity:.3}.lv-playing .lv-line.lv-active{color:var(--ink);opacity:1;font-size:15px;font-style:normal;font-weight:700}.lv-playing .lv-section{opacity:.4;transition:opacity .3s}.lv-playing .lv-section:has(~.lv-line.lv-active){opacity:1}.pick-lyrics-wrap{flex-direction:column;gap:8px;display:flex}.pick-lyrics-label{color:var(--text-2);text-transform:uppercase;letter-spacing:.7px;font-size:13px;font-weight:600}.pick-plain-lyrics{scrollbar-width:none;flex-direction:column;gap:0;max-height:160px;padding:14px 0;display:flex;overflow-y:auto;-webkit-mask-image:linear-gradient(#0000 0%,#000 15% 85%,#0000 100%);mask-image:linear-gradient(#0000 0%,#000 15% 85%,#0000 100%)}.pick-plain-lyrics::-webkit-scrollbar{display:none}.pick-plain-lyric-line{font-size:14px;font-family:var(--font-display);color:var(--text-1);text-align:center;margin:0;padding:1px 0;line-height:1.9}.pick-step{flex-direction:column;gap:20px;padding-bottom:8px;display:flex}.pick-header{flex-direction:column;gap:5px;display:flex}.pick-title{font-family:var(--font-display);color:var(--text-0);font-size:20px;font-weight:600}.pick-sub{color:var(--text-2);font-size:13px;font-style:italic;line-height:1.55}.pick-cards{flex-direction:column;gap:12px;display:flex}.pick-card{background:var(--bg-2);border:1.5px solid var(--border-md);border-radius:var(--r-lg);cursor:pointer;-webkit-tap-highlight-color:transparent;text-align:left;flex-direction:column;gap:14px;width:100%;padding:16px;transition:border-color .2s,background .2s,box-shadow .2s;display:flex;position:relative}.pick-card:hover{background:var(--bg-3)}.pick-card.selected{border-color:var(--ink);background:var(--ink-pale);box-shadow:none}.pick-card-header{justify-content:space-between;align-items:center;display:flex}.pick-version-label{text-transform:uppercase;letter-spacing:.9px;color:var(--text-2);font-size:13px;font-weight:700}.pick-card.selected .pick-version-label{color:var(--ink)}.pick-radio{border:1.5px solid var(--border-warm);background:var(--bg-3);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;transition:border-color .2s,background .2s;display:flex}.pick-card.selected .pick-radio{border-color:var(--ink);background:var(--ink)}.pick-radio-dot{background:var(--bg-0);opacity:0;width:8px;height:8px;transition:opacity .18s, transform .18s var(--ease-spring);border-radius:50%;transform:scale(.4)}.pick-card.selected .pick-radio-dot{opacity:1;transform:scale(1)}.pick-player{background:var(--bg-3);border-radius:var(--r-md);align-items:center;gap:12px;padding:10px 14px;display:flex}.pick-play-btn{background:var(--bg-4);-webkit-tap-highlight-color:transparent;width:36px;height:36px;color:var(--text-1);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,border-color .15s;display:flex}.pick-play-btn:hover{background:var(--bg-0);color:var(--text-0)}.pick-play-btn.playing{background:var(--ink);border-color:var(--ink);color:#fff}.pick-progress-wrap{flex-direction:column;flex:1;gap:5px;min-width:0;display:flex}.pick-progress-bar{background:var(--bg-4);cursor:pointer;border-radius:99px;width:100%;height:3px;overflow:hidden}.pick-progress-fill{background:var(--ink);border-radius:99px;height:100%;transition:width .1s linear}.pick-time{color:var(--text-3);font-variant-numeric:tabular-nums;letter-spacing:.3px;font-size:13px}.pick-duration{color:var(--text-3);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:13px}.pick-confirm-btn{background:var(--ink);color:#fff;border-radius:var(--r-md);width:100%;font-family:var(--font-display);-webkit-tap-highlight-color:transparent;justify-content:center;align-items:center;gap:8px;padding:14px;font-size:15px;font-weight:600;transition:opacity .2s;display:flex}.pick-confirm-btn:disabled{opacity:.35;cursor:not-allowed}.pick-confirm-btn:not(:disabled):active{opacity:.85}.pick-confirming{opacity:.6;pointer-events:none}.pick-hint{color:var(--text-3);text-align:center;font-size:14px;font-style:italic}.pick-lyrics-label{align-items:center;gap:0;display:flex}.pick-lyrics-variant-label{color:var(--text-3);letter-spacing:0;text-transform:none;font-size:11px;font-weight:400}.sheet-backdrop{-webkit-backdrop-filter:blur(8px);z-index:200;background:oklch(0% 0 0/.55);position:fixed;inset:0}.playlist-sheet{z-index:201;background:var(--bg-2);border-radius:var(--r-2xl) var(--r-2xl) 0 0;border-top:1px solid var(--border-md);padding:0 0 calc(16px + env(safe-area-inset-bottom));flex-direction:column;max-width:480px;max-height:78dvh;margin:0 auto;display:flex;position:fixed;bottom:0;left:0;right:0;overflow:hidden}@media (width>=768px){.playlist-sheet{transform:translateX(calc(-50% + (var(--sidebar-w) / 2)));width:var(--frame-w);max-width:calc(100vw - var(--sidebar-w) - 40px);left:50%;right:auto;bottom:calc(var(--player-h) + 16px);border-radius:var(--r-2xl);border:1px solid var(--border-md);margin:0;padding-bottom:16px}}.ps-handle{background:var(--border-md);border-radius:99px;flex-shrink:0;width:36px;height:3px;margin:12px auto 4px}.ps-header{flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:12px 20px 0;display:flex}.ps-title{font-family:var(--font-display);color:var(--text-0);margin:0;font-size:16px;font-weight:700}.ps-subtitle{color:var(--text-2);white-space:nowrap;text-overflow:ellipsis;max-width:240px;margin:3px 0 0;font-size:13px;font-style:italic;overflow:hidden}.ps-close{background:var(--bg-3);width:28px;height:28px;color:var(--text-2);transition:background var(--duration-quick);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.ps-close:hover{background:var(--bg-4)}.ps-create-form{flex-shrink:0;padding:12px 20px 0}.ps-input{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r-md);width:100%;color:var(--text-0);font-size:14px;font-family:var(--font-body);transition:border-color var(--duration-quick);box-sizing:border-box;outline:none;padding:10px 14px}.ps-input:focus{border-color:var(--border-bright)}.ps-input::placeholder{color:var(--text-3)}.ps-list{-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;gap:4px;padding:12px 20px 0;display:flex;overflow-y:auto}.ps-loading{flex-direction:column;gap:8px;padding:12px 20px 0;display:flex}.ps-playlist-row{background:var(--bg-3);border-radius:var(--r-md);text-align:left;cursor:pointer;width:100%;transition:background var(--duration-quick), border-color var(--duration-quick);-webkit-tap-highlight-color:transparent;border:1px solid #0000;flex-direction:row;flex-shrink:0;align-items:center;gap:12px;padding:10px 12px;display:flex}.ps-playlist-row:hover:not(:disabled){background:var(--bg-4)}.ps-playlist-row.ps-added{background:var(--ink-pale);border-color:var(--border-warm)}.ps-playlist-row:disabled{cursor:default;opacity:.5}.ps-pl-icon{border-radius:var(--r-sm);background:var(--bg-4);width:32px;height:32px;color:var(--text-2);flex-shrink:0;justify-content:center;align-items:center;display:flex}.ps-pl-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.ps-pl-name{color:var(--text-0);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;font-family:var(--font-display);overflow:hidden}.ps-pl-count{color:var(--text-3);font-size:12px}.ps-pl-action{flex-shrink:0;justify-content:center;align-items:center;width:20px;display:flex}.ps-check{color:var(--ink);justify-content:center;align-items:center;display:flex}.ps-plus{color:var(--text-2);font-size:20px;font-weight:300;line-height:1}.ps-spinner{color:var(--text-3);font-size:13px}.ps-new-btn{background:var(--bg-3);border:1px dashed var(--border-md);border-radius:var(--r-md);color:var(--ink);text-align:left;width:100%;transition:background var(--duration-quick), border-color var(--duration-quick);align-items:center;gap:10px;padding:10px 14px;font-size:13px;font-weight:500;display:flex}.ps-new-btn:hover{background:var(--bg-4)}.ps-new-icon{font-size:18px;font-weight:300;line-height:1}.ps-btn-cancel{color:var(--text-2);background:var(--bg-3);border-radius:var(--r-md);transition:background var(--duration-quick);flex-shrink:0;padding:10px 16px;font-size:14px;font-weight:500}.ps-btn-cancel:hover{background:var(--bg-4)}.ps-btn-create{color:oklch(12% .02 75);background:var(--ink);border-radius:var(--r-md);font-size:14px;font-weight:700;font-family:var(--font-display);transition:opacity var(--duration-quick);text-align:center;flex:1;padding:11px}.ps-btn-create:disabled{opacity:.4;cursor:default}.ps-confirm-row{flex-shrink:0;gap:8px;margin-top:auto;padding:12px 20px 4px;display:flex}.ps-desc{color:var(--text-3);white-space:normal;max-width:none;margin:0;padding:4px 20px 0;font-size:13px;font-style:normal;line-height:1.5}.ps-error{color:var(--color-error);text-align:center;margin:0;padding:8px 20px 0;font-size:13px}.basic-progress-step{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:28px;padding:56px 24px 48px;display:flex}.bps-orb{background:var(--ink-dim);width:72px;height:72px;color:var(--ink);border:1.5px solid oklch(80% .17 80/.25);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.bps-orb-ring{pointer-events:none;border:1px solid oklch(80% .17 80/.14);border-radius:50%;animation:2.4s ease-in-out infinite orbRingPulse;position:absolute;inset:-10px}@keyframes orbRingPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(1.12)}}.bps-phases{flex-direction:column;gap:0;width:100%;max-width:290px;display:flex}.bps-phase{border-bottom:1px solid var(--border);opacity:.28;transition:opacity var(--duration-normal);align-items:flex-start;gap:14px;padding:13px 0;display:flex}.bps-phase:last-child{border-bottom:none}.bps-phase.active{opacity:1}.bps-phase.done{opacity:.5}.bps-phase-indicator{background:var(--bg-3);width:22px;height:22px;color:var(--text-2);transition:background var(--duration-normal), color var(--duration-normal);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;display:flex}.bps-phase.active .bps-phase-indicator{background:var(--ink-dim);color:var(--ink)}.bps-phase.done .bps-phase-indicator{background:var(--bg-3);color:var(--color-success)}.bps-title{font-family:var(--font-display);color:var(--text-0);font-size:21px;font-weight:700}.bps-dot{background:var(--text-3);border-radius:50%;width:5px;height:5px;display:block}.bps-phase-text{text-align:left;flex-direction:column;gap:3px;display:flex}.bps-phase-label{color:var(--text-0);font-size:14px;font-weight:600;line-height:1.3}.bps-phase.active .bps-phase-label{color:var(--text-0)}.bps-phase:not(.active):not(.done) .bps-phase-label{color:var(--text-2)}.loading-step-rendering{text-align:center;flex-direction:column;flex:1;align-items:center;gap:24px;padding:32px 24px 36px;display:flex}.lsr-waveform{justify-content:center;align-items:flex-end;gap:5px;height:48px;display:flex}.lsr-bar{background:var(--ink);transform-origin:bottom;width:4px;animation:1.15s ease-in-out infinite lsrBarAnim;animation-delay:calc(var(--bar-i) * 85ms);opacity:.85;border-radius:2px}.lsr-bar:first-child{height:14px}.lsr-bar:nth-child(2){height:26px}.lsr-bar:nth-child(3){height:38px}.lsr-bar:nth-child(4){height:48px}.lsr-bar:nth-child(5){height:34px}.lsr-bar:nth-child(6){height:22px}.lsr-bar:nth-child(7){height:44px}.lsr-bar:nth-child(8){height:36px}.lsr-bar:nth-child(9){height:48px}.lsr-bar:nth-child(10){height:28px}.lsr-bar:nth-child(11){height:18px}.lsr-bar:nth-child(12){height:32px}@keyframes lsrBarAnim{0%,to{opacity:.35;transform:scaleY(.15)}50%{opacity:.95;transform:scaleY(1)}}.lsr-ring-wrap{flex-shrink:0;width:128px;height:128px;position:relative}.lsr-ring-svg{width:128px;height:128px;display:block}.lsr-ring-track{fill:none;stroke:var(--bg-3);stroke-width:4.5px}.lsr-ring-fill{fill:none;stroke:var(--ink);stroke-width:4.5px;stroke-linecap:round;transition:stroke-dashoffset 1.4s var(--ease-out)}.lsr-ring-center{justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.lsr-timer{font-family:var(--font-display);color:var(--text-0);font-variant-numeric:tabular-nums;letter-spacing:-.03em;font-size:28px;font-weight:700;line-height:1}.lsr-info{flex-direction:column;align-items:center;gap:5px;display:flex}.lsr-title{font-family:var(--font-display);color:var(--text-0);font-size:20px;font-weight:700}.lsr-eta{color:var(--text-3);transition:color var(--duration-normal);font-size:13px}.lsr-eta--soon{color:var(--ink);font-weight:600;animation:1.5s ease-in-out infinite etaSoon}@keyframes etaSoon{0%,to{opacity:1}50%{opacity:.6}}.lsr-phases{flex-direction:column;gap:0;width:100%;max-width:260px;display:flex}.lsr-phase{border-bottom:1px solid var(--border);opacity:.25;transition:opacity var(--duration-normal);align-items:center;gap:12px;padding:10px 0;display:flex}.lsr-phase:last-child{border-bottom:none}.lsr-phase.active{opacity:1}.lsr-phase.done{opacity:.5}.lsr-phase-dot{background:var(--bg-3);width:20px;height:20px;color:var(--text-2);transition:background var(--duration-normal), color var(--duration-normal);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.lsr-phase.active .lsr-phase-dot{background:var(--ink-dim);color:var(--ink)}.lsr-phase.done .lsr-phase-dot{background:var(--bg-3);color:var(--color-success)}.lsr-phase-label{color:var(--text-1);text-align:left;transition:color var(--duration-normal);font-size:13px;font-weight:500}.lsr-phase.active .lsr-phase-label{color:var(--text-0);font-weight:600}.gen-mode-btn{border-radius:var(--r-full);color:var(--text-2);background:var(--bg-3);border:1px solid var(--border);transition:color var(--duration-quick), background var(--duration-quick);-webkit-tap-highlight-color:transparent;white-space:nowrap;align-items:center;min-height:44px;padding:5px 12px;font-size:12px;font-weight:600;display:inline-flex}.gen-mode-btn:hover{color:var(--text-0);background:var(--bg-4)}.generate-screen{min-height:100dvh;padding-bottom:calc(var(--nav-h) + var(--mp-h) + env(safe-area-inset-bottom) + 8px);flex-direction:column;display:flex}.gen-header{padding:calc(env(safe-area-inset-top) + 20px) 20px 8px;justify-content:space-between;align-items:flex-start;display:flex}.gen-title{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.2px;font-size:24px;font-weight:700}.gen-sub{color:var(--text-2);margin-top:3px;font-size:13px}.step-dots{align-items:center;gap:6px;padding:12px 20px 4px;display:flex}.step-dot{background:var(--bg-4);height:6px;transition:background var(--duration-normal), width var(--duration-normal) var(--ease-out), opacity var(--duration-normal);border-radius:99px;width:6px}.step-dot.current{background:var(--ink);width:20px}.step-dot.active{background:var(--ink);opacity:.38;width:6px}.gen-body{flex:1;position:relative;overflow:hidden}.step-pane{flex-direction:column;gap:18px;height:100%;padding:16px 20px 24px;display:flex;overflow-y:auto}.input-step{flex-direction:column;gap:18px;display:flex}.input-field-group{flex-direction:column;gap:7px;display:flex;position:relative}.input-label{color:var(--text-2);text-transform:uppercase;letter-spacing:.7px;font-size:12px;font-weight:700}.notes-textarea{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);width:100%;color:var(--text-0);resize:none;transition:border-color var(--duration-quick), box-shadow var(--duration-quick);outline:none;padding:13px 15px;font-size:14px;line-height:1.65}.notes-textarea:focus{border-color:var(--border-bright);box-shadow:0 0 0 3px var(--ink-dim)}.notes-textarea::placeholder{color:var(--text-3)}.notes-textarea.small{font-size:13px}.char-count{color:var(--text-3);font-size:13px;position:absolute;bottom:10px;right:12px}.memorize-label-row{align-items:center;gap:8px;display:flex}.memorize-optional{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:500}.memorize-hint-row{justify-content:space-between;align-items:center;gap:8px;min-height:16px;display:flex}.memorize-hint{color:var(--text-3);font-size:13px}.memorize-warn{color:var(--ink);font-size:13px;font-weight:500}.char-count-inline{color:var(--text-3);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:13px}.char-count-inline.char-warn,.char-count-inline.char-near{color:var(--ink);font-weight:600}.notes-textarea.textarea-warn{border-color:oklch(80% .17 80/.5)}.genre-grid{flex-wrap:wrap;gap:8px;display:flex}.genre-chip{border-radius:var(--r-full);font-family:var(--font-display);background:var(--bg-3);color:var(--text-1);border:1.5px solid var(--border-md);cursor:pointer;transition:background var(--duration-quick), color var(--duration-quick), border-color var(--duration-quick);-webkit-tap-highlight-color:transparent;justify-content:center;align-items:center;gap:6px;min-height:40px;padding:8px 16px;font-size:13px;font-weight:600;display:flex;position:relative}.genre-chip:hover{border-color:var(--border-bright);color:var(--text-0);background:var(--bg-4)}.genre-chip.active,.genre-chip.selected{background:var(--ink);color:oklch(10% .025 75);border-color:var(--ink)}.genre-chip.disabled,.genre-chip:disabled{opacity:.38;cursor:not-allowed}.genre-max-hint{color:var(--text-3);font-size:11px;font-family:var(--font-display);letter-spacing:.05em;margin:4px 0 0;font-weight:600}.genre-max-warning{font-weight:700;color:var(--color-error)!important}.gen-primary-btn{background:var(--ink);color:oklch(10% .025 75);border-radius:var(--r-md);width:100%;font-family:var(--font-display);-webkit-tap-highlight-color:transparent;transition:opacity var(--duration-quick);justify-content:center;align-items:center;gap:8px;padding:14px;font-size:14px;font-weight:700;display:flex}.gen-primary-btn:disabled{opacity:.4;cursor:not-allowed}.gen-primary-btn.flex-1{flex:1}.review-step{flex-direction:column;gap:16px;display:flex}.review-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.review-song-title{font-family:var(--font-display);color:var(--text-0);font-size:18px;font-weight:700}.review-summary{color:var(--text-2);margin-top:4px;font-size:13px;line-height:1.55}.review-edit-btn{color:var(--ink);background:var(--ink-dim);border-radius:var(--r-full);border:1px solid var(--border-bright);flex-shrink:0;align-items:center;min-height:44px;padding:5px 12px;font-size:14px;font-weight:600;display:inline-flex}.review-concepts{flex-direction:column;gap:8px;display:flex}.review-concepts-label{color:var(--text-2);text-transform:uppercase;letter-spacing:.7px;font-size:12px;font-weight:700}.concept-tags{flex-wrap:wrap;gap:5px;display:flex}.concept-tag{border-radius:var(--r-full);border:1px solid #0000;padding:4px 10px;font-size:14px;font-weight:500}.concept-tag.importance-high{background:var(--ink-dim);color:var(--ink);border-color:var(--border-bright)}.concept-tag.importance-medium{background:var(--sage-dim);color:var(--sage);border-color:oklch(65% .01 75/.2)}.concept-tag.importance-low{background:var(--bg-3);color:var(--text-2);border-color:var(--border)}.review-lyrics-wrap{flex-direction:column;gap:8px;display:flex}.review-section-label{color:var(--text-2);text-transform:uppercase;letter-spacing:.7px;font-size:12px;font-weight:700}.lyrics-view{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);max-height:260px;padding:15px;overflow-y:auto}.lyrics-view.review-lyrics-scroll{max-height:340px;padding:18px 20px}.lyric-spacer{height:10px}.lyric-line{color:var(--text-0);font-size:14px;line-height:1.85;font-family:var(--font-display);font-style:italic}.lyric-line.section-label{color:var(--ink);text-transform:uppercase;letter-spacing:1px;margin-top:8px;font-size:12px;font-style:normal;font-weight:700}.lyrics-edit-textarea{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r-md);width:100%;color:var(--text-0);resize:none;font-size:14px;line-height:1.85;font-family:var(--font-display);transition:border-color var(--duration-quick);outline:none;padding:13px 15px;font-style:italic}.lyrics-edit-textarea:focus{border-color:var(--border-bright)}.review-actions{align-items:center;gap:8px;display:flex}.review-compose{position:relative}.review-compose.has-text .review-compose-textarea{border-color:var(--border-bright)}.review-skip-btn{opacity:0;pointer-events:none;white-space:nowrap;transition:opacity .18s,transform .18s;transform:translate(6px)}.review-skip-btn.visible{opacity:1;pointer-events:auto;transform:translate(0)}.review-primary-btn{justify-content:center;min-width:134px;position:relative}.review-btn-idle,.review-btn-revise{justify-content:center;align-items:center;gap:5px;transition:opacity .15s,transform .15s;display:inline-flex;position:absolute;inset:0}.review-btn-idle{opacity:1;transform:translateY(0)}.review-btn-revise{opacity:0;transform:translateY(7px)}.review-primary-btn.is-revise .review-btn-idle{opacity:0;transform:translateY(-7px)}.review-primary-btn.is-revise .review-btn-revise{opacity:1;transform:translateY(0)}.done-step{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:20px;padding:48px 32px 40px;display:flex}.done-icon-wrap{justify-content:center;align-items:center;width:88px;height:88px;display:flex;position:relative}.done-icon{background:var(--ink-dim);width:80px;height:80px;color:var(--ink);animation:doneCheckIn .55s var(--ease-out) both;z-index:1;border:1.5px solid oklch(80% .17 80/.3);border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative}@keyframes doneCheckIn{0%{opacity:0;transform:scale(.45)}65%{transform:scale(1.06)}to{opacity:1;transform:scale(1)}}.done-ring{animation:doneRingIn .65s var(--ease-out) .12s both;pointer-events:none;border:1px solid oklch(80% .17 80/.13);border-radius:50%;position:absolute;inset:-4px}@keyframes doneRingIn{0%{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}.done-text{flex-direction:column;gap:6px;display:flex}.done-song-name{color:var(--text-2);max-width:280px;font-size:15px;font-style:italic;line-height:1.45}.done-actions{flex-direction:column;gap:8px;width:100%;margin-top:4px;display:flex}.done-listen-btn{justify-content:center;align-items:center;gap:8px;display:flex}.done-actions .next-btn,.done-actions .secondary-btn{flex:none;width:100%}.ghost-btn{border-radius:var(--r-md);height:48px;color:var(--text-3);width:100%;transition:color var(--duration-quick), background var(--duration-quick);-webkit-tap-highlight-color:transparent;background:0 0;border:1px solid #0000;justify-content:center;align-items:center;gap:6px;padding:0 16px;font-size:14px;font-weight:400;display:inline-flex}.ghost-btn:hover{color:var(--text-1);background:var(--bg-2)}.notes-inline-error{color:var(--color-error);background:var(--color-error-bg);border-radius:var(--r-sm);border:1px solid oklch(71% .16 25/.18);padding:8px 12px;font-size:12px;font-weight:500}.gen-error{color:var(--color-error);background:var(--color-error-bg);border-radius:var(--r-sm);border:1px solid oklch(71% .16 25/.22);padding:10px 14px;font-size:13px}.concepts-extracting-badge{color:var(--text-2);background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-full);align-items:center;gap:8px;width:fit-content;padding:5px 12px;font-size:12px;font-weight:600;display:inline-flex}.concepts-extracting-dot{background:var(--ink);border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:1.3s ease-in-out infinite concExtractPulse;display:block}@keyframes concExtractPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.75)}}.loading-elapsed{color:var(--text-3);font-variant-numeric:tabular-nums;letter-spacing:.3px;font-size:13px}.done-pack-btn{background:var(--bg-3);border:1px dashed var(--border-md);border-radius:var(--r-md);width:100%;color:var(--text-1);transition:border-color var(--duration-quick), background var(--duration-quick), color var(--duration-quick);-webkit-tap-highlight-color:transparent;justify-content:center;align-items:center;gap:8px;padding:12px;font-size:13px;font-weight:500;display:flex}.done-pack-btn:hover{color:var(--ink);background:var(--ink-dim);border-style:solid;border-color:var(--border-bright)}.done-pack-added{color:var(--color-success);background:oklch(76% .15 162/.06);border-style:solid;border-color:oklch(76% .15 162/.35)}.done-pack-added:hover{color:var(--color-success);background:oklch(76% .15 162/.1)}.revise-toggle-btn{color:var(--text-2);border-radius:var(--r-md);background:var(--bg-3);border:1px dashed var(--border-md);width:100%;transition:color var(--duration-quick), border-color var(--duration-quick), background var(--duration-quick);-webkit-tap-highlight-color:transparent;justify-content:center;align-items:center;gap:7px;min-height:44px;padding:9px 14px;font-size:13px;font-weight:500;display:flex}.revise-toggle-btn:hover{color:var(--ink);border-style:solid;border-color:var(--border-bright);background:var(--ink-dim)}.revise-panel{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);flex-direction:column;gap:10px;padding:14px;display:flex}.revise-panel-header{justify-content:space-between;align-items:center;display:flex}.revise-panel-label{color:var(--text-1);text-transform:uppercase;letter-spacing:.7px;font-size:12px;font-weight:700}.revise-close-btn{color:var(--text-3);border-radius:var(--r-xs);justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:2px 6px;font-size:14px;line-height:1;display:flex}.revise-close-btn:hover{color:var(--text-1);background:var(--bg-4)}.revise-textarea{background:var(--bg-0);border:1px solid var(--border);border-radius:var(--r-sm);width:100%;color:var(--text-0);resize:none;transition:border-color var(--duration-quick), box-shadow var(--duration-quick);outline:none;padding:11px 13px;font-size:13px;line-height:1.6}.revise-textarea:focus{border-color:var(--border-bright);box-shadow:0 0 0 3px var(--ink-dim)}.revise-textarea::placeholder{color:var(--text-3)}.revise-hint{color:var(--text-3);font-size:13px}.revise-submit-btn{border-radius:var(--r-md);background:var(--bg-4);width:100%;color:var(--text-3);transition:background var(--duration-quick), color var(--duration-quick);-webkit-tap-highlight-color:transparent;justify-content:center;align-items:center;gap:7px;padding:11px;font-size:13px;font-weight:600;display:flex}.revise-submit-btn.active{background:var(--ink);color:oklch(10% .025 75)}.revise-submit-btn:disabled{cursor:not-allowed}.btn-cost-badge{color:oklch(10% .025 75/.7);border-radius:var(--r-sm);letter-spacing:.02em;background:oklch(10% .025 75/.13);align-items:center;gap:3px;margin-left:6px;padding:2px 8px;font-size:13px;font-weight:700;display:inline-flex}.btn-cost-badge.small{margin-left:4px;padding:2px 6px;font-size:13px}.btn-cost-hint{color:var(--text-2);margin-left:auto;font-size:13px;font-weight:500}.notes-label-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.notes-input-actions{align-items:center;gap:6px;display:flex}.notes-action-btn{color:var(--text-2);border-radius:var(--r-full);background:var(--bg-3);border:1px solid var(--border);transition:color var(--duration-quick), background var(--duration-quick), border-color var(--duration-quick);-webkit-tap-highlight-color:transparent;white-space:nowrap;align-items:center;gap:5px;min-height:36px;padding:5px 10px;font-size:12px;font-weight:500;display:flex}.notes-action-btn:hover:not(:disabled){color:var(--ink);background:var(--ink-dim);border-color:var(--border-bright)}.notes-action-btn:disabled{opacity:.35;cursor:not-allowed}.ocr-thumbnail-row{flex-wrap:wrap;gap:6px;display:flex}.ocr-done-thumb{border-radius:var(--r-sm);border:1px solid oklch(76% .15 162/.4);flex-shrink:0;width:36px;height:36px;position:relative;overflow:hidden}.ocr-done-thumb-img{object-fit:cover;opacity:.8;width:100%;height:100%;display:block}.ocr-done-thumb-badge{color:oklch(10% .025 75);background:oklch(76% .15 162/.9);border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;display:flex;position:absolute;bottom:2px;right:2px}.notes-drop-zone{border-radius:var(--r-md);transition:box-shadow var(--duration-quick);position:relative}.notes-drop-zone.drag-over{box-shadow:0 0 0 2px var(--ink)}.notes-drop-zone.drag-over .notes-textarea{opacity:.35}.drop-overlay{background:var(--ink-dim);border-radius:var(--r-md);border:2px dashed var(--ink);color:var(--ink);pointer-events:none;z-index:2;flex-direction:column;justify-content:center;align-items:center;gap:8px;font-size:13px;font-weight:600;display:flex;position:absolute;inset:0}.notes-meta-row{justify-content:space-between;align-items:center;gap:8px;min-height:18px;display:flex}.notes-over-limit{color:var(--color-error);align-items:center;gap:4px;font-size:12px;font-weight:500;display:flex}.notes-near-limit{color:var(--ink);align-items:center;gap:4px;font-size:12px;font-weight:500;display:flex}.ocr-card{background:var(--bg-2);border-radius:var(--r-md);border:1px solid var(--border);flex-direction:column;gap:14px;padding:14px;display:flex}.ocr-card-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.ocr-card-title{color:var(--text-0);font-size:15px;font-weight:700}.ocr-card-subtitle{color:var(--text-2);margin-top:4px;font-size:13px;line-height:1.45}.ocr-card-status-row{min-height:20px}.ocr-card-top{align-items:flex-start;gap:10px;display:flex}.ocr-card-preview{object-fit:cover;border-radius:var(--r-sm);border:1px solid var(--border);flex-shrink:0;width:56px;height:56px}.ocr-card-meta{flex:1;min-width:0;padding-top:4px}.ocr-card-status{color:var(--text-2);align-items:center;gap:7px;font-size:13px;display:flex}.ocr-card-status.done{color:var(--text-1);font-weight:500}.ocr-card-status.error{color:var(--color-error)}.ocr-card-discard{color:var(--text-3);border-radius:var(--r-xs);transition:color var(--duration-quick), background var(--duration-quick);-webkit-tap-highlight-color:transparent;flex-shrink:0;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:4px;display:flex}.ocr-card-discard:hover{color:var(--text-1);background:var(--bg-4)}.ocr-card-skeleton{flex-direction:column;gap:8px;padding:4px 0;display:flex}.ocr-skel-line{border-radius:var(--r-full);background:var(--bg-4);height:10px;animation:1.4s ease-in-out infinite skelPulse}@keyframes skelPulse{0%,to{opacity:.5}50%{opacity:1}}.ocr-card-textarea{background:var(--bg-0);border:1px solid var(--border);border-radius:var(--r-sm);width:100%;color:var(--text-0);resize:none;transition:border-color var(--duration-quick);outline:none;padding:10px 12px;font-family:inherit;font-size:13px;line-height:1.65}.ocr-card-textarea:focus{border-color:var(--border-bright)}.ocr-card-textarea::placeholder{color:var(--text-3)}.ocr-card-actions{justify-content:flex-end;align-items:center;gap:8px;display:flex}.ocr-card-discard-btn{color:var(--text-2);border-radius:var(--r-md);background:var(--bg-3);-webkit-tap-highlight-color:transparent;transition:color var(--duration-quick), background var(--duration-quick);min-height:44px;padding:8px 14px;font-size:13px;font-weight:400}.ocr-card-discard-btn:hover{color:var(--text-0);background:var(--bg-4)}.ocr-card-retry-btn{color:var(--ink);border-radius:var(--r-md);background:var(--ink-dim);border:1px solid var(--border-bright);-webkit-tap-highlight-color:transparent;min-height:44px;padding:8px 14px;font-size:13px;font-weight:500}.ocr-card-add-btn{color:oklch(10% .025 75);border-radius:var(--r-md);background:var(--ink);-webkit-tap-highlight-color:transparent;transition:opacity var(--duration-quick);min-height:44px;padding:8px 16px;font-size:13px;font-weight:700}.ocr-card-add-btn:disabled{opacity:.4;cursor:not-allowed}.ocr-error-msg{color:var(--color-error);align-items:center;gap:5px;font-size:12px;font-weight:500;display:flex}.memorize-required{color:var(--ink);text-transform:uppercase;letter-spacing:.5px;background:var(--ink-dim);border-radius:var(--r-full);border:1px solid var(--border-bright);padding:2px 7px;font-size:11px;font-weight:700}.field-required-hint{color:var(--ink);text-align:center;margin-top:-8px;font-size:12px;font-weight:500}.notes-textarea.textarea-pulse{border-color:oklch(80% .17 80/.6);animation:1.2s ease-out forwards fieldPulse}.ocr-review-layout{grid-template-columns:1fr;gap:12px;display:grid}.ocr-review-layout.is-done{grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr) minmax(0,1.1fr)}.ocr-preview-panel,.ocr-editor-panel,.ocr-render-panel,.ocr-side-placeholder{min-width:0}.ocr-panel-label{color:var(--text-2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;font-size:12px;font-weight:700}.ocr-image-shell{border-radius:var(--r-md);border:1px solid var(--border);background:var(--bg-3);min-height:220px;position:relative;overflow:hidden}.ocr-review-image{object-fit:cover;width:100%;height:100%;min-height:220px;display:block}.ocr-scan-overlay{pointer-events:none;background:linear-gradient(oklch(0% 0 0/.08),oklch(0% 0 0/.18));position:absolute;inset:0}.ocr-scan-line{background:linear-gradient(90deg, transparent, var(--ink), transparent);height:2px;animation:1.8s linear infinite ocrScan;position:absolute;left:0;right:0;box-shadow:0 0 18px oklch(80% .17 80/.45)}.ocr-side-placeholder,.ocr-render-surface{background:var(--bg-0);border:1px solid var(--border);border-radius:var(--r-md);min-height:220px;padding:12px}.ocr-side-placeholder{justify-content:center;align-items:center;display:flex}.ocr-empty-state{text-align:center;color:var(--text-2);flex-direction:column;justify-content:center;align-items:center;gap:8px;font-size:13px;display:flex}.ocr-card-textarea-lg{height:100%;min-height:220px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:12.5px;line-height:1.6}.ocr-render-surface{overflow:auto}.ocr-markdown-preview{color:var(--text-0);flex-direction:column;gap:10px;display:flex}.ocr-md-empty,.ocr-md-paragraph{color:var(--text-1);font-size:13px;line-height:1.7}.ocr-md-heading{color:var(--text-0);font-weight:700;line-height:1.3}.ocr-md-h1,.ocr-md-h2{font-size:16px}.ocr-md-h3,.ocr-md-h4,.ocr-md-h5,.ocr-md-h6{font-size:14px}.ocr-md-list{color:var(--text-1);gap:6px;padding-left:18px;font-size:13px;line-height:1.6;display:grid}.ocr-md-ordered{list-style:decimal}.ocr-md-table-wrap{overflow-x:auto}.ocr-md-table{border-collapse:collapse;width:100%;font-size:12.5px}.ocr-md-table th,.ocr-md-table td{text-align:left;vertical-align:top;border:1px solid var(--border);padding:8px 10px}.ocr-md-table th{background:var(--bg-3);color:var(--text-0);font-weight:600}.ocr-md-table td{color:var(--text-1)}@media (width<=980px){.ocr-review-layout.is-done{grid-template-columns:1fr}.ocr-review-image,.ocr-image-shell,.ocr-side-placeholder,.ocr-render-surface,.ocr-card-textarea-lg{min-height:180px}}.wizard-step{flex-direction:column;gap:16px;display:flex}.wizard-step-header{flex-direction:column;gap:5px;padding-bottom:4px;display:flex}.wizard-step-title{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.03em;font-size:24px;font-weight:800;line-height:1.1}.wizard-step-desc{color:var(--text-2);font-size:13px;line-height:1.55}.wizard-nav-row{align-items:center;gap:10px;margin-top:4px;display:flex}.wizard-back-btn{border-radius:var(--r-md);background:var(--bg-3);height:48px;color:var(--text-1);border:1px solid var(--border);cursor:pointer;white-space:nowrap;transition:background var(--duration-quick), color var(--duration-quick);flex-shrink:0;align-items:center;gap:4px;padding:0 14px;font-size:14px;font-weight:500;display:flex}.wizard-back-btn:hover{background:var(--bg-4);color:var(--text-0)}.add-notes-scan-row{gap:8px;display:flex}.ocr-capture-card{background:var(--bg-2);border-radius:var(--r-md);border:1px solid var(--border-md);overflow:hidden}.ocr-capture-top{align-items:center;gap:12px;padding:12px 14px;display:flex}.ocr-capture-thumb-wrap{border-radius:var(--r-sm);background:var(--bg-3);flex-shrink:0;width:56px;height:56px;position:relative;overflow:hidden}.ocr-capture-thumb{object-fit:cover;width:100%;height:100%}.ocr-capture-info{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.ocr-capture-name{color:var(--text-0);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.ocr-capture-status{color:var(--text-3);align-items:center;gap:5px;font-size:12px;display:flex}.ocr-capture-status.processing{color:var(--text-2)}.ocr-capture-status.done{color:var(--color-success)}.ocr-capture-status.error{color:var(--color-error)}.ocr-capture-dismiss{border-radius:var(--r-full);background:var(--bg-4);width:44px;height:44px;color:var(--text-2);cursor:pointer;transition:background var(--duration-quick), color var(--duration-quick);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.ocr-capture-dismiss:hover{background:var(--bg-3);color:var(--text-0)}.ocr-capture-actions{border-top:1px solid var(--border);justify-content:flex-end;align-items:center;gap:8px;padding:10px 14px;display:flex}.ocr-capture-wait{color:var(--text-3);margin:0;font-size:12px}.ocr-capture-btn-secondary,.ocr-capture-btn-primary{border-radius:var(--r-md);justify-content:center;align-items:center;gap:7px;min-height:44px;padding:0 13px;font-size:13px;font-weight:600;display:inline-flex}.ocr-capture-btn-secondary{background:var(--bg-3);color:var(--text-1);border:1px solid var(--border);transition:background var(--duration-quick)}.ocr-capture-btn-secondary:hover{background:var(--bg-4)}.ocr-capture-btn-primary{background:var(--ink);color:oklch(10% .025 75);cursor:pointer;transition:opacity var(--duration-quick);border:none}.ocr-capture-btn-primary:hover{opacity:.88}.ocr-review-split{grid-template-columns:1fr 1fr;gap:14px;display:grid}.ocr-review-col{flex-direction:column;gap:7px;min-height:0;display:flex}.ocr-review-col-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.7px;margin:0;font-size:11px;font-weight:700}.ocr-review-textarea{flex:1;min-height:260px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12.5px;line-height:1.6}.ocr-render-surface{background:var(--bg-2);border-radius:var(--r-md);flex:1;min-height:260px;padding:14px 16px;overflow-y:auto}.genre-grid-lg{grid-template-columns:repeat(2,1fr)!important;gap:10px!important}.genre-chip-check{opacity:.8;position:absolute;left:12px}@media (width<=600px){.ocr-review-split{grid-template-columns:1fr}.ocr-review-textarea,.ocr-render-surface{min-height:180px}.genre-grid-lg{grid-template-columns:repeat(2,1fr)!important}}.notes-tab-bar{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);grid-template-columns:1fr 1fr;gap:0;padding:4px;display:grid;position:relative}.notes-tab-btn{z-index:1;border-radius:var(--r-sm);color:var(--text-2);transition:color var(--duration-quick);-webkit-tap-highlight-color:transparent;justify-content:center;align-items:center;gap:6px;min-height:44px;padding:9px 12px;font-size:13px;font-weight:600;display:inline-flex;position:relative}.notes-tab-btn.active{color:var(--text-0)}.notes-tab-check{background:var(--color-success);color:oklch(10% .025 75);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;display:inline-flex}.notes-tab-indicator{border-radius:var(--r-sm);background:var(--bg-0);border:1px solid var(--border);pointer-events:none;z-index:0;width:calc(50% - 4px);transition:transform var(--duration-normal) var(--ease-out);position:absolute;inset:4px;box-shadow:0 1px 4px oklch(0% 0 0/.12)}.notes-tab-panels{flex:1;min-height:0;position:relative}.notes-tab-panel{flex-direction:column;display:flex}.notes-paste-panel{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);gap:0;padding:2px;position:relative}.notes-paste-panel.drag-over{box-shadow:0 0 0 2px var(--ink)}.notes-paste-panel.drag-over .notes-tab-textarea{opacity:.35}.notes-tab-textarea{border-radius:calc(var(--r-md) - 2px);resize:none;background:0 0;border:none;flex:1;min-height:220px}.notes-tab-textarea:focus{box-shadow:none;outline:none}.notes-paste-footer{align-items:center;padding:6px 12px 8px;display:flex}.notes-char-hint{color:var(--text-3);font-size:11px}.notes-image-panel{gap:12px}.notes-image-empty{grid-template-columns:1fr 1fr;gap:10px;display:grid}.notes-img-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);text-align:center;transition:border-color var(--duration-quick), background var(--duration-quick);-webkit-tap-highlight-color:transparent;flex-direction:column;align-items:center;gap:10px;padding:24px 16px;display:flex}.notes-img-card:hover{border-color:var(--border-bright);background:var(--ink-pale)}.notes-img-card-icon{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r-md);width:48px;height:48px;color:var(--text-1);justify-content:center;align-items:center;display:flex}.notes-img-card-title{color:var(--text-0);font-size:14px;font-weight:600;line-height:1.3}.notes-img-card-sub{color:var(--text-3);font-size:12px}.notes-capture-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);flex-direction:column;align-items:stretch;gap:12px;padding:12px;display:flex}.notes-capture-preview-wrap{border-radius:var(--r-sm);background:var(--bg-3);border:1px solid var(--border);justify-content:center;align-items:center;width:100%;display:flex;position:relative;overflow:hidden}.notes-capture-preview{object-fit:contain;width:100%;height:auto;max-height:360px;transition:filter var(--duration-normal);display:block}.notes-capture-preview-wrap.is-scanning .notes-capture-preview{filter:brightness(.6)}.notes-capture-status-overlay{pointer-events:none;background:linear-gradient(#0000 0%,oklch(0% 0 0/.7) 100%);justify-content:center;align-items:flex-end;padding:32px 16px 18px;display:flex;position:absolute;bottom:0;left:0;right:0}.notes-capture-processing-badge{color:oklch(97% .006 80);-webkit-backdrop-filter:blur(10px);border-radius:var(--r-full);background:oklch(0% 0 0/.5);border:1px solid oklch(100% 0 0/.12);align-items:center;gap:8px;padding:8px 16px;font-size:13px;font-weight:600;display:inline-flex}.notes-capture-done-badge{color:var(--color-success);-webkit-backdrop-filter:blur(8px);border-radius:var(--r-full);animation:doneCheckIn .35s var(--ease-out) both;background:oklch(0% 0 0/.58);border:1px solid oklch(76% .15 162/.4);align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:600;display:inline-flex;position:absolute;bottom:10px;left:10px}.notes-capture-discard-btn{color:oklch(97% .006 80);cursor:pointer;width:34px;height:34px;transition:background var(--duration-quick), transform var(--duration-quick) var(--ease-out);-webkit-tap-highlight-color:transparent;-webkit-backdrop-filter:blur(4px);background:oklch(0% 0 0/.62);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:10px;right:10px}.notes-capture-discard-btn:hover{background:oklch(0% 0 0/.82);transform:scale(1.08)}.notes-capture-processing{color:var(--text-1);align-items:center;gap:7px;padding:4px 2px;font-size:13px;display:flex}.notes-capture-remove{color:oklch(97% .006 80);width:22px;height:22px;transition:background var(--duration-quick);-webkit-tap-highlight-color:transparent;background:oklch(0% 0 0/.55);border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:5px;right:5px}.notes-capture-remove:hover{background:oklch(0% 0 0/.8)}.notes-capture-body{flex-direction:column;gap:6px;min-width:0;display:flex}.notes-capture-filename{color:var(--text-0);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.notes-capture-status{color:var(--text-2);align-items:center;gap:5px;font-size:12px;display:inline-flex}.notes-capture-status.processing{color:var(--text-1)}.notes-capture-status.done{color:var(--color-success);font-weight:500}.notes-capture-status.error{color:var(--color-error);font-weight:500}.notes-capture-actions{flex-wrap:wrap;align-items:center;gap:8px;margin-top:4px;display:flex}.notes-img-replace-btn{color:var(--text-3);transition:color var(--duration-quick);-webkit-tap-highlight-color:transparent;align-items:center;gap:5px;margin-top:4px;font-size:12px;display:inline-flex}.notes-img-replace-btn:hover{color:var(--text-1)}@media (width<=480px){.notes-image-empty{grid-template-columns:1fr 1fr}.notes-capture-card{gap:10px}.notes-capture-preview{max-height:260px}.ocr-capture-btn-secondary,.ocr-capture-btn-primary{flex:100px}}.gender-section{flex-direction:column;gap:10px;margin-top:4px;display:flex}.gender-label{color:var(--text-2);text-transform:uppercase;letter-spacing:.06em;margin:0;font-size:12px;font-weight:700}.gender-chips{gap:8px;display:flex}.gender-chip{border-radius:var(--r-md);background:var(--bg-2);border:1px solid var(--border-md);color:var(--text-2);cursor:pointer;transition:background var(--duration-quick), border-color var(--duration-quick), color var(--duration-quick);-webkit-tap-highlight-color:transparent;flex:1;justify-content:center;align-items:center;gap:7px;min-height:48px;padding:11px 10px;font-size:13px;font-weight:500;display:flex}.gender-chip:hover{background:var(--bg-3);color:var(--text-0)}.gender-chip.active{background:var(--ink);border-color:var(--ink);color:oklch(10% .025 75);font-weight:700}.gender-chip-emoji{font-size:15px;line-height:1}.wizard-nav{align-items:center;gap:10px;margin-top:auto;padding-top:8px;display:flex}.wizard-nav.single{justify-content:flex-end}.wizard-nav.review-nav{justify-content:space-between}.back-btn{border-radius:var(--r-md);background:var(--bg-3);height:48px;color:var(--text-1);white-space:nowrap;border:1px solid var(--border);transition:background var(--duration-quick), color var(--duration-quick);-webkit-tap-highlight-color:transparent;flex-shrink:0;align-items:center;gap:4px;padding:0 14px;font-size:14px;font-weight:500;display:inline-flex}.back-btn:hover{background:var(--bg-4);color:var(--text-0)}.back-btn:active{background:var(--bg-4)}.next-btn{border-radius:var(--r-md);background:var(--ink);color:oklch(10% .025 75);height:48px;font-family:var(--font-display);white-space:nowrap;transition:opacity var(--duration-quick);-webkit-tap-highlight-color:transparent;flex:1;justify-content:center;align-items:center;gap:6px;padding:0 20px;font-size:14px;font-weight:700;display:inline-flex}.next-btn:disabled{opacity:.38;cursor:not-allowed}.next-btn:not(:disabled):active{opacity:.8}.secondary-btn{border-radius:var(--r-md);background:var(--bg-3);height:48px;color:var(--text-0);white-space:nowrap;border:1px solid var(--border);transition:background var(--duration-quick), border-color var(--duration-quick);-webkit-tap-highlight-color:transparent;justify-content:center;align-items:center;gap:6px;padding:0 16px;font-size:14px;font-weight:500;display:inline-flex}.secondary-btn:hover{background:var(--bg-4);border-color:var(--border-md)}.secondary-btn:disabled{opacity:.38;cursor:not-allowed}.secondary-btn:not(:disabled):active{opacity:.8}.primary-btn{border-radius:var(--r-md);background:var(--ink);color:oklch(10% .025 75);height:40px;font-family:var(--font-display);white-space:nowrap;transition:opacity var(--duration-quick);-webkit-tap-highlight-color:transparent;justify-content:center;align-items:center;gap:6px;padding:0 16px;font-size:13px;font-weight:700;display:inline-flex}.primary-btn:disabled{opacity:.38;cursor:not-allowed}.primary-btn:not(:disabled):active{opacity:.8}.link-btn{color:var(--ink);text-underline-offset:3px;-webkit-tap-highlight-color:transparent;transition:opacity var(--duration-quick);align-items:center;gap:4px;min-height:44px;font-size:13px;font-weight:600;text-decoration:underline;display:inline-flex}.link-btn:hover{opacity:.75}.icon-btn{border-radius:var(--r-sm);width:44px;height:44px;transition:background var(--duration-quick), color var(--duration-quick);-webkit-tap-highlight-color:transparent;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.icon-btn.ghost{color:var(--text-2);background:0 0}.icon-btn.ghost:hover{background:var(--bg-3);color:var(--text-0)}.icon-btn.ghost:active{background:var(--bg-4)}.voice-section{flex-direction:column;gap:8px;display:flex}.voice-label{color:var(--text-1);margin:0;font-size:13px;font-weight:600}.voice-grid{flex-wrap:wrap;gap:7px;display:flex}.voice-chip{border-radius:var(--r-full);background:var(--bg-3);color:var(--text-1);border:1px solid var(--border);cursor:pointer;transition:background var(--duration-quick), color var(--duration-quick), border-color var(--duration-quick);-webkit-tap-highlight-color:transparent;justify-content:center;align-items:center;gap:5px;min-height:36px;padding:6px 14px;font-size:13px;font-weight:400;display:inline-flex}.voice-chip span{font-size:12px;line-height:1}.voice-chip.selected{background:var(--ink);color:oklch(10% .025 75);border-color:var(--ink)}.cost-row{color:var(--text-2);justify-content:space-between;align-items:center;padding:2px 0;font-size:13px;display:flex}.focus-suggestions{flex-wrap:wrap;gap:7px;margin-top:-4px;display:flex}.focus-suggestion-chip{border-radius:var(--r-full);color:var(--text-1);background:var(--bg-3);border:1px solid var(--border);cursor:pointer;transition:background var(--duration-quick), color var(--duration-quick), border-color var(--duration-quick);-webkit-tap-highlight-color:transparent;align-items:center;min-height:36px;padding:6px 12px;font-size:13px;font-weight:400;display:inline-flex}.focus-suggestion-chip:hover{color:var(--text-0);border-color:var(--border-md)}.focus-suggestion-chip:active{background:var(--bg-4)}.violation-callout{border-radius:var(--r-lg,12px);background:color-mix(in srgb, var(--color-error,#e53e3e) 10%, transparent);border:1.5px solid color-mix(in srgb, var(--color-error,#e53e3e) 40%, transparent);align-items:flex-start;gap:12px;margin:12px 0 4px;padding:14px 16px;animation:.35s violation-shake;display:flex}@keyframes violation-shake{0%{transform:translate(0)}20%{transform:translate(-5px)}40%{transform:translate(5px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}to{transform:translate(0)}}.violation-callout-icon{color:var(--color-error,#e53e3e);flex-shrink:0;margin-top:1px}.violation-callout-body{flex-direction:column;gap:2px;min-width:0;display:flex}.violation-callout-heading{color:var(--color-error,#e53e3e);margin:0;font-size:14px;font-weight:700;line-height:1.3}.violation-callout-reason{color:var(--text-1);margin:0;font-size:13px;font-weight:500;line-height:1.4}.violation-callout-hint{color:var(--text-3);margin:4px 0 0;font-size:12px;line-height:1.4}.song-card{background:var(--bg-2);border:1.5px solid var(--border-md);border-radius:var(--r-lg);text-align:left;transition:border-color var(--duration-quick), transform var(--duration-normal) var(--ease-out);-webkit-tap-highlight-color:transparent;flex-direction:column;width:100%;display:flex;overflow:hidden}.song-card:hover{border-color:var(--border-bright);transform:translateY(-2px)}.sc-art{background:oklch(.22 .09 var(--hue,75));align-items:flex-end;height:90px;display:flex;position:relative;overflow:hidden}.sc-art:not(:has(img)):before{content:"";background:linear-gradient(135deg, oklch(.28 .1 var(--hue,75)) 0%, oklch(.18 .08 var(--hue,75)) 100%);position:absolute;inset:0}.sc-art:not(:has(img)):after{content:"♪";color:oklch(.7 .08 var(--hue,75));opacity:.5;pointer-events:none;z-index:1;font-size:28px;line-height:1;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.sc-art-img{object-fit:cover;width:100%;height:100%;display:block;position:absolute;inset:0}.sc-genre-badge{z-index:2;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.08em;color:var(--text-0);border-radius:var(--r-full);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:oklch(0% 0 0/.45);padding:3px 8px;font-size:10px;font-weight:700;position:absolute;top:9px;right:9px}.sc-saved-badge{z-index:2;color:oklch(97% .006 80/.8);border-radius:var(--r-full);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:oklch(0% 0 0/.35);align-items:center;gap:4px;padding:3px 7px;font-size:11px;font-weight:600;display:flex;position:absolute;bottom:9px;right:9px}.sc-info{flex-direction:column;gap:8px;padding:12px 13px 14px;display:flex}.sc-title{font-family:var(--font-display);color:var(--text-0);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:14px;font-weight:700;line-height:1.25;display:-webkit-box;overflow:hidden}.sc-meta{flex-wrap:wrap;gap:5px;display:flex}.sc-meta-pill{font-family:var(--font-display);letter-spacing:.05em;text-transform:uppercase;color:var(--text-2);background:var(--bg-3);border-radius:var(--r-full);padding:3px 8px;font-size:11px;font-weight:600}.sc-strength-bar{background:var(--bg-4);border-radius:var(--r-full);height:3px;overflow:hidden}.sc-strength-fill{background:var(--ink);border-radius:var(--r-full);height:100%;transition:width .6s var(--ease-out)}.song-card-compact{background:var(--bg-2);border:1.5px solid var(--border-md);border-radius:var(--r-md);text-align:left;width:100%;transition:border-color var(--duration-quick), background var(--duration-quick);-webkit-tap-highlight-color:transparent;align-items:center;gap:12px;min-height:64px;padding:11px 13px;display:flex}.song-card-compact:hover{border-color:var(--border-bright);background:var(--bg-3)}.sc-compact-art{border-radius:var(--r-sm);background:linear-gradient(135deg, oklch(.28 .1 var(--hue,75)) 0%, oklch(.18 .08 var(--hue,75)) 100%);flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex;position:relative;overflow:hidden}.sc-compact-art:not(:has(img)):after{content:"♪";color:oklch(.7 .08 var(--hue,75));opacity:.65;pointer-events:none;font-size:18px;line-height:1}.sc-compact-art-img{object-fit:cover;width:100%;height:100%;display:block;position:absolute;inset:0}.sc-compact-info{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.sc-compact-title{font-family:var(--font-display);color:var(--text-0);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:700;overflow:hidden}.sc-compact-genre{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);font-size:10px;font-weight:700}.sc-compact-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.sc-compact-count{font-family:var(--font-display);color:var(--text-2);background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r-full);white-space:nowrap;padding:3px 8px;font-size:11px;font-weight:600}.song-card-shelf{cursor:pointer;-webkit-tap-highlight-color:transparent;flex-direction:column;flex:0 0 136px;width:136px;display:flex}.sc-shelf-cover{border-radius:var(--r-md);background:oklch(.22 .09 var(--hue,75));width:136px;height:136px;transition:transform var(--duration-normal) var(--ease-out);position:relative;overflow:hidden}.song-card-shelf:hover .sc-shelf-cover{transform:translateY(-2px)}.song-card-shelf:focus-visible .sc-shelf-cover{outline:2px solid var(--ink);outline-offset:2px}.song-card-shelf:focus-visible{outline:none}.sc-shelf-cover:not(:has(img)):before{content:"";background:linear-gradient(135deg, oklch(.28 .1 var(--hue,75)) 0%, oklch(.18 .08 var(--hue,75)) 100%);position:absolute;inset:0}.sc-shelf-cover:not(:has(img)):after{content:"♪";color:oklch(.7 .08 var(--hue,75));opacity:.5;pointer-events:none;font-size:44px;line-height:1;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.sc-shelf-cover-img{object-fit:cover;width:100%;height:100%;display:block;position:absolute;inset:0}.sc-shelf-title{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.01em;white-space:nowrap;text-overflow:ellipsis;margin-top:10px;font-size:13px;font-weight:700;line-height:1.25;overflow:hidden}.sc-shelf-genre{color:var(--text-2);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:11px;font-weight:500;overflow:hidden}.waveform-bars{align-items:center;gap:3px;display:flex}.wb{width:2px;height:calc(var(--h) * 42px);opacity:.55;background:currentColor;border-radius:99px}.wb.wb-playing{animation:1s ease-in-out infinite waveform}.sc-queue-btn{color:#fff;cursor:pointer;background:oklch(0% 0 0/.45);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;padding:0;transition:background .15s,transform .15s;display:inline-flex}.sc-queue-btn:hover{background:oklch(0% 0 0/.65);transform:scale(1.06)}.sc-queue-btn:active{transform:scale(.94)}.sc-queue-btn:focus-visible{outline:2px solid var(--ink);outline-offset:2px}.sc-queue-btn--floating{position:absolute;bottom:10px;right:10px;box-shadow:0 2px 10px oklch(0% 0 0/.35)}.sc-art{position:relative}.sc-compact-right .sc-queue-btn{width:28px;height:28px}.sc-queue-btn--in-queue{background:oklch(65% .17 145)}.sc-queue-btn--in-queue:hover{background:oklch(58% .19 145);transform:scale(1.06)}@keyframes sc-queue-pulse{0%{transform:scale(1);box-shadow:0 0 oklch(65% .17 145/.55)}60%{transform:scale(1.14);box-shadow:0 0 0 10px oklch(65% .17 145/0)}to{transform:scale(1);box-shadow:0 0 oklch(65% .17 145/0)}}.sc-queue-btn--pulsing{animation:.6s ease-out sc-queue-pulse}.shelf{--shelf-cover-size:136px;margin-bottom:28px}.shelf-header{justify-content:space-between;align-items:center;gap:12px;min-height:32px;padding:0 20px 12px;display:flex}.shelf-title{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text-0);margin:0;font-size:18px;font-weight:800;line-height:1.1}.shelf-header-right{flex-shrink:0;align-items:center;gap:10px;display:flex}.shelf-sub,.shelf-link{font-family:var(--font-display);letter-spacing:.1em;text-transform:uppercase;color:var(--text-2);white-space:nowrap;font-size:11px;font-weight:700}.shelf-link{cursor:pointer;-webkit-tap-highlight-color:transparent;transition:color var(--duration-quick);background:0 0;border:none;min-height:32px;padding:6px 0}.shelf-link:hover{color:var(--ink)}.shelf-action-btn{background:var(--bg-2);border:1.5px solid var(--border-md);width:36px;height:36px;color:var(--ink);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background var(--duration-quick), border-color var(--duration-quick), transform var(--duration-quick) var(--ease-out);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:inline-flex;position:relative}.shelf-action-btn:before{content:"";position:absolute;inset:-4px}.shelf-action-btn:hover{background:var(--ink-pale);border-color:var(--border-bright);transform:scale(1.06)}.shelf-action-btn:active{transform:scale(.94)}.shelf-action-btn:focus-visible{outline:2px solid var(--ink);outline-offset:2px}.shelf-rail{position:relative}.shelf-scroll{scrollbar-width:none;-ms-overflow-style:none;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;scroll-padding-inline:20px;overflow:auto visible}.shelf-scroll::-webkit-scrollbar{display:none}.shelf-track{align-items:flex-start;gap:12px;padding:4px 20px 8px;display:flex}.shelf-track>*{scroll-snap-align:start;flex:none}.shelf-empty{color:var(--text-2);letter-spacing:-.01em;flex:auto;padding:32px 20px;font-size:13px;line-height:1.5}.shelf-empty-plus{background:var(--bg-2);border:1px solid var(--border-md);width:20px;height:20px;color:var(--ink);vertical-align:-4px;border-radius:50%;justify-content:center;align-items:center;margin:0 2px;display:inline-flex}.shelf-arrow{display:none}@media (hover:hover) and (pointer:fine){.shelf-arrow{top:calc(4px + (var(--shelf-cover-size) / 2) - 20px);width:40px;height:40px;color:var(--text-0);border:1.5px solid var(--border-md);z-index:2;opacity:0;cursor:pointer;-webkit-backdrop-filter:blur(8px);transition:opacity var(--duration-quick), background var(--duration-quick), border-color var(--duration-quick), transform var(--duration-quick) var(--ease-out);-webkit-tap-highlight-color:transparent;background:oklch(13% .022 75/.85);border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute}.shelf-arrow--left{left:4px}.shelf-arrow--right{right:4px}.shelf:hover .shelf-arrow,.shelf-arrow:focus-visible{opacity:1}.shelf-arrow:hover{background:var(--ink);color:oklch(10% .025 75);border-color:var(--ink);transform:scale(1.06)}.shelf-arrow:active{transform:scale(.96)}.shelf-arrow--hidden{pointer-events:none;opacity:0!important}}.ps-card{text-align:left;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;flex:0 0 136px;width:136px;padding:0;display:flex}.ps-cover{border-radius:var(--r-md);background:var(--bg-2);border:1.5px solid var(--border-md);width:136px;height:136px;color:var(--ink);transition:border-color var(--duration-quick), transform var(--duration-normal) var(--ease-out), background var(--duration-quick);justify-content:center;align-items:center;display:flex;overflow:hidden}.ps-card:hover .ps-cover{border-color:var(--border-bright);transform:translateY(-2px)}.ps-card:focus-visible .ps-cover{border-color:var(--ink);outline:2px solid var(--ink);outline-offset:2px}.ps-card:focus-visible{outline:none}.ps-cover-img{object-fit:cover;width:100%;height:100%;display:block}.ps-name{font-family:var(--font-display);color:var(--text-0);white-space:nowrap;text-overflow:ellipsis;letter-spacing:-.01em;margin-top:10px;font-size:13px;font-weight:700;line-height:1.25;overflow:hidden}.ps-count{color:var(--text-2);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:11px;font-weight:600;overflow:hidden}.library-screen{min-height:100dvh;padding-bottom:calc(var(--nav-h) + var(--mp-h) + env(safe-area-inset-bottom) + 8px);flex-direction:column;display:flex}.lib-header{padding:calc(env(safe-area-inset-top) + 24px) 20px 16px;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.lib-header-left{flex:1;min-width:0}.lib-title{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.03em;margin:0;font-size:40px;font-weight:800;line-height:.97}.lib-header-actions{flex-shrink:0;align-items:center;gap:6px;padding-top:4px;display:flex}.lib-settings-btn{border-radius:var(--r-sm);border:1px solid var(--border);background:var(--bg-2);width:44px;height:44px;color:var(--text-2);transition:color var(--duration-quick), background var(--duration-quick), border-color var(--duration-quick);cursor:pointer;justify-content:center;align-items:center;display:flex}.lib-settings-btn:hover{color:var(--text-0);background:var(--bg-3);border-color:var(--border-md)}.lib-search-wrap{padding:0 20px 20px}.lib-search{align-items:center;display:flex;position:relative}.lib-search-icon{color:var(--text-3);pointer-events:none;position:absolute;left:14px}.lib-search-input{background:var(--bg-2);border:1.5px solid var(--border-md);border-radius:var(--r-full);width:100%;font-family:var(--font-body);color:var(--text-0);transition:border-color var(--duration-quick), box-shadow var(--duration-quick);-webkit-appearance:none;outline:none;padding:11px 14px 11px 40px;font-size:14px}.lib-search-input:focus{border-color:var(--ink);box-shadow:0 0 0 3px var(--ink-dim)}.lib-search-input::placeholder{color:var(--text-3)}.lib-search-input::-webkit-search-cancel-button{display:none}.lib-search-clear{background:var(--bg-4);width:22px;height:22px;color:var(--text-1);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;right:12px}.lib-create-inline{padding:0 20px 12px}.pl-create-row{align-items:center;gap:8px;display:flex}.pl-create-input{background:var(--bg-2);border:1.5px solid var(--border-bright);border-radius:var(--r-md);font-family:var(--font-body);color:var(--text-0);transition:border-color var(--duration-quick), box-shadow var(--duration-quick);outline:none;flex:1;padding:11px 13px;font-size:14px}.pl-create-input:focus{border-color:var(--ink);box-shadow:0 0 0 3px var(--ink-dim)}.pl-create-input::placeholder{color:var(--text-3)}.pl-create-cancel{border-radius:var(--r-sm);border:1px solid var(--border-md);color:var(--text-2);font-family:var(--font-body);cursor:pointer;white-space:nowrap;transition:background var(--duration-quick);background:0 0;min-height:44px;padding:10px 14px;font-size:13px;font-weight:600}.pl-create-cancel:hover{background:var(--bg-3)}.pl-create-save{border-radius:var(--r-sm);background:var(--ink);color:oklch(10% .025 75);font-family:var(--font-display);cursor:pointer;white-space:nowrap;transition:opacity var(--duration-quick);border:none;min-height:44px;padding:10px 18px;font-size:13px;font-weight:700}.pl-create-save:disabled{opacity:.45;cursor:default}.pl-create-save:not(:disabled):hover{opacity:.9}.lib-content{flex:1;padding-top:4px;overflow-y:auto}.lib-search-results{padding:0 20px 20px}.lib-results-count{font-family:var(--font-display);letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);margin:0 0 12px;font-size:11px;font-weight:700}.lib-list{flex-direction:column;gap:8px;display:flex}.lib-empty-search{text-align:left;padding:40px 20px}.lib-empty-search-text{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.01em;margin:0 0 6px;font-size:18px;font-weight:700}.lib-empty-search-sub{color:var(--text-2);margin:0;font-size:14px}.lib-empty{flex-direction:column;align-items:flex-start;gap:12px;padding:60px 20px;display:flex}.lib-empty-text{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.02em;font-size:22px;font-weight:800;line-height:1.1}.lib-empty-sub{color:var(--text-2);max-width:280px;margin-top:-4px;font-size:14px;line-height:1.6}.lib-empty-btn{background:var(--ink);color:oklch(10% .025 75);border-radius:var(--r-full);font-family:var(--font-display);-webkit-tap-highlight-color:transparent;transition:opacity var(--duration-quick);cursor:pointer;border:none;min-height:48px;margin-top:8px;padding:13px 24px;font-size:14px;font-weight:700}.lib-empty-btn:hover{opacity:.9}.lib-archived-section{flex-direction:column;gap:6px;padding:8px 20px 20px;display:flex}.lib-archived-toggle{font-family:var(--font-display);color:var(--text-2);cursor:pointer;-webkit-tap-highlight-color:transparent;min-height:44px;transition:color var(--duration-quick);background:0 0;border:none;align-self:flex-start;align-items:center;gap:8px;padding:10px 2px;font-size:13px;font-weight:700;display:inline-flex}.lib-archived-toggle:hover{color:var(--text-0)}.lib-archived-list{flex-direction:column;gap:6px;padding-top:6px;display:flex}.playlist-row{background:var(--bg-2);border:1.5px solid var(--border-md);border-radius:var(--r-md);transition:border-color var(--duration-quick), background var(--duration-quick);-webkit-tap-highlight-color:transparent;text-align:left;align-items:center;gap:12px;width:100%;min-height:68px;padding:12px 14px;display:flex}.playlist-row--archived{opacity:.6}.pl-icon{border-radius:var(--r-sm);background:var(--bg-0);border:1.5px solid var(--border-md);width:44px;height:44px;color:var(--ink);flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.pl-icon--archived{background:var(--bg-3);border-color:var(--border);color:var(--text-3)}.pl-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.pl-name{font-family:var(--font-display);color:var(--text-0);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:700;overflow:hidden}.pl-count{color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:600}.pl-unarchive-btn{font-family:var(--font-display);color:oklch(10% .025 75);background:var(--ink);border-radius:var(--r-full);cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;flex-shrink:0;min-height:36px;padding:5px 12px;font-size:12px;font-weight:700}.lib-skeleton-wrap{padding-top:4px}.lib-skel-shelf{margin-bottom:28px}.lib-skel-title{margin:0 20px 12px}.lib-skel-row{gap:12px;padding:0 20px;display:flex;overflow:hidden}.lib-skel-card{flex:0 0 136px}@media (width<=420px){.lib-title{font-size:34px}.lib-header-actions{gap:4px}}@media (width>=768px){.library-screen{min-height:0;padding-bottom:32px}.lib-content{flex:none;overflow:visible}.lib-header{align-items:center;gap:32px;padding:40px 32px 16px}.lib-title{letter-spacing:-.035em;font-size:48px}.lib-header-actions{display:none}.lib-search-wrap{max-width:560px;padding:0 32px 28px}.lib-search-input{padding:13px 16px 13px 44px;font-size:15px}.lib-create-inline{max-width:560px;padding:0 32px 16px}.lib-search-results{padding:0 32px 24px}.lib-empty{padding:72px 32px}.lib-archived-section{padding:16px 32px 32px}.lib-skel-title{margin:0 32px 12px}.lib-skel-row{padding:0 32px}}@media (width>=1280px){.lib-header{padding:48px 40px 20px}.lib-title{font-size:56px}.lib-search-wrap,.lib-create-inline,.lib-search-results{padding-inline:40px}.lib-empty{padding:96px 40px}.lib-archived-section{padding:16px 40px 40px}.lib-skel-title{margin-inline:40px}.lib-skel-row{padding-inline:40px}}@media (width>=768px){.library-screen .shelf-header{padding:0 32px 14px}.library-screen .shelf-track{gap:16px;padding:6px 32px 10px}.library-screen .shelf-scroll{scroll-padding-inline:32px}.library-screen .shelf-arrow--left{left:20px}.library-screen .shelf-arrow--right{right:20px}.library-screen .shelf-title{font-size:22px}.library-screen .shelf{--shelf-cover-size:172px;margin-bottom:40px}.library-screen .song-card-shelf,.library-screen .sc-shelf-cover{width:172px}.library-screen .sc-shelf-cover{height:172px}.library-screen .playlist-shelf-card,.library-screen .ps-card,.library-screen .ps-cover{width:172px}.library-screen .ps-cover{height:172px}}@media (width>=1280px){.library-screen .shelf-header{padding:0 40px 14px}.library-screen .shelf-track{gap:20px;padding:6px 40px 10px}.library-screen .shelf-scroll{scroll-padding-inline:40px}.library-screen .shelf-arrow--left{left:28px}.library-screen .shelf-arrow--right{right:28px}.library-screen .shelf{--shelf-cover-size:192px}.library-screen .song-card-shelf,.library-screen .sc-shelf-cover,.library-screen .ps-card,.library-screen .ps-cover{width:192px}.library-screen .sc-shelf-cover,.library-screen .ps-cover{height:192px}}@media (width>=768px){.shelf.lib-playlists-grid .shelf-track{grid-template-columns:repeat(auto-fill,minmax(172px,1fr));gap:16px;padding:6px 32px 10px;display:grid;overflow-x:visible}.shelf.lib-playlists-grid .shelf-scroll{scroll-padding-inline:0;overflow-x:visible}.shelf.lib-playlists-grid .shelf-arrow{display:none!important}.shelf.lib-playlists-grid .shelf-track>*,.shelf.lib-playlists-grid .ps-card,.shelf.lib-playlists-grid .ps-cover{width:100%}.shelf.lib-playlists-grid .ps-cover{aspect-ratio:1;height:auto}.shelf.lib-playlists-grid .song-card-shelf,.shelf.lib-playlists-grid .sc-shelf-cover{width:100%}.shelf.lib-playlists-grid .sc-shelf-cover{aspect-ratio:1;height:auto}}@media (width>=1280px){.shelf.lib-playlists-grid .shelf-track{grid-template-columns:repeat(auto-fill,minmax(192px,1fr));gap:20px;padding:6px 40px 10px}}@media (width>=900px){.lib-list{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:8px 16px;display:grid}}.practice-screen{min-height:100dvh;padding-bottom:calc(var(--nav-h) + var(--mp-h) + env(safe-area-inset-bottom) + 8px);flex-direction:column;display:flex}.practice-screen.no-nav{padding-bottom:env(safe-area-inset-bottom,20px)}.practice-header{padding:calc(env(safe-area-inset-top) + 20px) 20px 12px;flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.practice-title{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.2px;font-size:24px;font-weight:700}.practice-back{width:44px;height:44px;color:var(--text-1);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background var(--duration-quick), color var(--duration-quick);background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.practice-back:hover{background:var(--bg-3);color:var(--text-0)}.practice-exit{color:var(--color-error);background:var(--color-error-bg);border-radius:var(--r-full);transition:background var(--duration-quick), border-color var(--duration-quick);-webkit-tap-highlight-color:transparent;border:1px solid oklch(71% .16 25/.25);align-items:center;gap:6px;min-height:44px;padding:7px 16px;font-size:13px;font-weight:600;display:flex}.practice-exit:hover{background:oklch(71% .16 25/.18)}.practice-body{flex-direction:column;flex:1;padding:0 20px;display:flex;position:relative;overflow-y:auto}.practice-body>div{flex-direction:column;flex:1;min-height:0;display:flex}.pick-screen{flex-direction:column;gap:14px;padding-bottom:16px;display:flex;overflow-y:auto}.pick-intro-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-lg);align-items:flex-start;gap:14px;padding:16px;display:flex}.pic-icon{width:28px;height:28px;color:var(--ink);flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;display:flex}.pic-title{font-family:var(--font-display);color:var(--text-0);margin-bottom:5px;font-size:15px;font-weight:600}.pic-body{color:var(--text-1);font-size:13px;line-height:1.55}.hint-explainer{background:var(--ink-pale);border:1px solid var(--border-warm);border-radius:var(--r-md);padding:14px 16px}.he-label{text-transform:uppercase;letter-spacing:.6px;color:var(--ink);margin-bottom:10px;font-size:13px;font-weight:700}.he-steps{flex-direction:column;gap:7px;display:flex}.he-step{color:var(--text-1);align-items:center;gap:10px;font-size:13px;display:flex}.he-step--anchor{color:var(--ink);font-weight:600}.he-num{background:var(--bg-3);width:20px;height:20px;color:var(--text-0);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.he-step--anchor .he-num{background:var(--ink);color:oklch(10% .025 75)}.start-btn{background:var(--ink);color:oklch(10% .025 75);border-radius:var(--r-md);width:100%;font-family:var(--font-display);-webkit-tap-highlight-color:transparent;transition:opacity var(--duration-quick);padding:14px;font-size:15px;font-weight:700}.start-btn:disabled{opacity:.5;cursor:not-allowed}.session-screen{flex-direction:column;gap:14px;padding-bottom:12px;display:flex}.session-top{flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.progress-dots{align-items:center;gap:5px;display:flex}.pdot{background:var(--bg-4);width:6px;height:6px;transition:background var(--duration-normal), width var(--duration-normal) var(--ease-out);border-radius:99px}.pdot.active{background:var(--ink);width:18px}.pdot.done{background:var(--ink);opacity:.3}.card-counter{color:var(--text-2);font-size:14px}.card-scene{perspective:1000px;cursor:pointer;-webkit-tap-highlight-color:transparent;flex-direction:column;flex-shrink:0;display:flex}.card-area{flex-direction:column;display:flex}.card-flipper{width:100%;transform-style:preserve-3d;border-radius:var(--r-xl);transition:transform .5s cubic-bezier(.45,.05,.2,1);position:relative}.card-flipper.is-flipped{transform:rotateY(180deg)}.card-face{backface-visibility:hidden;border-radius:var(--r-xl);border:1px solid var(--border);flex-direction:column;gap:10px;padding:18px;display:flex}.card-front{background:var(--bg-2);position:relative}.card-back{background:var(--bg-2);border-color:var(--border-md);height:auto;position:absolute;inset:0;overflow:visible;transform:rotateY(180deg)}.card-front-top{justify-content:space-between;align-items:center;display:flex}.hint-btn-corner{color:var(--ink);background:var(--ink-dim);border-radius:var(--r-full);border:1px solid var(--border-bright);transition:background var(--duration-quick), transform var(--duration-quick) var(--ease-out);-webkit-tap-highlight-color:transparent;flex-shrink:0;align-items:center;gap:4px;min-width:44px;min-height:44px;padding:8px;display:flex}.hint-btn-corner:hover{background:oklch(80% .17 80/.2)}.hint-btn-corner:active{transform:scale(.93)}.hint-btn-count{color:var(--ink);padding-right:2px;font-size:13px;font-weight:700;line-height:1}.card-face-label{text-transform:uppercase;letter-spacing:.7px;color:var(--text-2);font-size:12px;font-weight:700;display:block}.card-face-label.faded{text-transform:none;letter-spacing:0;opacity:.55;font-size:14px;font-weight:400;line-height:1.4}.card-face-label.answer-label{color:var(--color-success)}.card-face-label.ink-label{color:var(--ink)}.card-question-text{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.2px;font-size:21px;font-weight:600;line-height:1.3}.card-answer-text{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.3px;font-size:24px;font-weight:600;line-height:1.2}.card-song-link{color:var(--text-2);background:var(--bg-3);border-radius:var(--r-full);width:fit-content;transition:color var(--duration-quick);align-items:center;gap:5px;padding:4px 10px;font-size:13px;display:flex}.card-song-link:hover{color:var(--ink)}.card-tap-cue{color:var(--text-3);align-items:center;gap:5px;margin-top:auto;padding-top:6px;font-size:13px;display:flex}.back-divider{background:var(--border);height:1px;margin:2px 0 4px}.back-anchor{background:var(--ink-dim);border-radius:var(--r-sm);border:1px solid var(--border-warm);margin-top:4px;padding:10px 12px}.back-anchor-text{font-family:var(--font-display);color:var(--ink);margin-top:4px;font-size:13px;font-style:italic;line-height:1.5}.front-hints{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r-md);flex-direction:column;gap:8px;margin-top:4px;padding:12px 13px;display:flex}.front-hints-label{color:var(--text-2);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:7px;font-size:12px;font-weight:700;display:flex}.hint-count-badge{background:var(--ink-dim);color:var(--ink);border-radius:var(--r-full);padding:1px 7px;font-size:12px;font-weight:700}.hint-lines{flex-direction:column;gap:2px;display:flex}.hint-line{font-family:var(--font-display);padding:3px 0;font-style:italic;line-height:1.6}.hint-line--context{color:var(--text-2);font-size:13px}.hint-line--anchor{color:var(--ink);background:var(--ink-dim);border-radius:var(--r-xs);padding:6px 10px;font-size:14px;font-style:normal;font-weight:500}.hint-anchor-placeholder{text-align:center;color:var(--text-3);letter-spacing:3px;padding:2px 0;font-size:16px}.below-card{z-index:1;flex-direction:column;flex-shrink:0;justify-content:flex-end;min-height:90px;padding-bottom:4px;display:flex;position:relative}.hint-area{flex-direction:column;align-items:center;gap:6px;display:flex}.hint-nudge,.hints-exhausted{color:var(--text-3);text-align:center;font-size:14px}.grade-area{flex-direction:column;gap:10px;display:flex}.grade-prompt{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);text-align:center;font-size:11px;font-weight:700}.grade-btns{gap:8px;display:flex}.grade-btn{border-radius:var(--r-md);-webkit-tap-highlight-color:transparent;transition:background var(--duration-quick), transform var(--duration-quick) var(--ease-out), filter var(--duration-quick);border:1.5px solid #0000;flex-direction:column;flex:1;align-items:center;gap:7px;min-height:76px;padding:16px 4px;display:flex}.grade-btn:active{filter:brightness(1.1);transform:scale(.96)}.g-icon{justify-content:center;align-items:center;line-height:1;display:flex}.g-label{font-family:var(--font-display);text-align:center;letter-spacing:.01em;font-size:12px;font-weight:800;line-height:1.2}.g-missed{background:var(--color-error-bg);color:var(--color-error);border-color:oklch(71% .16 25/.25)}.g-cue{background:var(--ink-dim);color:var(--ink);border-color:var(--border-bright)}.g-knew{background:var(--ink);color:oklch(10% .025 75);border-color:var(--ink)}.done-screen{text-align:center;flex-direction:column;align-items:center;gap:16px;padding:28px 0;display:flex;overflow-y:auto}.done-badge{background:var(--ink);color:oklch(10% .025 75);border:none;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;display:flex}.done-kicker{font-family:var(--font-display);letter-spacing:.12em;text-transform:uppercase;color:var(--ink);align-items:center;gap:8px;margin-bottom:-4px;font-size:11px;font-weight:700;display:inline-flex}.done-kicker:before{content:"";background:currentColor;flex-shrink:0;width:16px;height:1.5px;display:block}.done-title{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.04em;font-size:44px;font-weight:900;line-height:.95}.done-subtitle{color:var(--text-2);margin-top:-4px;font-size:14px}.score-cards{gap:8px;width:100%;display:flex}.score-card{background:var(--bg-2);border:1.5px solid var(--border-md);border-radius:var(--r-md);flex-direction:column;flex:1;align-items:center;gap:4px;padding:16px 4px;display:flex}.sc-num{font-family:var(--font-display);letter-spacing:-.04em;font-size:52px;font-weight:900;line-height:.9}.sc-label{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;font-size:10px;font-weight:700}.sc-hint{color:var(--text-3);font-size:11px}.sc-green .sc-num,.sc-green .sc-label{color:var(--color-success)}.sc-amber .sc-num,.sc-amber .sc-label{color:var(--ink)}.sc-red .sc-num,.sc-red .sc-label{color:var(--color-error)}.done-advice{color:var(--text-1);max-width:290px;font-size:14px;line-height:1.65}.done-actions{flex-direction:column;gap:10px;width:100%;display:flex}.done-cta{border-radius:var(--r-md);width:100%;font-family:var(--font-display);-webkit-tap-highlight-color:transparent;transition:opacity var(--duration-quick);padding:13px;font-size:14px;font-weight:700}.done-cta-secondary{background:var(--ink);color:oklch(10% .025 75)}.done-cta-finish{background:var(--bg-3);color:var(--text-1)}.done-cta:hover:not(:disabled){opacity:.88}.empty-nudge{background:var(--ink-pale);border:1px solid var(--border-warm);border-radius:var(--r-md);align-items:flex-start;gap:12px;padding:14px 15px;display:flex}.en-title{color:var(--ink);margin-bottom:3px;font-size:14px;font-weight:600}.en-body{color:var(--text-1);font-size:13px;line-height:1.5}.en-body-wrap{flex-direction:column;gap:6px;display:flex}.en-create-btn{background:var(--ink);color:oklch(10% .025 75);border-radius:var(--r-md);font-size:13px;font-weight:700;font-family:var(--font-display);-webkit-tap-highlight-color:transparent;transition:opacity var(--duration-quick);align-self:flex-start;margin-top:4px;padding:9px 18px}.en-create-btn:hover{opacity:.88}.practice-error{color:var(--color-error);background:var(--color-error-bg);border-radius:var(--r-sm);border:1px solid oklch(71% .16 25/.22);padding:10px 14px;font-size:13px}.practice-auto-loading{flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:80px 24px;display:flex}.practice-spinner{border:2.5px solid var(--bg-4);border-top-color:var(--ink);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}.practice-loading-text{color:var(--text-3);font-size:14px}.rs-overlay{-webkit-backdrop-filter:blur(4px);z-index:300;background:#000000a6;align-items:flex-end;display:flex;position:fixed;inset:0}.rs-sheet{background:var(--bg-1);width:100%;padding:0 0 calc(env(safe-area-inset-bottom) + 16px);overscroll-behavior:contain;border-radius:22px 22px 0 0;max-height:92dvh;overflow-y:auto}.rs-handle{background:var(--bg-4);border-radius:99px;width:36px;height:4px;margin:12px auto 0}.rs-form{padding:0 20px 8px}.rs-header{border-bottom:1px solid var(--bg-3);margin-bottom:12px;padding:18px 0 14px}.rs-title-row{align-items:center;gap:8px;margin-bottom:5px;display:flex}.rs-flag-icon{color:var(--red);flex-shrink:0}.rs-title{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.1px;font-size:17px;font-weight:600}.rs-sub{color:var(--text-2);font-size:14px;line-height:1.5}.rs-song-name{color:var(--text-1);font-style:italic}.rs-options{flex-direction:column;gap:4px;margin-bottom:4px;display:flex}.rs-option{border-radius:var(--r-md);text-align:left;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:11px 14px;transition:background .15s;display:flex}.rs-option:hover,.rs-option.selected{background:var(--bg-3)}.rs-option-icon{text-align:center;width:20px;color:var(--text-3);flex-shrink:0;font-size:13px;line-height:1}.rs-option-text{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.rs-option-label{color:var(--text-0);font-size:14px;font-weight:500;line-height:1.3}.rs-option-desc{color:var(--text-2);font-size:13px;line-height:1.4}.rs-radio{background:var(--bg-4);border:none;border-radius:50%;flex-shrink:0;width:18px;height:18px;transition:background .15s;position:relative}.rs-radio.checked{background:var(--ink)}.rs-radio.checked:after{content:"";background:var(--bg-0);border-radius:50%;position:absolute;inset:5px}.rs-detail-wrap{margin-top:8px;position:relative;overflow:hidden}.rs-detail{background:var(--bg-3);border-radius:var(--r-md);width:100%;color:var(--text-0);resize:none;border:none;outline:none;padding:12px 14px 28px;font-size:14px;line-height:1.55;transition:background .15s}.rs-detail:focus{background:var(--bg-4)}.rs-detail-count{color:var(--text-3);pointer-events:none;font-size:12px;position:absolute;bottom:8px;right:12px}.rs-error{color:var(--red);border-radius:var(--r-sm);background:#f8717114;margin-top:10px;padding:9px 12px;font-size:13px;line-height:1.4}.rs-actions{gap:10px;margin-top:18px;display:flex}.rs-cancel{border-radius:var(--r-md);background:var(--bg-3);color:var(--text-1);border:none;flex:1;padding:12px;font-size:14px;font-weight:500;transition:background .15s}.rs-cancel:hover{background:var(--bg-4)}.rs-cancel:disabled{opacity:.5}.rs-submit{border-radius:var(--r-md);background:var(--red);color:#fff;border:none;flex:2;justify-content:center;align-items:center;gap:8px;padding:12px;font-size:14px;font-weight:600;transition:opacity .15s;display:flex}.rs-submit:hover{opacity:.88}.rs-submit:disabled{opacity:.4;cursor:not-allowed}.rs-legal{color:var(--text-3);text-align:center;margin-top:14px;font-size:12px;line-height:1.5}.rs-done{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:32px 20px 20px;display:flex}.rs-done-icon{background:#34d3991f;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.rs-done h3{font-family:var(--font-display);color:var(--text-0);font-size:18px;font-weight:600}.rs-done p{color:var(--text-1);max-width:280px;font-size:14px;line-height:1.6}.qs-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:260;background:#00000080;position:fixed;inset:0}.qs-sheet{background:var(--bg-1);z-index:270;border-radius:20px 20px 0 0;flex-direction:column;max-height:80vh;padding-top:8px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -8px 40px oklch(0% 0 0/.5)}@media (width>=768px){.qs-sheet{transform:translateX(calc(-50% + (var(--sidebar-w) / 2)));width:var(--frame-w);max-width:calc(100vw - var(--sidebar-w) - 32px);left:50%;right:auto;bottom:calc(var(--player-h) + 16px);border-radius:20px;max-height:70vh}}.qs-handle{background:var(--bg-4);border-radius:2px;flex-shrink:0;width:40px;height:4px;margin:0 auto 12px}.qs-header{flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:12px;padding:4px 20px 14px;display:flex}.qs-title{color:var(--text-0);margin:0 0 4px;font-size:18px;font-weight:700}.qs-subtitle{color:var(--text-2);margin:0;font-size:13px}.qs-subtitle strong{color:var(--text-1);font-weight:600}.qs-header-actions{align-items:center;gap:8px;display:flex}.qs-clear-btn{background:var(--bg-2);color:var(--text-1);cursor:pointer;border:none;border-radius:8px;align-items:center;gap:6px;padding:7px 10px;font-size:12px;font-weight:600;display:inline-flex}.qs-clear-btn:hover:not(:disabled){background:var(--bg-3)}.qs-clear-btn:disabled{opacity:.4;cursor:default}.qs-close-btn{background:var(--bg-2);width:32px;height:32px;color:var(--text-1);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.qs-close-btn:hover{background:var(--bg-3)}.qs-scroll{padding:0 12px calc(env(safe-area-inset-bottom) + 20px);flex:1;min-height:0;overflow-y:auto}.qs-empty{color:var(--text-3);text-align:center;padding:24px 20px;font-size:14px}.qs-list{flex-direction:column;display:flex}.qs-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);margin:0;padding:12px 8px 6px;font-size:11px;font-weight:700}.qs-section-label--muted{opacity:.6}.qs-row{border-radius:10px;align-items:center;gap:10px;min-height:56px;padding:10px 8px;transition:background .15s,opacity .15s;display:flex}.qs-row--past{opacity:.55}.qs-row--current,.qs-row--upcoming:hover{background:var(--bg-2)}.qs-row--dragging{opacity:.4}.qs-row--drop-target{background:var(--bg-3);box-shadow:inset 0 2px 0 var(--ink)}.qs-drag-handle{color:var(--text-3);cursor:grab;touch-action:none;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:6px 2px;display:flex}.qs-drag-handle:active{cursor:grabbing}.qs-cover{object-fit:cover;background:var(--bg-3);border-radius:6px;flex-shrink:0;width:40px;height:40px}.qs-cover--placeholder{background:linear-gradient(135deg, var(--bg-3), var(--bg-4))}.qs-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.qs-row-title{color:var(--text-0);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.qs-row--past .qs-row-title{color:var(--text-2)}.qs-now-playing-pill{color:var(--ink);align-items:center;gap:5px;font-size:11px;font-weight:600;display:inline-flex}.qs-pulse{background:var(--ink);border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite qs-pulse}@keyframes qs-pulse{0%,to{opacity:.4;transform:scale(.9)}50%{opacity:1;transform:scale(1.1)}}.qs-row-actions{flex-shrink:0;gap:4px;display:flex}.qs-action-btn{width:32px;height:32px;color:var(--text-2);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;display:flex}.qs-action-btn:hover{background:var(--bg-3);color:var(--text-0)}.qs-action-btn--danger:hover{color:var(--red,#e74c3c)}.qs-row--manual{background:0 0}.qs-row--manual:hover{background:var(--bg-2)}.qs-section-playlist{color:var(--text-1);text-transform:none;letter-spacing:normal;font-weight:600}.qs-row-badge{color:var(--text-3);font-size:11px;font-weight:500}.om-wrap{display:inline-flex;position:relative}.om-trigger{background:var(--bg-2);border:1px solid var(--border-md);color:var(--text-1);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background var(--duration-quick), border-color var(--duration-quick), color var(--duration-quick), transform var(--duration-quick) var(--ease-out);border-radius:50%;justify-content:center;align-items:center;padding:0;display:inline-flex}.om-trigger:hover{background:var(--bg-3);border-color:var(--border-bright);color:var(--text-0)}.om-trigger:active{transform:scale(.93)}.om-trigger[aria-expanded=true]{background:var(--bg-3);border-color:var(--border-bright);color:var(--text-0)}.om-menu{background:var(--bg-1);border:1.5px solid var(--border-md);border-radius:var(--r-md);z-index:50;transform-origin:100% 0;flex-direction:column;gap:2px;min-width:184px;padding:4px;display:flex;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 12px 32px oklch(0% 0 0/.35)}.om-item{border-radius:var(--r-sm);color:var(--text-0);font-family:var(--font-body);text-align:left;cursor:pointer;white-space:nowrap;transition:background var(--duration-quick);background:0 0;border:none;align-items:center;gap:10px;min-height:40px;padding:9px 12px;font-size:14px;font-weight:500;display:flex}.om-item:hover:not(:disabled){background:var(--bg-3)}.om-item:focus-visible{outline:2px solid var(--ink);outline-offset:-2px}.om-item:disabled{opacity:.45;cursor:default}.om-item-icon{width:18px;height:18px;color:var(--text-2);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.om-item--danger,.om-item--danger .om-item-icon{color:var(--color-error)}.om-item--danger:hover:not(:disabled){background:var(--color-error-bg)}.om-item-label{flex:1;min-width:0}@keyframes pc-spin{to{transform:rotate(360deg)}}.pc-spinner{transform-origin:50%;animation:.75s linear infinite pc-spin}.pc-play-btn{cursor:pointer;color:oklch(10% .025 75);background:var(--ink);-webkit-tap-highlight-color:transparent;transition:opacity var(--duration-quick), transform var(--duration-quick) var(--ease-out);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.pc-play-btn__ring{transition:border-color var(--duration-quick);pointer-events:none;background:0 0;border:1.5px solid #0000;border-radius:50%;position:absolute;inset:-4px}.pc-play-btn:hover:not(:disabled) .pc-play-btn__ring{border-color:var(--border-bright)}.pc-play-btn:hover:not(:disabled){opacity:.9;transform:scale(1.04)}.pc-play-btn:active:not(:disabled){transform:scale(.95)}.pc-play-btn:disabled{opacity:.5;cursor:not-allowed}.pc-play-btn--error{background:color-mix(in oklch, var(--color-error) 70%, var(--bg-3))}.pc-play-btn--lg{width:64px;height:64px}.pc-play-btn--sm{width:40px;height:40px}.pc-scrubber{flex-direction:column;gap:4px;width:100%;display:flex}.pc-scrubber__track{appearance:none;border-radius:var(--r-full);cursor:pointer;background:linear-gradient(to right, var(--ink) 0%, var(--ink) var(--pct,0%), var(--bg-4) var(--pct,0%), var(--bg-4) 100%);width:100%;height:4px;transition:height var(--duration-quick);outline:none}.pc-scrubber__track:hover{height:5px}.pc-scrubber__track::-webkit-slider-thumb{-webkit-appearance:none;background:var(--ink);cursor:pointer;width:16px;height:16px;box-shadow:0 0 0 3px var(--ink-dim);transition:transform var(--duration-quick) var(--ease-out);border-radius:50%}.pc-scrubber__track::-webkit-slider-thumb:hover{box-shadow:0 0 0 5px var(--ink-dim);transform:scale(1.25)}.pc-scrubber__track:active::-webkit-slider-thumb{box-shadow:0 0 0 5px var(--ink-dim);transform:scale(1.25)}.pc-scrubber__track::-moz-range-thumb{background:var(--ink);cursor:pointer;border:none;border-radius:50%;width:16px;height:16px}.pc-scrubber__times{font-family:var(--font-display);font-variant-numeric:tabular-nums;color:var(--text-3);letter-spacing:.02em;justify-content:space-between;padding:0 1px;font-size:11px;display:flex}.pc-controls{flex-direction:column;width:100%;margin-bottom:30px;display:flex}.pc-controls__row{justify-content:center;align-items:center;gap:24px;display:flex}.pc-spacer{flex-shrink:0;width:44px;height:44px}.pc-icon-btn{width:44px;height:44px;color:var(--text-1);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background var(--duration-quick), color var(--duration-quick);background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex;position:relative}.pc-icon-btn:hover:not(:disabled){background:var(--bg-3);color:var(--text-0)}.pc-icon-btn:disabled{opacity:.25;cursor:default}.pc-toggle{color:var(--text-2)}.pc-toggle--on{color:var(--ink);position:relative}.pc-toggle--on:after{content:"";background:var(--ink);border-radius:50%;width:5px;height:5px;position:absolute;bottom:5px;left:50%;transform:translate(-50%)}.pc-toggle--on:hover:not(:disabled){color:var(--ink);background:var(--ink-pale)}.pc-icon-btn--skip{flex-direction:column;gap:1px;height:48px}.pc-skip-label{font-family:var(--font-display);color:var(--text-2);letter-spacing:.03em;font-size:10px;font-weight:700;line-height:1}.pc-secondary{justify-content:space-between;align-items:center;gap:12px;padding:18px 2px 0;display:flex}.pc-speed-btn{font-family:var(--font-display);letter-spacing:-.01em;color:var(--text-1);background:var(--bg-2);border:1.5px solid var(--border-md);border-radius:var(--r-full);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:color var(--duration-quick), background var(--duration-quick), border-color var(--duration-quick);font-variant-numeric:tabular-nums;min-width:52px;min-height:36px;padding:8px 16px;font-size:13px;font-weight:700}.pc-speed-btn:hover{background:var(--bg-3);border-color:var(--border-bright);color:var(--text-0)}.pc-speed-btn--on{color:oklch(10% .025 75);background:var(--ink);border-color:var(--ink)}.pc-speed-btn--on:hover{opacity:.9;background:var(--ink);border-color:var(--ink);color:oklch(10% .025 75)}.pc-queue-btn{font-family:var(--font-display);letter-spacing:-.01em;color:var(--text-1);background:var(--bg-2);border:1.5px solid var(--border-md);border-radius:var(--r-full);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:color var(--duration-quick), background var(--duration-quick), border-color var(--duration-quick);align-items:center;gap:6px;min-height:36px;padding:8px 14px 8px 12px;font-size:13px;font-weight:700;display:inline-flex}.pc-queue-btn:hover{background:var(--bg-3);border-color:var(--border-bright);color:var(--text-0)}.pc-error{color:var(--color-error);text-align:center;margin-top:10px;font-size:13px}.pc-retry-btn{color:var(--ink);cursor:pointer;background:0 0;border:none;padding:0;font-size:13px;text-decoration:underline}.song-detail{flex-direction:column;min-height:100dvh;padding-bottom:40px;display:flex;overflow-y:auto}.sd-nav-bar{padding:calc(env(safe-area-inset-top) + 14px) 16px 8px;flex-shrink:0;justify-content:space-between;align-items:center;display:flex;position:relative}.spv-url-badge{font-family:var(--font-body,"Epilogue", sans-serif);letter-spacing:.01em;color:var(--text-1);background:var(--bg-3);border:1px solid var(--border-md);white-space:nowrap;pointer-events:none;-webkit-user-select:none;user-select:none;text-overflow:ellipsis;border-radius:20px;max-width:calc(100% - 120px);padding:4px 11px;font-size:11.5px;font-weight:600;position:absolute;left:50%;overflow:hidden;transform:translate(-50%)}.spv-nav-right{align-items:center;gap:4px;display:flex}.sd-nav-btn{border-radius:var(--r-full);cursor:pointer;-webkit-tap-highlight-color:transparent;width:40px;height:40px;transition:background var(--duration-quick), opacity var(--duration-quick), transform var(--duration-quick) var(--ease-out);border:none;justify-content:center;align-items:center;display:flex}.sd-nav-btn:active{transform:scale(.91)}.sd-back{color:var(--text-0);background:0 0}.sd-back:hover{background:var(--bg-2)}.sd-share-btn{background:var(--bg-2);border:1px solid var(--border-md);color:var(--text-0)}.sd-share-btn:hover{background:var(--bg-3);border-color:var(--border-bright)}.sd-report-btn{color:var(--text-3);opacity:.55;background:0 0;width:34px;height:34px}.sd-report-btn:hover{background:var(--bg-2);opacity:1;color:var(--text-2)}.sd-delete-btn{color:var(--color-error);background:oklch(71% .16 25/.1);border:1px solid oklch(71% .16 25/.2)}.sd-delete-btn:hover{background:oklch(71% .16 25/.18)}.sd-btn-disabled{opacity:.35;cursor:not-allowed;pointer-events:none}.sd-cover-section{text-align:center;flex-direction:column;flex-shrink:0;align-items:center;padding:20px 20px 16px;display:flex}.spv-cover-wrap{isolation:isolate;flex-shrink:0;width:220px;height:220px;margin-bottom:20px;position:relative}.spv-cover-glow{object-fit:cover;filter:blur(44px)saturate(1.4);opacity:.55;z-index:0;pointer-events:none;border-radius:50%;width:132%;height:132%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.spv-cover-wrap--no-cover:before{content:"";filter:blur(36px);z-index:0;pointer-events:none;background:radial-gradient(circle,oklch(80% .17 80/.3) 0%,oklch(80% .17 80/.12) 40%,#0000 70%);border-radius:50%;width:132%;height:132%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.spv-cover-disc{z-index:1;border-radius:var(--r-lg);background:linear-gradient(135deg,oklch(30% .13 75) 0%,oklch(17% .02 75) 100%);justify-content:center;align-items:center;width:220px;height:220px;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px oklch(100% 0 0/.07),0 18px 40px oklch(0% 0 0/.35),0 4px 12px oklch(0% 0 0/.18)}.spv-cover-img{object-fit:cover;border-radius:var(--r-lg);width:100%;height:100%;display:block}.spv-cover-disc-inner{width:48px;height:48px;color:var(--ink);opacity:.6;justify-content:center;align-items:center;display:flex}.sd-genre{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.1em;color:var(--ink);background:var(--ink-dim);border-radius:var(--r-full);border:1px solid var(--border-warm);align-items:center;gap:5px;margin-bottom:8px;padding:4px 10px;font-size:11px;font-weight:700;display:inline-flex}.sd-genre--centered{text-align:center}.sd-title{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.03em;font-size:28px;font-weight:800;line-height:1.1}.sd-title--centered{text-align:center}.sd-queue-caption{color:var(--text-2);margin:6px 0 0;font-size:13px}.sd-queue-caption--centered{text-align:center}.sd-lyrics-section{flex-shrink:0;padding:0 20px}.sd-player{padding:20px 20px 8px}.sd-cta-row{align-items:center;gap:8px;padding:8px 20px 16px;display:flex}.sd-practice-btn{background:var(--ink);color:oklch(10% .025 75);border-radius:var(--r-full);font-family:var(--font-display);letter-spacing:-.01em;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity var(--duration-quick), transform var(--duration-quick) var(--ease-out);border:none;flex:1;justify-content:center;align-items:center;gap:8px;min-height:52px;padding:15px 16px;font-size:15px;font-weight:800;display:flex}.sd-practice-btn:hover{opacity:.9;transform:translateY(-1px)}.sd-practice-btn:active{transform:translateY(0)}.sd-practice-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.sd-pack-btn{background:var(--bg-2);border:1.5px solid var(--border-md);border-radius:var(--r-full);width:52px;height:52px;color:var(--text-1);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background var(--duration-quick), border-color var(--duration-quick), color var(--duration-quick), transform var(--duration-quick) var(--ease-out);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sd-pack-btn:hover{background:var(--bg-3);border-color:var(--border-bright);color:var(--ink)}.sd-pack-btn:active{transform:scale(.93)}.sd-pack-btn--added{background:var(--color-success);border-color:var(--color-success);color:oklch(12% .05 162)}.sd-pack-btn--added:hover{background:var(--color-success);border-color:var(--color-success);color:oklch(12% .05 162);opacity:.9}.spv-skeleton-body{flex-direction:column;align-items:center;gap:16px;padding:24px 20px;display:flex}.sd-delete-overlay{-webkit-backdrop-filter:blur(4px);z-index:200;background:#00000080;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.sd-delete-sheet{background:var(--bg-1);padding:28px 24px calc(env(safe-area-inset-bottom) + 28px);text-align:center;border-radius:20px 20px 0 0;width:100%;max-width:480px}.sds-icon{color:var(--red);background:#f871711a;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;margin:0 auto 12px;display:flex}.sds-title{color:var(--text-0);margin-bottom:8px;font-size:18px;font-weight:700}.sds-body{color:var(--text-1);margin-bottom:24px;font-size:14px;line-height:1.55}.sds-actions{gap:10px;display:flex}.sds-cancel{background:var(--bg-2);color:var(--text-0);cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:12px;flex:1;padding:14px;font-size:15px;font-weight:600;transition:background .15s}.sds-cancel:hover{background:var(--bg-3)}.sds-confirm{background:var(--red);color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:12px;flex:1;padding:14px;font-size:15px;font-weight:700;transition:opacity .15s}.sds-confirm:hover{opacity:.88}.sds-confirm:disabled,.sds-cancel:disabled{opacity:.5}.shared-badge-pill{color:var(--text-1);background:var(--bg-2);pointer-events:none;-webkit-user-select:none;user-select:none;border:none;border-radius:99px;align-items:center;gap:5px;padding:5px 10px;font-size:12px;font-weight:500;display:flex}.shared-saved-row{color:var(--green);align-items:center;gap:8px;width:100%;font-size:14px;font-weight:500;display:flex}.save-go-btn{color:var(--ink);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;margin-left:auto;font-size:13px;font-weight:600;transition:opacity .15s}.save-go-btn:hover{opacity:.75}.shared-state-body{text-align:center;flex-direction:column;align-items:center;gap:10px;margin:auto;padding:48px 32px;display:flex}.shared-state-body h2{font-family:var(--font-display);color:var(--text-0);font-size:20px;font-weight:600}.shared-state-body p{color:var(--text-1);max-width:280px;font-size:14px;font-style:italic;line-height:1.65}.shared-report-footer{justify-content:center;margin-top:auto;padding:24px 20px 36px;display:flex}.report-footer-btn{color:var(--text-3);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:99px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:color .2s,background .2s;display:flex}.report-footer-btn:hover{color:var(--red);background:#f8717114}.report-footer-done{color:var(--green);align-items:center;gap:7px;font-size:14px;font-weight:500;display:flex}.referral-landing-cta{flex-direction:column;gap:8px;width:100%;display:flex}.referral-landing-hint{color:var(--text-2);text-align:center;margin:0;font-size:13px}.pl-detail{min-height:100dvh;padding-bottom:calc(var(--nav-h) + var(--mp-h) + env(safe-area-inset-bottom) + 24px);flex-direction:column;display:flex;overflow-y:auto}.pl-detail-nav{padding:calc(env(safe-area-inset-top) + 14px) 12px 4px;flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.pl-detail-back{width:40px;height:40px;color:var(--text-0);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background var(--duration-quick), transform var(--duration-quick) var(--ease-out);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.pl-detail-back:hover{background:var(--bg-2)}.pl-detail-back:active{transform:scale(.92)}.pl-detail-hero{text-align:center;flex-direction:column;flex-shrink:0;align-items:center;padding:16px 20px 12px;display:flex}.pl-hero-cover{border-radius:var(--r-lg);width:180px;height:180px;color:var(--ink);background:linear-gradient(135deg,oklch(30% .13 75) 0%,oklch(17% .02 75) 100%);flex-shrink:0;justify-content:center;align-items:center;margin-bottom:20px;display:flex;overflow:hidden;box-shadow:0 18px 40px oklch(0% 0 0/.35),inset 0 0 0 1px oklch(100% 0 0/.08)}.pl-hero-cover-img{object-fit:cover;width:100%;height:100%;display:block}.pl-hero-kicker{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.12em;color:var(--ink);align-items:center;gap:8px;margin-bottom:6px;font-size:11px;font-weight:700;display:inline-flex}.pl-hero-kicker:before{content:"";background:currentColor;flex-shrink:0;width:14px;height:1.5px;display:block}.pl-hero-name{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.03em;max-width:320px;margin:0 0 8px;font-size:32px;font-weight:800;line-height:1.02}.pl-hero-meta{color:var(--text-2);letter-spacing:.01em;margin:0;font-size:13px}.pl-hero-rename{flex-direction:column;align-items:stretch;gap:10px;width:100%;max-width:320px;margin:0 auto;display:flex}.pl-hero-name-input{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.03em;text-align:center;background:var(--bg-2);border:1.5px solid var(--border-bright);border-radius:var(--r-md);transition:border-color var(--duration-quick), box-shadow var(--duration-quick);outline:none;padding:10px 14px;font-size:28px;font-weight:800;line-height:1.05}.pl-hero-name-input:focus{border-color:var(--ink);box-shadow:0 0 0 3px var(--ink-dim)}.pl-hero-rename-actions{justify-content:center;gap:8px;display:flex}.pl-rename-save{background:var(--ink);color:oklch(10% .025 75);font-family:var(--font-display);border-radius:var(--r-full);cursor:pointer;min-height:40px;transition:opacity var(--duration-quick);border:none;padding:10px 20px;font-size:13px;font-weight:700}.pl-rename-save:disabled{opacity:.45;cursor:default}.pl-rename-save:not(:disabled):hover{opacity:.9}.pl-rename-cancel{color:var(--text-1);border:1.5px solid var(--border-md);border-radius:var(--r-full);font-family:var(--font-body);cursor:pointer;min-height:40px;transition:background var(--duration-quick);background:0 0;padding:10px 18px;font-size:13px;font-weight:600}.pl-rename-cancel:hover{background:var(--bg-2)}.pl-actions{flex-shrink:0;align-items:center;gap:10px;padding:4px 20px 20px;display:flex}.pl-play-all{background:var(--ink);color:oklch(10% .025 75);border-radius:var(--r-full);height:52px;font-family:var(--font-display);letter-spacing:-.01em;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity var(--duration-quick), transform var(--duration-quick) var(--ease-out);border:none;flex:1;justify-content:center;align-items:center;gap:8px;font-size:15px;font-weight:800;display:flex}.pl-play-all:hover{opacity:.9;transform:translateY(-1px)}.pl-play-all:active{transform:translateY(0)}.pl-play-all:disabled{opacity:.4;cursor:not-allowed;transform:none}.pl-add-btn{background:var(--bg-2);border:1.5px solid var(--border-md);border-radius:var(--r-full);width:52px;height:52px;color:var(--ink);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background var(--duration-quick), border-color var(--duration-quick);flex-shrink:0;justify-content:center;align-items:center;display:flex}.pl-add-btn:hover{background:var(--bg-3);border-color:var(--border-bright)}.pl-song-list{flex-direction:column;gap:6px;padding:0 12px 12px;display:flex}.pl-song-row{background:var(--bg-2);border:1.5px solid var(--border-md);border-radius:var(--r-md);transition:background var(--duration-quick), border-color var(--duration-quick);-webkit-tap-highlight-color:transparent;cursor:pointer;align-items:center;gap:12px;min-height:64px;padding:11px 13px;display:flex}.pl-song-row:hover{background:var(--bg-3);border-color:var(--border-bright)}.pl-song-row--playing{background:color-mix(in oklch, var(--ink-pale), var(--bg-2) 60%);border-color:oklch(82% .17 80/.28)}.pl-song-row--playing .pl-song-title{color:var(--ink)}.pl-song-row--playing:hover{background:color-mix(in oklch, var(--ink-pale), var(--bg-2) 45%);border-color:oklch(82% .17 80/.42)}.pl-song-art{border-radius:var(--r-sm);background:linear-gradient(135deg, oklch(.28 .1 var(--hue,75)) 0%, oklch(.18 .08 var(--hue,75)) 100%);flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex;position:relative;overflow:hidden}.pl-song-art:not(:has(img)):after{content:"♪";color:oklch(.7 .08 var(--hue,75));opacity:.65;pointer-events:none;font-size:18px;line-height:1}.pl-song-art img{object-fit:cover;width:100%;height:100%;display:block;position:absolute;inset:0}.pl-song-info{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.pl-song-title{font-family:var(--font-display);color:var(--text-0);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:700;overflow:hidden}.pl-song-genre{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);white-space:nowrap;text-overflow:ellipsis;font-size:10px;font-weight:700;overflow:hidden}.pl-song-row--playing .pl-song-genre{color:oklch(80% .17 80/.75)}.pl-song-eq{height:16px;color:var(--ink);flex-shrink:0;align-items:flex-end;gap:2px;display:flex}.pl-song-eq span{transform-origin:bottom;background:currentColor;border-radius:2px;width:3px;animation:1s ease-in-out infinite pl-eq;display:block}.pl-song-eq span:first-child{height:10px;animation-delay:-.2s}.pl-song-eq span:nth-child(2){height:14px}.pl-song-eq span:nth-child(3){height:8px;animation-delay:-.4s}@keyframes pl-eq{0%,to{transform:scaleY(.35)}50%{transform:scaleY(1)}}@media (prefers-reduced-motion:reduce){.pl-song-eq span{animation:none;transform:scaleY(.7)}}.pl-song-row .om-trigger{width:32px;height:32px;color:var(--text-2);background:0 0;border:none}.pl-song-row .om-trigger:hover{background:var(--bg-3);color:var(--text-0);border-color:#0000}.pl-empty{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:40px 24px 24px;display:flex}.pl-empty-icon{background:var(--bg-2);border:1.5px solid var(--border-md);width:64px;height:64px;color:var(--text-3);border-radius:50%;justify-content:center;align-items:center;margin-bottom:4px;display:flex}.pl-empty-text{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.02em;margin:0;font-size:18px;font-weight:800}.pl-empty-sub{color:var(--text-2);max-width:260px;margin:0 0 8px;font-size:14px;line-height:1.55}.pl-empty-cta{background:var(--ink);color:oklch(10% .025 75);border-radius:var(--r-full);font-family:var(--font-display);letter-spacing:-.01em;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity var(--duration-quick);border:none;align-items:center;gap:8px;min-height:44px;padding:13px 20px;font-size:14px;font-weight:800;display:inline-flex}.pl-empty-cta:hover{opacity:.9}.pl-skeleton{flex-direction:column;align-items:center;gap:16px;padding:16px 20px 12px;display:flex}.pl-skeleton-list{flex-direction:column;gap:6px;width:100%;padding:8px 12px 0;display:flex}.pl-error{text-align:center;color:var(--color-error);padding:40px 24px;font-size:14px;line-height:1.55}.as-backdrop{-webkit-backdrop-filter:blur(4px);z-index:260;background:oklch(0% 0 0/.5);position:fixed;inset:0}.as-sheet{background:var(--bg-1);z-index:270;border-radius:20px 20px 0 0;flex-direction:column;max-height:85vh;padding-top:8px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -8px 40px oklch(0% 0 0/.5)}@media (width>=768px){.as-sheet{transform:translateX(calc(-50% + (var(--sidebar-w) / 2)));width:var(--frame-w);max-width:calc(100vw - var(--sidebar-w) - 32px);left:50%;right:auto;bottom:calc(var(--player-h) + 16px);border-radius:20px;max-height:70vh}}.as-handle{background:var(--bg-4);border-radius:2px;flex-shrink:0;width:40px;height:4px;margin:0 auto 12px}.as-header{flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:12px;padding:4px 20px 14px;display:flex}.as-title{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text-0);margin:0 0 4px;font-size:18px;font-weight:800}.as-sub{color:var(--text-2);margin:0;font-size:13px}.as-close{background:var(--bg-2);width:32px;height:32px;color:var(--text-1);cursor:pointer;transition:background var(--duration-quick);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.as-close:hover{background:var(--bg-3)}.as-search-wrap{flex-shrink:0;padding:0 20px 14px}.as-search{align-items:center;display:flex;position:relative}.as-search-icon{color:var(--text-3);pointer-events:none;position:absolute;left:14px}.as-search-input{background:var(--bg-2);border:1.5px solid var(--border-md);border-radius:var(--r-full);width:100%;font-family:var(--font-body);color:var(--text-0);transition:border-color var(--duration-quick), box-shadow var(--duration-quick);outline:none;padding:10px 14px 10px 40px;font-size:14px}.as-search-input:focus{border-color:var(--ink);box-shadow:0 0 0 3px var(--ink-dim)}.as-list{flex:1;padding:0 12px 8px;overflow-y:auto}.as-item{border-radius:var(--r-md);cursor:pointer;-webkit-tap-highlight-color:transparent;width:100%;transition:background var(--duration-quick), border-color var(--duration-quick);text-align:left;background:0 0;border:1.5px solid #0000;align-items:center;gap:12px;min-height:60px;padding:10px 13px;display:flex}.as-item:hover:not(:disabled):not(.as-item--existing){background:var(--bg-2)}.as-item--selected{background:var(--ink-pale);border-color:oklch(82% .17 80/.28)}.as-item--selected:hover{background:oklch(80% .17 80/.11)}.as-item--existing{opacity:.5;cursor:default}.as-item-art{border-radius:var(--r-sm);background:var(--bg-3);flex-shrink:0;width:40px;height:40px;position:relative;overflow:hidden}.as-item-art img{object-fit:cover;width:100%;height:100%;display:block}.as-item-info{flex:1;min-width:0}.as-item-title{font-family:var(--font-display);color:var(--text-0);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:700;overflow:hidden}.as-item-genre{color:var(--text-2);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:11px;overflow:hidden}.as-item-check{border:1.5px solid var(--border-md);color:#0000;width:22px;height:22px;transition:background var(--duration-quick), border-color var(--duration-quick), color var(--duration-quick);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.as-item--selected .as-item-check{background:var(--ink);border-color:var(--ink);color:oklch(10% .025 75)}.as-item--existing .as-item-check{background:var(--bg-3);border-color:var(--border);color:var(--text-3)}.as-empty{text-align:center;color:var(--text-2);padding:40px 20px;font-size:14px}.as-footer{padding:10px 16px calc(env(safe-area-inset-bottom) + 14px);border-top:1px solid var(--border);background:var(--bg-1);flex-shrink:0}.as-add-btn{background:var(--ink);color:oklch(10% .025 75);width:100%;height:52px;font-family:var(--font-display);letter-spacing:-.01em;border-radius:var(--r-full);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity var(--duration-quick);border:none;font-size:15px;font-weight:800}.as-add-btn:disabled{opacity:.45;cursor:default}.as-add-btn:not(:disabled):hover{opacity:.9}.settings-screen{background:var(--bg-0);z-index:150;flex-direction:column;display:flex;position:fixed;inset:0;overflow:hidden}.settings-pane{flex-direction:column;flex:1;display:flex;overflow:hidden}.settings-header{padding:calc(env(safe-area-inset-top) + 14px) 20px 12px;border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:12px;display:flex}.settings-back{color:var(--ink);-webkit-tap-highlight-color:transparent;align-items:center;gap:5px;min-height:44px;font-size:13px;font-weight:500;display:flex}.settings-title{font-family:var(--font-display);color:var(--text-0);text-align:center;flex:1;margin-right:60px;font-size:16px;font-weight:700}.settings-body{padding:14px 0 calc(var(--mp-h) + env(safe-area-inset-bottom) + 40px);flex-direction:column;flex:1;gap:6px;display:flex;overflow-y:auto}.settings-section{flex-direction:column;gap:0;margin:0 0 4px;display:flex}.settings-section-label{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.12em;color:var(--ink);align-items:center;gap:8px;padding:8px 20px 6px;font-size:11px;font-weight:700;display:inline-flex}.settings-section-label:before{content:"";background:currentColor;flex-shrink:0;width:14px;height:1.5px;display:block}.settings-rows{background:var(--bg-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.settings-row{text-align:left;border-bottom:1px solid var(--border);width:100%;transition:background var(--duration-quick);-webkit-tap-highlight-color:transparent;justify-content:space-between;align-items:center;min-height:48px;padding:13px 20px;display:flex}.settings-row:last-child{border-bottom:none}.settings-row:not(.no-press):active{background:var(--bg-3)}.sr-label{color:var(--text-0);font-size:14px;font-weight:400}.sr-right{align-items:center;gap:8px;display:flex}.sr-value{color:var(--text-2);text-overflow:ellipsis;white-space:nowrap;max-width:180px;font-size:13px;overflow:hidden}.sr-sub{color:var(--text-2);margin-top:2px;font-size:13px}.sr-badge{color:var(--ink);background:var(--ink-dim);border-radius:var(--r-full);border:1px solid var(--border-bright);padding:2px 8px;font-size:12px;font-weight:700}.sr-logout,.sr-danger{color:var(--color-error)}.logout-row,.danger-row{justify-content:flex-start}.settings-version{color:var(--text-3);text-align:center;padding:16px 0 0;font-size:13px}.settings-hint{color:var(--text-2);padding:8px 20px;font-size:14px;line-height:1.55}.settings-error{color:var(--color-error);background:var(--color-error-bg);border-radius:var(--r-sm);border:1px solid oklch(71% .16 25/.22);margin:0 20px;padding:8px 12px;font-size:13px}.billing-card-wrap{flex-direction:column;display:flex}.billing-card{background:var(--bg-1);border-radius:var(--r-lg);border:1.5px solid var(--border-md);margin:0 16px;overflow:hidden;box-shadow:0 2px 16px oklch(0% 0 0/.25)}.billing-plan-row{justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;display:flex}.billing-plan-info{align-items:center;gap:10px;display:flex}.billing-plan-badge{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;border-radius:var(--r-full);color:var(--text-2);border:1px solid var(--border-md);background:0 0;padding:3px 9px;font-size:10px;font-weight:700}.billing-plan-badge[data-pro=true]{background:var(--ink-dim);color:var(--ink);border:1px solid var(--border-bright)}.billing-plan-label{color:var(--text-1);font-size:13px}.billing-upgrade-btn{color:oklch(10% .025 75);background:var(--ink);border-radius:var(--r-full);transition:opacity var(--duration-quick), transform var(--duration-quick) var(--ease-out);flex-shrink:0;min-height:44px;padding:8px 18px;font-size:13px;font-weight:700}.billing-upgrade-btn:active{opacity:.85;transform:scale(.96)}.billing-divider{background:var(--border-warm);height:1px;margin:0 16px}.billing-credits-row{justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;display:flex}.billing-credits-info{align-items:baseline;gap:5px;display:flex}.billing-credits-number{font-family:var(--font-display);color:var(--ink);font-size:18px;font-weight:800;line-height:1}.billing-credits-label{color:var(--text-2);font-size:13px}.billing-credits-actions{flex-shrink:0;gap:8px;display:flex}.billing-buy-btn,.billing-promo-btn{border-radius:var(--r-full);transition:background var(--duration-quick), opacity var(--duration-quick), transform var(--duration-quick) var(--ease-out);-webkit-tap-highlight-color:transparent;align-items:center;gap:5px;min-height:44px;padding:8px 14px;font-size:13px;font-weight:600;display:flex}.billing-buy-btn svg,.billing-promo-btn svg{flex-shrink:0;width:13px;height:13px}.billing-buy-btn:active,.billing-promo-btn:active{transform:scale(.95)}.billing-buy-btn{background:var(--bg-3);color:var(--text-0);border:1px solid var(--border-md)}.billing-buy-btn:hover{background:var(--bg-4)}.billing-card:not(:has(.billing-upgrade-btn)) .billing-buy-btn{background:var(--ink);color:oklch(10% .025 75);border-color:#0000}.billing-card:not(:has(.billing-upgrade-btn)) .billing-buy-btn:hover{opacity:.9}.billing-promo-btn{color:var(--text-2);border:1px solid var(--border);background:0 0}.billing-promo-btn:hover{background:var(--bg-3);color:var(--text-1)}.account-info-block{background:var(--bg-0);border-radius:var(--r-md);border:1px solid var(--border);margin:0 16px;overflow:hidden}.settings-rows:has(.account-info-block){background:0 0;border-top:none;border-bottom:none}.account-info-row{justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.account-info-divider{background:var(--border);height:1px;margin:0 16px}.account-info-label{color:var(--text-3);font-size:13px;font-weight:500}.account-info-value{color:var(--text-1);text-overflow:ellipsis;white-space:nowrap;max-width:220px;font-size:13px;overflow:hidden}.account-plan-badge{letter-spacing:.05em;text-transform:uppercase;border-radius:var(--r-full);background:var(--bg-3);color:var(--text-2);padding:3px 9px;font-size:11px;font-weight:700}.account-plan-badge[data-pro=true]{background:var(--ink-dim);color:var(--ink);border:1px solid var(--border-bright)}.legal-row{align-items:center;text-decoration:none;display:flex}.legal-info{flex-direction:column;flex:1;gap:2px;display:flex}.delete-body{gap:0!important;padding:24px 20px 40px!important}.delete-pane{text-align:center;flex-direction:column;align-items:center;gap:12px;display:flex}.delete-icon{color:var(--ink);background:var(--ink-dim);border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.delete-title{font-family:var(--font-display);color:var(--text-0);font-size:20px;font-weight:700}.delete-body-text{color:var(--text-1);max-width:300px;font-size:14px;line-height:1.65}.delete-body-text strong{color:var(--text-0)}.delete-email{color:var(--text-2);font-size:13px}.delete-email strong{color:var(--text-0);font-weight:500}.delete-actions{flex-direction:column;gap:8px;width:100%;max-width:320px;margin-top:8px;display:flex}.delete-form{flex-direction:column;gap:10px;width:100%;max-width:320px;display:flex}.delete-proceed-btn{background:var(--color-error);width:100%;color:var(--text-0);border-radius:var(--r-md);font-family:var(--font-display);transition:opacity var(--duration-quick);padding:13px;font-size:14px;font-weight:700}.delete-proceed-btn:disabled{opacity:.5}.delete-cancel-btn{background:var(--bg-3);width:100%;color:var(--text-1);border-radius:var(--r-md);padding:12px;font-size:14px;font-weight:400}.contact-intro{color:var(--text-1);padding:0 20px 8px;font-size:14px;line-height:1.65}.contact-form{flex-direction:column;gap:14px;padding:0 20px;display:flex}.contact-category-row{flex-wrap:wrap;gap:7px;display:flex}.category-chip{border-radius:var(--r-full);background:var(--bg-3);color:var(--text-1);border:1px solid var(--border);transition:background var(--duration-quick), color var(--duration-quick), border-color var(--duration-quick);-webkit-tap-highlight-color:transparent;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:400;display:inline-flex}.category-chip.active{background:var(--ink-dim);color:var(--ink);border-color:var(--border-bright)}.contact-field{flex-direction:column;gap:6px;display:flex}.contact-label{text-transform:uppercase;letter-spacing:.7px;color:var(--text-2);font-size:12px;font-weight:700}.contact-input,.contact-textarea{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);width:100%;color:var(--text-0);transition:border-color var(--duration-quick), box-shadow var(--duration-quick);outline:none;padding:11px 13px;font-size:14px}.contact-input:focus,.contact-textarea:focus{border-color:var(--border-bright);box-shadow:0 0 0 3px var(--ink-dim)}.contact-input::placeholder,.contact-textarea::placeholder{color:var(--text-3)}.contact-textarea{resize:none;line-height:1.65}.contact-submit{background:var(--ink);color:oklch(10% .025 75);border-radius:var(--r-md);font-family:var(--font-display);transition:opacity var(--duration-quick);padding:13px;font-size:14px;font-weight:700}.contact-submit:disabled{opacity:.45}.contact-submit:not(:disabled):hover{opacity:.9}.contact-sent{text-align:center;flex-direction:column;align-items:center;gap:10px;padding:60px 24px;display:flex}.contact-sent h3{font-family:var(--font-display);color:var(--text-0);font-size:20px;font-weight:700}.contact-sent p{color:var(--text-1);font-size:14px}.promo-intro{color:var(--text-1);padding:0 20px 4px;font-size:14px;line-height:1.65}.promo-form{flex-direction:column;gap:10px;padding:0 20px;display:flex}.promo-input-row{align-items:stretch;gap:8px;display:flex}.promo-input{background:var(--bg-2);border:1px solid var(--border-md);border-radius:var(--r-md);font-size:15px;font-family:var(--font-display);letter-spacing:2px;color:var(--ink);transition:border-color var(--duration-quick), box-shadow var(--duration-quick);text-transform:uppercase;outline:none;flex:1;padding:11px 14px;font-weight:700}.promo-input:focus{border-color:var(--border-bright);box-shadow:0 0 0 3px var(--ink-dim)}.promo-input::placeholder{color:var(--text-3);letter-spacing:1px;font-weight:400}.promo-input:disabled{opacity:.55}.promo-submit{background:var(--ink);color:oklch(10% .025 75);border-radius:var(--r-md);font-family:var(--font-display);transition:opacity var(--duration-quick);white-space:nowrap;flex-shrink:0;padding:11px 20px;font-size:14px;font-weight:700}.promo-submit:disabled{opacity:.4}.promo-submit:not(:disabled):active{opacity:.8}.promo-error{color:var(--color-error);background:var(--color-error-bg);border-radius:var(--r-sm);border:1px solid oklch(71% .16 25/.22);padding:8px 12px;font-size:13px}.promo-hint{color:var(--text-3);padding:2px 20px;font-size:12px}.promo-success{text-align:center;flex-direction:column;align-items:center;gap:10px;padding:60px 24px 40px;display:flex}.promo-success-icon{background:var(--ink-dim);width:80px;height:80px;color:var(--ink);border:1px solid var(--border-bright);border-radius:50%;justify-content:center;align-items:center;display:flex}.promo-success-title{font-family:var(--font-display);color:var(--ink);font-size:24px;font-weight:800}.promo-success-sub{color:var(--text-1);font-size:15px;line-height:1.6}.promo-success-sub strong{color:var(--text-0)}.promo-go-home{background:var(--ink);color:oklch(10% .025 75);border-radius:var(--r-md);font-family:var(--font-display);transition:opacity var(--duration-quick);margin-top:8px;padding:12px 32px;font-size:14px;font-weight:700}.promo-go-home:active{opacity:.75}.phone-form{flex-direction:column;gap:10px;padding:16px 0 0;display:flex}.phone-label{color:var(--text-2);font-size:13px;font-weight:500}.phone-hint{color:var(--text-3);margin-top:-4px;font-size:12px;line-height:1.5}.phone-sent-note{color:var(--text-1);padding:16px 0 4px;font-size:14px;line-height:1.55}.phone-sent-note strong{color:var(--text-0);font-weight:500}.phone-submit-btn{background:var(--ink);color:oklch(10% .025 75);border-radius:var(--r-md);width:100%;font-size:14px;font-weight:700;font-family:var(--font-display);transition:opacity var(--duration-quick);margin-top:2px;padding:13px}.phone-submit-btn:hover:not(:disabled){opacity:.9}.phone-submit-btn:disabled{opacity:.4;cursor:not-allowed}.phone-cancel-btn{color:var(--text-2);text-align:center;transition:color var(--duration-quick);padding:4px;font-size:13px}.phone-cancel-btn:hover{color:var(--text-1)}.phone-actions{gap:10px;padding:12px 16px;display:flex}.phone-change-btn{background:var(--bg-3);border-radius:var(--r-md);color:var(--text-1);transition:background var(--duration-quick);flex:1;padding:10px;font-size:13px;font-weight:500}.phone-change-btn:hover{background:var(--bg-4)}.phone-remove-btn{background:var(--color-error-bg);border-radius:var(--r-md);color:var(--color-error);transition:background var(--duration-quick), opacity var(--duration-quick);border:1px solid oklch(71% .16 25/.18);flex:1;padding:10px;font-size:13px;font-weight:500}.phone-remove-btn:hover:not(:disabled){background:oklch(71% .16 25/.15)}.phone-remove-btn:disabled{opacity:.4;cursor:not-allowed}.phone-done{text-align:center;flex-direction:column;align-items:center;gap:10px;padding:32px 16px 16px;display:flex}.phone-done-icon{background:var(--ink-dim);width:52px;height:52px;color:var(--ink);border:1px solid var(--border-bright);border-radius:50%;justify-content:center;align-items:center;margin-bottom:4px;display:flex}.phone-done-title{font-family:var(--font-display);color:var(--text-0);font-size:18px;font-weight:700}.phone-done-sub{color:var(--text-2);max-width:280px;font-size:13px;line-height:1.6}.sms-phone-row{gap:8px;display:flex}.sms-dial-select{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r-md);width:110px;color:var(--text-0);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%236b7280' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;outline:none;flex-shrink:0;padding:12px 28px 12px 10px;font-size:14px}.sms-dial-select:focus{box-shadow:0 0 0 2px var(--ink-dim);border-color:var(--border-bright)}.sms-local-input{flex:1;min-width:0}.ob-shell{background:var(--bg-0);z-index:300;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);overscroll-behavior:none;-webkit-user-select:none;user-select:none;flex-direction:column;display:flex;position:fixed;inset:0}.ob-header{flex-shrink:0;align-items:center;gap:8px;height:52px;padding:0 16px 0 12px;display:flex}.ob-back-top{width:44px;height:44px;color:var(--text-2);background:var(--bg-2);-webkit-tap-highlight-color:transparent;transition:color var(--duration-quick), background var(--duration-quick);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.ob-back-top:active{color:var(--text-0);background:var(--bg-3)}.ob-dots{flex:1;justify-content:center;align-items:center;gap:5px;display:flex}.ob-dot{background:var(--bg-4);height:6px;transition:width var(--duration-normal) var(--ease-out), background var(--duration-normal);border-radius:99px;min-width:6px}.ob-viewport{flex:1;position:relative;overflow:hidden}.ob-slide{-webkit-overflow-scrolling:touch;overscroll-behavior:contain;position:absolute;inset:0;overflow:hidden auto}.slide{flex-direction:column;min-height:100%;display:flex}.slide-body{flex-direction:column;flex:1;gap:16px;padding:20px 22px 28px;display:flex}.ob-title{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.03em;font-size:30px;font-weight:800;line-height:1.1}.ob-body-text{color:var(--text-1);font-size:14px;line-height:1.65}.ob-footer{border-top:1px solid var(--border);background:var(--bg-0);flex-direction:column;flex-shrink:0;align-items:center;gap:4px;padding:14px 20px 12px;display:flex}.ob-cta{background:var(--ink);color:oklch(10% .025 75);border-radius:var(--r-md);width:100%;height:54px;font-family:var(--font-display);letter-spacing:-.2px;-webkit-tap-highlight-color:transparent;transition:opacity var(--duration-quick), filter var(--duration-quick);justify-content:center;align-items:center;gap:8px;font-size:15px;font-weight:800;display:flex}.ob-cta:active{filter:brightness(.88)}.ob-cta--dim{cursor:default}.ob-cta-spinner{border:2.5px solid oklch(10% .025 75/.3);border-top-color:oklch(10% .025 75);border-radius:50%;width:18px;height:18px;animation:.7s linear infinite ob-spin}.ob-fine{color:var(--text-3);letter-spacing:.1px;padding:4px 0 2px;font-size:12px}.slide-hook{position:relative;overflow:hidden}.vp-body{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:24px;padding:36px 26px 28px;display:flex}.vp-brand{font-family:var(--font-display);letter-spacing:.14em;text-transform:uppercase;color:var(--ink);align-items:center;gap:8px;font-size:11px;font-weight:700;display:inline-flex}.vp-brand:before{content:"";background:currentColor;flex-shrink:0;width:16px;height:1.5px;display:block}.vp-logo-wrap{justify-content:center;align-items:center;width:100%;height:90px;display:flex}.vp-logo{object-fit:contain;-webkit-user-select:none;user-select:none;pointer-events:none;filter:drop-shadow(0 6px 18px oklch(0% 0 0/.25));width:clamp(72px,11vw,110px);height:auto;display:block}.vp-bar{background:var(--ink);border-radius:99px;width:3px;animation:1.6s ease-in-out infinite ob-wave}.vp-headline{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.045em;font-size:42px;font-weight:900;line-height:.97}.vp-sub{color:var(--text-2);font-size:16px;line-height:1.55}.vp-sub em{color:var(--text-3);font-style:italic}.vp-login-link{color:var(--text-3);-webkit-tap-highlight-color:transparent;min-height:44px;transition:color var(--duration-quick);text-underline-offset:3px;text-decoration:underline;-webkit-text-decoration-color:var(--bg-4);text-decoration-color:var(--bg-4);align-items:center;padding:4px 0;font-size:13px;font-weight:500;display:inline-flex}.vp-login-link:hover,.vp-login-link:active{color:var(--text-1);-webkit-text-decoration-color:var(--text-2);text-decoration-color:var(--text-2)}.pressure-list{flex-direction:column;gap:9px;margin-top:2px;display:flex}.pressure-row{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);text-align:left;-webkit-tap-highlight-color:transparent;transition:border-color var(--duration-quick), background var(--duration-quick);align-items:center;gap:13px;min-height:60px;padding:15px;display:flex}.pressure-row--on{border-color:var(--ink);background:var(--ink)}.pressure-row--on .pressure-label{color:oklch(10% .025 75)}.pressure-row--on .pressure-sub{color:oklch(10% .025 75/.65)}.pressure-content{flex-direction:column;flex:1;gap:3px;display:flex}.pressure-label{color:var(--text-0);font-size:15px;font-weight:600;line-height:1.2}.pressure-sub{color:var(--text-2);margin-top:2px;font-size:13px;line-height:1.3}.pressure-radio{display:none}.ob-goal-input{background:var(--bg-2);border:1px solid var(--border-md);border-radius:var(--r-md);width:100%;font-family:var(--font-body);color:var(--text-0);resize:none;transition:border-color var(--duration-quick), box-shadow var(--duration-quick);-webkit-appearance:none;outline:none;padding:14px 16px;font-size:16px;font-weight:500;line-height:1.5}.ob-goal-input:focus{border-color:var(--border-bright);box-shadow:0 0 0 3px var(--ink-dim)}.ob-goal-input::placeholder{color:var(--text-3);font-weight:400}.ob-suggestions{flex-direction:column;gap:10px;display:flex}.ob-suggestions-label{letter-spacing:.5px;text-transform:uppercase;color:var(--text-3);font-size:12px;font-weight:700}.ob-chip-row{flex-wrap:wrap;gap:8px;display:flex}.ob-chip{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-full);color:var(--text-1);-webkit-tap-highlight-color:transparent;transition:border-color var(--duration-quick), background var(--duration-quick), color var(--duration-quick);text-align:left;align-items:center;min-height:44px;padding:8px 13px;font-size:13px;font-weight:500;line-height:1.3;display:inline-flex}.ob-chip:active{background:var(--bg-3)}.ob-chip--on{border-color:var(--ink);background:var(--ink);color:oklch(10% .025 75)}.ob-goal-echo{color:var(--text-1);background:var(--ink-pale);border-radius:var(--r-md);border:1px solid var(--border-warm);padding:12px 16px;font-size:14px;line-height:1.5}.ob-when-chips{flex-wrap:wrap;gap:9px;margin-top:2px;display:flex}.ob-when-chip{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-1);-webkit-tap-highlight-color:transparent;transition:border-color var(--duration-quick), background var(--duration-quick), color var(--duration-quick);align-items:center;gap:6px;min-height:44px;padding:11px 16px;font-size:14px;font-weight:600;display:flex}.ob-when-chip:active{background:var(--bg-3)}.ob-when-chip--on{border-color:var(--ink);background:var(--ink);color:oklch(10% .025 75)}.ob-when-chip--picker{color:var(--text-2);font-size:13px;font-weight:500}.examdate-input{background:var(--bg-2);border:1px solid var(--border-bright);border-radius:var(--r-md);width:100%;font-family:var(--font-body);color:var(--text-0);transition:border-color var(--duration-quick), box-shadow var(--duration-quick);appearance:none;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;outline:none;padding:14px 16px;font-size:15px;font-weight:500}.examdate-input:focus{border-color:var(--border-bright);box-shadow:0 0 0 3px var(--ink-dim)}.ob-date-hint{border-radius:var(--r-md);padding:10px 14px;font-size:13px;font-weight:500;line-height:1.5}.ob-date-hint--good{color:oklch(76% .15 162);background:oklch(76% .15 162/.08);border:1px solid oklch(76% .15 162/.18)}.ob-date-hint--warn{color:oklch(78% .16 55);background:oklch(78% .16 55/.08);border:1px solid oklch(78% .16 55/.18)}.ob-date-hint--info{background:var(--ink-pale);color:var(--ink-soft);border:1px solid var(--border-warm)}.slide-plan .slide-body{gap:18px}.plan-spark{background:var(--ink-pale);border:1px solid var(--border-warm);width:72px;height:72px;color:var(--ink);border-radius:20px;justify-content:center;align-items:center;display:flex}.plan-card{background:var(--bg-2);border-radius:var(--r-lg);border:1px solid var(--border);overflow:hidden}.plan-row{align-items:flex-start;gap:13px;padding:14px 15px;display:flex}.plan-row-icon{width:28px;height:28px;color:var(--ink);flex-shrink:0;justify-content:center;align-items:center;padding-top:2px;display:flex}.plan-row-label{letter-spacing:.8px;text-transform:uppercase;color:var(--text-3);margin-bottom:3px;font-size:11px;font-weight:700}.plan-row-value{color:var(--text-0);font-size:14px;font-weight:500;line-height:1.45}.plan-divider{background:var(--border);height:1px}.plan-note{color:var(--ink);text-align:center;padding:2px 0;font-size:13px;font-weight:500}.slide-age-gate{justify-content:center}.age-gate-body{text-align:center;justify-content:center;align-items:center;gap:12px;padding:32px 28px 40px}.age-gate-icon{background:var(--ink-dim);border:1px solid var(--border-bright);width:64px;height:64px;color:var(--ink);border-radius:18px;justify-content:center;align-items:center;margin-bottom:4px;display:flex}.age-gate-sub{color:var(--text-1);max-width:280px;font-size:17px;font-weight:400;line-height:1.5}.age-gate-buttons{flex-direction:column;gap:10px;width:100%;max-width:320px;margin-top:8px;display:flex}.age-gate-btn{border-radius:var(--r-md);letter-spacing:.1px;width:100%;transition:opacity var(--duration-quick), transform var(--duration-quick) var(--ease-out);-webkit-tap-highlight-color:transparent;padding:15px 20px;font-size:16px;font-weight:700}.age-gate-btn:active{opacity:.8;transform:scale(.98)}.age-gate-btn--yes{background:var(--ink);color:oklch(10% .025 75)}.age-gate-btn--no{background:var(--bg-2);border:1px solid var(--border);color:var(--text-1)}.age-gate-fine{color:var(--text-3);max-width:280px;margin-top:4px;font-size:12px;line-height:1.5}.ob-footer--hidden{visibility:hidden;pointer-events:none}.age-blocked-overlay{background:var(--bg-0);z-index:400;padding:32px 24px;padding-top:env(safe-area-inset-top,0px);padding-bottom:env(safe-area-inset-bottom,0px);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.age-blocked-card{text-align:center;flex-direction:column;align-items:center;gap:16px;max-width:320px;display:flex}.age-blocked-icon{background:var(--bg-2);border:1px solid var(--border);width:64px;height:64px;color:var(--text-2);border-radius:18px;justify-content:center;align-items:center;display:flex}.age-blocked-title{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.3px;font-size:22px;font-weight:700;line-height:1.2}.age-blocked-body{color:var(--text-2);font-size:15px;line-height:1.6}.logout-button{border-radius:var(--r-sm);border:1px solid var(--border);color:var(--text-2);cursor:pointer;transition:background var(--duration-quick);background:0 0;min-height:44px;margin-top:24px;padding:10px 16px}.logout-button:hover{background:var(--bg-2)}.bottom-nav{z-index:100;padding-bottom:env(safe-area-inset-bottom);-webkit-backdrop-filter:blur(16px);border-top:1.5px solid var(--border-md);background:oklch(10% .025 75/.96);position:fixed;bottom:0;left:0;right:0}.bottom-nav-inner{justify-content:space-around;align-items:center;gap:8px;max-width:480px;margin:0 auto;padding:8px 12px 10px;display:flex}.nav-item{color:var(--text-2);transition:color var(--duration-quick);-webkit-tap-highlight-color:transparent;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:5px;min-height:56px;padding:6px 0;display:flex}.nav-item.active{color:var(--ink)}.nav-icon-wrap{justify-content:center;align-items:center;width:48px;height:32px;display:flex;position:relative}.nav-pill{background:var(--ink-dim);border-radius:var(--r-full);border:1px solid var(--border-bright);position:absolute;inset:0}.nav-icon{z-index:1;justify-content:center;align-items:center;line-height:0;display:flex;position:relative}.nav-label{font-family:var(--font-display);letter-spacing:.1em;text-transform:uppercase;font-size:10px;font-weight:700}.nav-item:nth-child(2){color:oklch(10% .025 75)}.nav-item:nth-child(2) .nav-icon-wrap{background:var(--ink);border-radius:var(--r-full);border:none;width:64px;height:36px}.nav-item:nth-child(2) .nav-label{color:var(--ink);font-weight:800}.nav-item:nth-child(2).active{color:oklch(10% .025 75)}.nav-item:nth-child(2).active .nav-icon-wrap{filter:brightness(1.05)}.nav-item:nth-child(2) .nav-pill,.side-nav{display:none}@media (width>=768px){.side-nav{width:var(--sidebar-w);background:var(--bg-1);border-right:1px solid var(--border);z-index:50;flex-direction:column;height:100dvh;padding:24px 16px 16px;display:flex;position:relative;overflow:hidden}}.side-nav-brand{border-bottom:1px solid var(--border);align-items:center;gap:10px;margin-bottom:8px;padding:0 8px 20px;display:flex}.side-nav-wordmark{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text-0);font-size:1.25rem;font-weight:800;line-height:1}.side-nav-tabs{flex-direction:column;gap:2px;margin-top:8px;display:flex}.side-nav-item{border-radius:var(--r-md);color:var(--text-2);font-family:var(--font-body);cursor:pointer;text-align:left;transition:color var(--duration-quick), background var(--duration-quick), border-color var(--duration-quick);-webkit-tap-highlight-color:transparent;background:0 0;border:1px solid #0000;align-items:center;gap:14px;min-height:44px;padding:10px 14px;font-size:.95rem;font-weight:600;display:flex}.side-nav-item:hover{color:var(--text-0);background:var(--bg-3)}.side-nav-item:focus-visible{outline:2px solid var(--ink);outline-offset:2px}.side-nav-item svg{flex-shrink:0}.side-nav-item--active{color:var(--ink);background:var(--ink-dim);border-color:var(--border-bright)}.side-nav-item--active:hover{color:var(--ink);background:var(--ink-dim)}.side-nav-item--create{color:var(--ink);background:var(--bg-2);border-color:var(--border-bright);margin-top:4px}.side-nav-item--create:hover{color:var(--ink);background:var(--ink-pale);border-color:var(--border-bright)}.side-nav-item--create.side-nav-item--active{color:oklch(10% .025 75);background:var(--ink);border-color:var(--ink)}.side-nav-item--create.side-nav-item--active:hover{color:oklch(10% .025 75);background:var(--ink);opacity:.95}.side-nav-label{letter-spacing:-.005em}.side-nav-divider{background:var(--border);flex-shrink:0;height:1px;margin:16px 4px 12px}.side-nav-playlists-header{flex-shrink:0;justify-content:space-between;align-items:baseline;gap:8px;padding:0 10px 8px;display:flex}.side-nav-section-label{font-family:var(--font-display);letter-spacing:.1em;text-transform:uppercase;color:var(--text-2);font-size:11px;font-weight:700}.side-nav-count{color:var(--text-3);letter-spacing:.02em;font-size:11px;font-weight:600}.side-nav-playlists{flex-direction:column;flex:1;gap:2px;min-height:0;margin-right:-2px;padding:0 4px 0 2px;display:flex;overflow:hidden auto}.side-nav-playlists::-webkit-scrollbar{width:3px}.side-nav-playlists::-webkit-scrollbar-thumb{background:var(--bg-4);border-radius:99px}.side-nav-empty{color:var(--text-3);letter-spacing:-.005em;padding:4px 10px;font-size:12px;line-height:1.5}.side-nav-pl{border-radius:var(--r-sm);color:var(--text-2);cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent;width:100%;min-width:0;transition:color var(--duration-quick), background var(--duration-quick);background:0 0;border:none;align-items:center;gap:10px;padding:7px 8px;display:flex}.side-nav-pl:hover{color:var(--text-0);background:var(--bg-3)}.side-nav-pl:focus-visible{outline:2px solid var(--ink);outline-offset:1px}.side-nav-pl--active{color:var(--text-0);background:var(--bg-3)}.side-nav-pl--active .side-nav-pl-cover{border-color:var(--border-bright);color:var(--ink)}.side-nav-pl-cover{border-radius:var(--r-sm);background:var(--bg-0);border:1px solid var(--border);width:36px;height:36px;color:var(--text-3);flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.side-nav-pl-cover img{object-fit:cover;width:100%;height:100%}.side-nav-pl-text{flex-direction:column;flex:1;gap:1px;min-width:0;line-height:1.25;display:flex}.side-nav-pl-name{font-family:var(--font-display);letter-spacing:-.01em;color:inherit;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:700;overflow:hidden}.side-nav-pl-count{color:var(--text-3);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;text-overflow:ellipsis;font-size:11px;font-weight:600;overflow:hidden}.side-nav-pl-skeleton{flex-direction:column;gap:4px;padding:2px;display:flex}.side-nav-pl-skel-row{align-items:center;gap:10px;padding:7px 8px;display:flex}.side-nav-pl-skel-cover{border-radius:var(--r-sm);flex-shrink:0;width:36px;height:36px}.side-nav-pl-skel-name{border-radius:3px;flex:1;max-width:120px;height:10px}.side-nav-footer{border-top:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;margin-top:12px;padding:12px 8px 4px;display:flex}.side-nav-settings{border-radius:var(--r-sm);border:1px solid var(--border);background:var(--bg-2);width:40px;height:40px;color:var(--text-2);cursor:pointer;transition:color var(--duration-quick), background var(--duration-quick), border-color var(--duration-quick);justify-content:center;align-items:center;display:inline-flex}.side-nav-settings:hover{color:var(--text-0);background:var(--bg-3);border-color:var(--border-md)}.side-nav-settings:focus-visible{outline:2px solid var(--ink);outline-offset:2px}.mini-player{bottom:calc(var(--nav-h) + env(safe-area-inset-bottom) + 8px);box-sizing:border-box;z-index:200;background:var(--bg-1);border:1.5px solid var(--border-md);border-radius:var(--r-xl);flex-direction:column-reverse;width:auto;display:flex;position:fixed;left:10px;right:10px;overflow:hidden;box-shadow:0 4px 6px oklch(0% 0 0/.12),0 12px 40px oklch(0% 0 0/.5)}@media (width>=768px){.mini-player{bottom:0;left:var(--sidebar-w);width:auto;height:var(--player-h);border:none;border-top:1px solid var(--border-md);background:var(--bg-1);border-radius:0;margin:0;right:0;box-shadow:0 -8px 24px oklch(0% 0 0/.25)}.mini-player--no-nav{bottom:0}.mini-player{flex-direction:column}.mp-progress{height:2px}.mp-body{flex:1;gap:16px;padding:12px 20px}.mp-art{width:48px;height:48px}.mp-info{flex:0 320px;gap:14px}.mp-controls{flex:1;justify-content:center;gap:6px}.mp-toggle{display:inline-flex}}.mp-progress{background:var(--bg-4);flex-shrink:0;height:3px}.mp-progress-fill{background:var(--ink);height:100%;transition:width .5s linear}.mp-body{flex-shrink:0;align-items:center;gap:6px;padding:12px 10px 12px 14px;display:flex}.mp-info{cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex:1;align-items:center;gap:11px;min-width:0;padding:0;display:flex}.mp-art{border-radius:var(--r-sm);background:linear-gradient(135deg, oklch(.28 .1 var(--hue,75)) 0%, oklch(.18 .08 var(--hue,75)) 100%);flex-shrink:0;width:38px;height:38px;position:relative;overflow:hidden}.mp-art:not(:has(img)):after{content:"♪";color:oklch(.7 .08 var(--hue,75));opacity:.65;justify-content:center;align-items:center;font-size:16px;display:flex;position:absolute;inset:0}.mp-art-img{object-fit:cover;width:100%;height:100%;display:block}.mp-art--playing{outline:2px solid var(--ink);outline-offset:1px}.mp-text{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.mp-title{font-family:var(--font-display);color:var(--text-0);white-space:nowrap;text-overflow:ellipsis;letter-spacing:-.01em;font-size:14px;font-weight:700;line-height:1.3;overflow:hidden}.mp-sub{color:var(--text-2);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:500;line-height:1.2;overflow:hidden}.mp-controls{flex-shrink:0;align-items:center;gap:0;display:flex}.mp-icon-btn{border-radius:var(--r-sm);width:44px;height:44px;color:var(--text-2);cursor:pointer;transition:background var(--duration-quick), color var(--duration-quick);-webkit-tap-highlight-color:transparent;background:0 0;border:none;justify-content:center;align-items:center;display:flex}.mp-icon-btn:hover{background:var(--bg-3);color:var(--text-0)}.mp-icon-btn:disabled{opacity:.2;cursor:default}.mp-icon-btn--close{width:34px;height:34px;color:var(--text-3);opacity:.65;border-radius:50%;flex-shrink:0;margin-left:4px}.mp-icon-btn--close:hover{background:var(--bg-3);color:var(--text-2);opacity:1}.mp-toggle{position:relative}.mp-toggle--on{color:var(--ink)}.mp-toggle--on:after{content:"";background:var(--ink);border-radius:50%;width:3px;height:3px;position:absolute;bottom:1px;left:50%;transform:translate(-50%)}.mp-controls{gap:4px}@media (width<=360px){.mp-info{gap:9px}.mp-toggle{display:none}}.mini-player--no-nav{bottom:calc(env(safe-area-inset-bottom) + 8px)}.app-shell{flex-direction:column;min-height:100dvh;display:flex;position:relative}.app-shell--has-player{--mp-h:62px}.app-shell--has-deletion-banner{--deletion-banner-h:44px}.page-wrapper,.page-transition-inner{flex-direction:column;flex:1;min-height:100dvh;display:flex}.top-nav{display:none!important}@media (width>=768px){body{background:var(--bg-0);overflow:hidden}.app-shell{flex-direction:row;align-items:stretch;min-height:100dvh;max-height:100dvh;display:flex;overflow:hidden}.side-nav{flex-shrink:0}.page-wrapper{width:auto;min-width:0;max-width:none;padding-top:var(--deletion-banner-h);background:var(--bg-0);flex:auto;height:100dvh;min-height:0;position:relative;overflow:hidden auto}.app-shell--has-player .page-wrapper{padding-bottom:var(--player-h)}.page-transition-inner{min-height:0}.bottom-nav{display:none}.onboarding-screen{overflow-y:auto;width:100%!important;height:100%!important;position:absolute!important;inset:0!important}.generate-screen,.settings-screen,.song-detail-screen,.practice-screen,.shared-song-screen,.terms-screen,.auth-screen{max-width:var(--reading-max);width:100%;margin-inline:auto}.library-screen,.playlist-detail-screen{max-width:var(--content-max);width:100%;margin-inline:auto}}@media (width<=767px){.page-wrapper{padding-top:var(--deletion-banner-h);min-height:100dvh}.page-transition-inner{min-height:calc(100dvh - var(--deletion-banner-h))}}.splash{background:var(--bg-0);z-index:1000;justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow:hidden}.splash-content{flex-direction:column;align-items:center;gap:20px;display:flex;position:relative}.splash-bg{background:var(--ink);transform-origin:50%;pointer-events:none;z-index:0;border-radius:50%;width:96px;height:96px;position:absolute;top:0;left:50%;translate:-50%}.splash-mascot{z-index:1;position:relative}.splash-name{z-index:1;font-family:var(--font-display);letter-spacing:-.5px;color:var(--text-0);font-size:28px;font-weight:800;position:relative}.deletion-banner{z-index:300;width:100%;position:fixed;top:0;left:0;right:0;overflow:hidden}.deletion-banner-inner{padding:calc(env(safe-area-inset-top) + 8px) 16px 8px;background:var(--color-error-bg);box-sizing:border-box;border-bottom:1px solid oklch(71% .16 25/.2);justify-content:space-between;align-items:center;gap:12px;width:100%;display:flex}@media (width>=768px){.deletion-banner-inner{padding-left:calc(var(--sidebar-w) + 20px);padding-right:20px}}.deletion-banner-text{color:var(--color-error);flex:1;align-items:center;gap:8px;font-size:13px;line-height:1.4;display:flex}.deletion-banner-icon{flex-shrink:0;font-size:13px}.deletion-banner-text strong{font-weight:600}.deletion-banner-cancel{color:var(--color-error);border-radius:var(--r-full);white-space:nowrap;transition:background var(--duration-quick);background:oklch(71% .16 25/.12);border:none;flex-shrink:0;padding:5px 14px;font-size:13px;font-weight:600}.deletion-banner-cancel:hover{background:oklch(71% .16 25/.22)}.deletion-banner-cancel:disabled{opacity:.5}.pending-draft-banner{z-index:120;flex-shrink:0;position:relative}.pending-draft-inner{padding:calc(env(safe-area-inset-top) + 10px) 16px 10px;background:var(--ink-pale);border-bottom:1px solid var(--border-warm);justify-content:space-between;align-items:center;gap:12px;display:flex}.pending-draft-text{color:var(--ink-soft);flex:1;align-items:center;gap:8px;font-size:14px;font-weight:500;display:flex}.pending-draft-dot{background:var(--ink);border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:1.8s ease-in-out infinite pulse-dot}.pending-draft-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.pending-draft-cancel{color:var(--text-2);border-radius:var(--r-full);background:var(--bg-3);transition:color var(--duration-quick), background var(--duration-quick);border:none;padding:5px 12px;font-size:13px}.pending-draft-cancel:hover{color:var(--text-0);background:var(--bg-4)}.pending-draft-dismiss{color:oklch(10% .025 75);background:var(--ink);border-radius:var(--r-full);transition:opacity var(--duration-quick);padding:5px 14px;font-size:13px;font-weight:700}.pending-draft-dismiss:hover{opacity:.85}.offline-banner{width:100%;max-width:var(--frame-w);z-index:999;padding:calc(env(safe-area-inset-top) + 10px) 16px 10px;background:var(--bg-3);color:var(--text-1);justify-content:center;align-items:center;gap:8px;font-size:13px;font-weight:500;display:flex;position:fixed;top:0;left:50%;transform:translate(-50%)}@media (width>=768px){.offline-banner{left:var(--sidebar-w);max-width:none;width:calc(100% - var(--sidebar-w));transform:none}}.low-credits-toast{bottom:calc(var(--nav-h) + 12px);z-index:190;background:var(--bg-2);border:1px solid var(--border-warm);border-radius:var(--r-lg);align-items:center;gap:12px;padding:14px 14px 14px 16px;display:flex;position:fixed;left:16px;right:16px;box-shadow:0 4px 24px oklch(0% 0 0/.45)}@media (width>=768px){.low-credits-toast{left:calc(var(--sidebar-w) + 20px);max-width:440px;right:auto;bottom:calc(var(--player-h) + 16px)}}.low-credits-toast-icon{background:var(--ink-dim);width:36px;height:36px;color:var(--ink);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.low-credits-toast-icon svg{width:16px;height:16px}.low-credits-toast-body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.low-credits-toast-title{color:var(--text-0);font-size:14px;font-weight:700}.low-credits-toast-sub{color:var(--text-2);font-size:12px}.low-credits-toast-btn{color:oklch(10% .025 75);background:var(--ink);border-radius:var(--r-full);transition:opacity var(--duration-quick), transform var(--duration-quick) var(--ease-out);flex-shrink:0;padding:7px 14px;font-size:13px;font-weight:700}.low-credits-toast-btn:active{opacity:.85;transform:scale(.95)}.low-credits-toast-close{width:28px;height:28px;color:var(--text-3);transition:color var(--duration-quick), background var(--duration-quick);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.low-credits-toast-close svg{width:13px;height:13px}.low-credits-toast-close:hover{color:var(--text-1);background:var(--bg-3)}.credits-modal-overlay{z-index:200;-webkit-backdrop-filter:blur(8px);padding-bottom:env(safe-area-inset-bottom);background:oklch(8% .015 75/.72);align-items:flex-end;display:flex;position:fixed;inset:0}@media (width>=768px){.credits-modal-overlay{justify-content:center;align-items:center;padding:40px}}.credits-modal{background:var(--bg-1);border-radius:var(--r-2xl) var(--r-2xl) 0 0;text-align:center;flex-direction:column;align-items:center;gap:14px;width:100%;padding:32px 24px 40px;display:flex;box-shadow:0 -12px 60px oklch(0% 0 0/.5)}@media (width>=768px){.credits-modal{border-radius:var(--r-2xl);max-width:440px;padding:40px 32px}}.credits-modal-icon{background:var(--ink-dim);border:1px solid var(--border-bright);width:64px;height:64px;color:var(--ink);border-radius:50%;justify-content:center;align-items:center;margin-bottom:4px;display:flex}.credits-modal-icon svg{width:28px;height:28px}.credits-modal-title{font-family:var(--font-display);color:var(--text-0);font-size:26px;font-weight:800;line-height:1.1}.credits-modal-body{color:var(--text-2);max-width:300px;font-size:15px;line-height:1.55}.credits-modal-perks{text-align:left;flex-direction:column;gap:9px;width:100%;max-width:280px;margin:4px 0;list-style:none;display:flex}.credits-modal-perks li{color:var(--text-1);align-items:center;gap:10px;font-size:14px;display:flex}.credits-modal-perks li svg{width:15px;height:15px;color:var(--color-success);flex-shrink:0}.credits-modal-cta{background:var(--ink);color:oklch(10% .025 75);border-radius:var(--r-lg);width:100%;max-width:320px;font-family:var(--font-display);transition:opacity var(--duration-quick), transform var(--duration-quick) var(--ease-out);justify-content:center;align-items:center;gap:8px;padding:15px;font-size:16px;font-weight:700;display:flex}.credits-modal-cta:active{opacity:.88;transform:scale(.97)}.credits-modal-dismiss{color:var(--text-3);transition:color var(--duration-quick);padding:8px;font-size:14px}.credits-modal-dismiss:hover{color:var(--text-2)}
