@import "https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,600;0,9..144,900;1,9..144,400;1,9..144,600&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap";:root{--bg-0:#111315;--bg-1:#181b1f;--bg-2:#1f2428;--bg-3:#272c32;--bg-4:#2e343c;--border:transparent;--border-md:transparent;--border-warm:transparent;--ink:#facc15;--ink-dim:#facc151f;--ink-glow:#facc1547;--ink-soft:#facc15a6;--ink-pale:#facc150f;--amber:var(--ink);--amber-dim:var(--ink-dim);--amber-glow:var(--ink-glow);--amber-soft:var(--ink-soft);--teal:#9ca3af;--teal-dim:#9ca3af1f;--sage:#9ca3af;--sage-dim:#9ca3af1f;--text-0:#f9fafb;--text-1:#d1d5db;--text-2:#9ca3af;--text-3:#6b7280;--green:#34d399;--red:#f87171;--r-sm:8px;--r-md:14px;--r-lg:18px;--r-xl:24px;--nav-h:72px;--mp-h:0px;--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-in-out:cubic-bezier(.65, 0, .35, 1);--font-display:"Fraunces", Georgia, serif;--font-body:"DM Sans", system-ui, sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;overscroll-behavior:none;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.5;position:relative;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:9999;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='grain'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.68' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23grain)'/%3E%3C/svg%3E");background-size:220px;position:fixed;inset:0}#root{flex-direction:column;min-height:100dvh;display:flex}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,textarea{font-family:inherit}img{display:block}::-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:1.5px solid var(--ink);outline-offset:3px;border-radius:4px}@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 pulse-warm{0%,to{box-shadow:0 0 0 0 var(--ink-glow)}50%{box-shadow:0 0 0 7px #0000}}@keyframes pulse-glow{0%,to{box-shadow:0 0 0 0 var(--ink-glow)}50%{box-shadow:0 0 0 7px #0000}}@keyframes waveform{0%,to{transform:scaleY(.55)}50%{transform:scaleY(1)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}.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-spring) 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}.skeleton{background:var(--bg-3);border-radius:var(--r-sm);background-size:200% 100%;animation:1.8s infinite shimmer}.card{background:var(--bg-2);border-radius:var(--r-lg);transition:background .2s, transform .15s var(--ease-out);border:none}.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,.sc-compact-genre,.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)}::placeholder{opacity:1;color:var(--text-3)!important}[class*=eyebrow],[class*=label]:not(label),[class*=-label]{-webkit-font-smoothing:antialiased}.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}@media (width>=768px){:root{--nav-h:0px}}.auth-screen{justify-content:center;align-items:center;min-height:100dvh;padding:24px 20px;display:flex;position:relative;overflow:hidden}.auth-bg{pointer-events:none;position:absolute;inset:0}.auth-orb{filter:blur(100px);opacity:.12;border-radius:50%;position:absolute}.auth-orb-1{background:var(--ink-dim);width:360px;height:360px;top:-120px;right:-80px}.auth-orb-2{background:var(--sage-dim);width:260px;height:260px;bottom:-80px;left:-60px}.auth-content{flex-direction:column;gap:28px;width:100%;max-width:380px;display:flex;position:relative}.auth-logo{align-items:center;gap:14px;display:flex}.auth-brand{font-family:var(--font-display);letter-spacing:-.3px;color:var(--text-0);font-size:28px;font-weight:900;line-height:1}.auth-tagline{color:var(--text-2);margin-top:4px;font-size:13px;font-style:italic}.auth-card{background:var(--bg-2);border-radius:var(--r-xl);border:none;flex-direction:column;gap:14px;padding:26px 22px;display:flex}.auth-card-title{font-family:var(--font-display);color:var(--text-0);font-size:20px;font-weight:600}.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-radius:var(--r-md);width:100%;color:var(--text-0);border:none;outline:none;padding:12px 16px;font-size:15px;transition:border-color .2s,box-shadow .2s}.auth-input:focus{border-color:var(--ink);box-shadow:none}.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:#fff;border-radius:var(--r-md);width:100%;font-size:14px;font-weight:600;font-family:var(--font-display);justify-content:center;align-items:center;gap:8px;padding:13px;transition:background .2s,transform .12s,opacity .2s;display:flex}.auth-btn:hover:not(:disabled){background:var(--ink-soft)}.auth-btn:active:not(:disabled){transform:scale(.97)}.auth-btn:disabled{opacity:.4;cursor:not-allowed}.auth-error{color:var(--red);border-radius:var(--r-sm);background:#facc151a;border:1px solid #facc152e;padding:8px 12px;font-size:13px}.auth-resend{color:var(--text-2);text-align:center;padding:4px;font-size:13px;transition:color .2s}.auth-resend:hover:not(:disabled){color:var(--text-1)}.auth-back{color:var(--text-2);align-items:center;gap:6px;width:fit-content;margin-bottom:4px;font-size:13px;transition:color .2s;display:flex}.auth-back:hover{color:var(--text-1)}.auth-share-notice{background:var(--sage-dim);border-radius:var(--r-md);color:var(--sage);border:1px solid #9ca3af2e;align-items:center;gap:8px;padding:10px 14px;font-size:13px;display:flex}.auth-share-notice svg{flex-shrink:0}.auth-signup-icon{background:var(--ink-dim);border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;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-verified-icon{background:var(--ink-dim);border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;margin:0 auto 4px;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-orb-1{opacity:.09}.auth-orb-2{opacity:.07;width:280px;height:280px}.auth-share-notice{color:var(--sage);background:#9ca3af14;border-color:#9ca3af26}.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)}.paywall-overlay{z-index:900;-webkit-backdrop-filter:blur(6px);background:#0f0c0a73;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.paywall-sheet{background:var(--bg-1);width:100%;max-width:480px;padding:10px 20px calc(env(safe-area-inset-bottom,0px) + 20px);border-radius:24px 24px 0 0;flex-direction:column;gap:18px;max-height:90dvh;display:flex;overflow-y:auto}.paywall-handle{background:var(--bg-4);border-radius:2px;width:36px;height:4px;margin:0 auto 4px}.paywall-header{text-align:center;flex-direction:column;align-items:center;gap:8px;display:flex}.paywall-icon{background:var(--ink-dim);border-radius:16px;place-items:center;width:52px;height:52px;margin-bottom:4px;display:grid}.paywall-title{font-family:var(--font-display);color:var(--text-0);margin:0;font-size:22px;font-weight:600}.paywall-subtitle{color:var(--text-1);max-width:320px;margin:0;font-size:14px;line-height:1.5}.paywall-subtitle strong{color:var(--ink);font-weight:600}.paywall-costs{background:var(--bg-2);border-radius:var(--r-md);flex-direction:column;gap:8px;padding:12px 16px;display:flex}.paywall-cost-row{justify-content:space-between;align-items:center;display:flex}.pcr-label{color:var(--text-1);font-size:13px}.pcr-value{color:var(--text-0);font-variant-numeric:tabular-nums;font-size:13px;font-weight:600}.paywall-products{grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:10px;display:grid}.paywall-product{border-radius:var(--r-md);border:1.5px solid var(--border-md);background:var(--bg-2);cursor:pointer;flex-direction:column;align-items:center;gap:2px;padding:18px 10px 14px;transition:border-color .18s,background .18s,box-shadow .18s;display:flex;position:relative}.paywall-product.selected{border-color:var(--ink);background:var(--ink-pale);box-shadow:none}.pp-badge{text-transform:uppercase;letter-spacing:.04em;color:#fff;background:var(--ink);white-space:nowrap;border-radius:6px;padding:2px 8px;font-size:13px;font-weight:700;position:absolute;top:-9px;left:50%;transform:translate(-50%)}.pp-credits{font-family:var(--font-display);color:var(--text-0);font-size:26px;font-weight:700;line-height:1.1}.pp-label{color:var(--text-1);text-transform:uppercase;letter-spacing:.05em;font-size:13px}.paywall-buy-btn{border-radius:var(--r-md);background:var(--ink);color:#fff;width:100%;height:52px;font-family:var(--font-body);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;font-size:16px;font-weight:600;transition:opacity .15s;display:flex}.paywall-buy-btn:disabled{opacity:.5;cursor:not-allowed}.paywall-spinner{border:2.5px solid #1f24284d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.7s linear infinite paywall-spin}@keyframes paywall-spin{to{transform:rotate(360deg)}}.paywall-dismiss{color:var(--text-2);cursor:pointer;text-align:center;background:0 0;border:none;padding:4px 0;font-size:14px;transition:color .15s}.paywall-dismiss:hover{color:var(--text-1)}.paywall-legal{color:var(--text-2);text-align:center;margin:0;font-size:13px;line-height:1.4}.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{background:var(--bg-2);border-radius:var(--r-md);scrollbar-width:none;border:none;gap:0;max-height:280px;padding:14px 16px;overflow-y:auto}.lv-timestamped::-webkit-scrollbar{display:none}.lv-section{text-transform:uppercase;letter-spacing:1px;color:var(--ink);margin-top:10px;margin-bottom:2px;font-size:13px;font-style:normal;font-weight:700;line-height:2.2}.lv-line{color:var(--text-1);font-size:14px;line-height:2;font-family:var(--font-display);padding:1px 0;font-style:italic;transition:color .25s,opacity .25s,font-size .2s;position:relative}.lv-line.lv-anchor{color:var(--text-0);font-weight:500}.lv-timestamped .lv-line.lv-anchor{padding-left:16px}.lv-timestamped .lv-line{color:var(--text-2);opacity:.55}.lv-timestamped .lv-line.lv-past{color:var(--text-3);opacity:.35}.lv-timestamped .lv-line.lv-active{color:var(--text-0);opacity:1;font-size:15px}.lv-timestamped .lv-section{opacity:.4;transition:opacity .3s}.lv-timestamped .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-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}.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:600}.gen-sub{color:var(--text-2);margin-top:3px;font-size:13px;font-style:italic}.step-dots{align-items:center;gap:6px;padding:12px 20px 4px;display:flex}.step-dot{background:var(--bg-4);width:6px;height:6px;transition:background .3s, width .3s var(--ease-spring);border-radius:99px}.step-dot.active{background:var(--ink);width:20px}.step-dot.done{background:var(--ink);opacity:.35}.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:13px;font-weight:600}.notes-textarea{background:var(--bg-2);border-radius:var(--r-md);width:100%;color:var(--text-0);resize:none;border:none;outline:none;padding:13px 15px;font-size:14px;line-height:1.65;transition:border-color .2s,box-shadow .2s}.notes-textarea:focus{border-color:var(--ink);box-shadow:none}.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;font-style:italic}.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{color:var(--ink);font-weight:600}.notes-textarea.textarea-warn{box-shadow:none;border-color:#e8a03080}.genre-grid{flex-wrap:wrap;gap:7px;display:flex}.genre-chip{background:var(--bg-3);color:var(--text-1);-webkit-tap-highlight-color:transparent;border:none;border-radius:99px;padding:6px 14px;font-size:13px;font-weight:400;transition:background .15s,color .15s,border-color .15s}.genre-chip.active{background:var(--ink-dim);color:var(--ink);border-color:#facc1538}.gen-primary-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:14px;font-weight:600;transition:opacity .2s,background .2s;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:600}.review-summary{color:var(--text-2);margin-top:4px;font-size:13px;font-style:italic;line-height:1.55}.review-edit-btn{color:var(--ink);background:var(--ink-dim);border-radius:99px;flex-shrink:0;padding:5px 12px;font-size:14px;font-weight:600}.review-concepts{flex-direction:column;gap:8px;display:flex}.review-concepts-label{color:var(--text-2);text-transform:uppercase;letter-spacing:.7px;font-size:13px;font-weight:600}.concept-tags{flex-wrap:wrap;gap:5px;display:flex}.concept-tag{border:1px solid #0000;border-radius:99px;padding:4px 10px;font-size:14px;font-weight:500}.concept-tag.importance-high{background:var(--ink-dim);color:var(--ink);border-color:#facc152e}.concept-tag.importance-medium{background:var(--sage-dim);color:var(--sage);border-color:#5da0b526}.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:13px;font-weight:600}.lyrics-view{background:var(--bg-2);border-radius:var(--r-md);border:none;max-height:260px;padding:15px;overflow-y:auto}.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:13px;font-style:normal;font-weight:600}.lyrics-edit-textarea{background:var(--bg-2);background:var(--bg-3);border-radius:var(--r-md);width:100%;color:var(--text-0);resize:none;box-shadow:none;font-size:14px;line-height:1.85;font-family:var(--font-display);border:none;outline:none;padding:13px 15px;font-style:italic}.review-actions{gap:8px;display:flex}.review-back-btn{color:var(--text-2);border-radius:var(--r-md);background:var(--bg-3);white-space:nowrap;padding:13px 15px;font-size:14px;font-weight:400}.loading-step{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:22px;padding:60px 24px;display:flex}.loading-visual{justify-content:center;align-items:center;display:flex}.loading-bars{align-items:center;gap:4px;display:flex}.lb{width:3px;height:calc(var(--h) * 60px);background:var(--ink);border-radius:99px;animation:1.2s ease-in-out infinite waveform}.loading-title{font-family:var(--font-display);color:var(--text-0);font-size:20px;font-weight:600}.loading-phase{color:var(--text-2);height:20px;font-size:13px;font-style:italic}.done-step{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:14px;padding:60px 24px;display:flex}.done-icon{background:var(--ink-dim);border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;margin-bottom:8px;display:flex}.done-body{color:var(--text-1);max-width:280px;font-size:14px;line-height:1.65}.done-actions{flex-direction:column;gap:8px;width:100%;max-width:300px;margin-top:8px;display:flex}.done-new-btn{color:var(--text-2);text-align:center;padding:12px;font-size:14px}.gen-error{color:var(--red);border-radius:var(--r-sm);background:#facc1514;border:1px solid #facc152e;padding:10px 14px;font-size:13px}.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);-webkit-tap-highlight-color:transparent;justify-content:center;align-items:center;gap:8px;padding:12px;font-size:13px;font-weight:500;transition:border-color .2s,background .2s,color .2s;display:flex}.done-pack-btn:hover{color:var(--ink);background:var(--ink-dim);border-style:solid}.done-pack-added{color:var(--green);background:#9ca3af14;border-style:solid;border-color:#4a7c5959}.done-pack-added:hover{color:var(--green);background:#9ca3af1f}.revise-toggle-btn{color:var(--text-2);border-radius:var(--r-md);background:var(--bg-3);border:1px dashed var(--border-md);-webkit-tap-highlight-color:transparent;justify-content:center;align-items:center;gap:7px;width:100%;padding:9px 14px;font-size:13px;font-weight:500;transition:color .15s,border-color .15s,background .15s;display:flex}.revise-toggle-btn:hover{color:var(--ink);background:var(--ink-dim);border-style:solid}.revise-panel{background:var(--bg-2);border-radius:var(--r-md);border:none;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:.6px;font-size:14px;font-weight:600}.revise-close-btn{color:var(--text-3);border-radius:4px;padding:2px 6px;font-size:14px;line-height:1}.revise-close-btn:hover{color:var(--text-1);background:var(--bg-4)}.revise-textarea{background:var(--bg-0);border-radius:var(--r-sm);width:100%;color:var(--text-0);resize:none;border:none;outline:none;padding:11px 13px;font-size:13px;line-height:1.6;transition:border-color .2s,box-shadow .2s}.revise-textarea:focus{border-color:var(--ink);box-shadow:none}.revise-textarea::placeholder{color:var(--text-3)}.revise-hint{color:var(--text-3);font-size:13px;font-style:italic}.revise-submit-btn{border-radius:var(--r-md);background:var(--bg-4);width:100%;color:var(--text-3);-webkit-tap-highlight-color:transparent;justify-content:center;align-items:center;gap:7px;padding:11px;font-size:13px;font-weight:600;transition:background .2s,color .2s;display:flex}.revise-submit-btn.active{background:var(--ink);color:#fff}.revise-submit-btn:disabled{cursor:not-allowed}.btn-cost-badge{color:#1f2428b3;letter-spacing:.02em;background:#1f242821;border-radius:8px;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);background:var(--bg-3);border:1px solid var(--border);-webkit-tap-highlight-color:transparent;white-space:nowrap;border-radius:99px;align-items:center;gap:5px;padding:5px 10px;font-size:12px;font-weight:500;transition:color .15s,background .15s,border-color .15s;display:flex}.notes-action-btn:hover:not(:disabled){color:var(--ink);background:var(--ink-dim);border-color:#facc1538}.notes-action-btn:disabled{opacity:.35;cursor:not-allowed}.ocr-thumbnail-row{flex-wrap:wrap;gap:6px;display:flex}.ocr-done-thumb{border:1.5px solid #4a7c5966;border-radius:6px;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:#fff;background:#4a7c59e6;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 .2s;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(--red,#e55);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}.char-count-inline.char-near{color:var(--ink);font-weight:600}.ocr-card{background:var(--bg-2);border-radius:var(--r-md);border:1px solid var(--border);flex-direction:column;gap:10px;padding:12px;display:flex}.ocr-card-top{align-items:flex-start;gap:10px;display:flex}.ocr-card-preview{object-fit:cover;border:1px solid var(--border);border-radius:6px;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;font-style:italic;display:flex}.ocr-card-status.done{color:var(--text-1);font-style:normal;font-weight:500}.ocr-card-status.error{color:var(--red,#e55);font-style:normal}.ocr-card-discard{color:var(--text-3);-webkit-tap-highlight-color:transparent;border-radius:4px;flex-shrink:0;padding:4px;transition:color .15s,background .15s}.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{background:var(--bg-4);border-radius:99px;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;outline:none;padding:10px 12px;font-family:inherit;font-size:13px;line-height:1.65;transition:border-color .2s}.ocr-card-textarea:focus{border-color:var(--ink)}.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;padding:8px 14px;font-size:13px;font-weight:400;transition:color .15s,background .15s}.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);-webkit-tap-highlight-color:transparent;padding:8px 14px;font-size:13px;font-weight:500}.ocr-card-add-btn{color:#fff;border-radius:var(--r-md);background:var(--ink);-webkit-tap-highlight-color:transparent;padding:8px 16px;font-size:13px;font-weight:600;transition:opacity .15s}.ocr-card-add-btn:disabled{opacity:.4;cursor:not-allowed}.ocr-error-msg{color:var(--red,#e55);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:1px solid #facc1538;border-radius:99px;padding:2px 7px;font-size:11px;font-weight:600}.field-required-hint{color:var(--ink);text-align:center;margin-top:-8px;font-size:12px;font-weight:500}.spin{animation:.8s linear infinite spin}@keyframes fieldPulse{0%{box-shadow:0 0 #facc158c}40%{box-shadow:0 0 0 4px #facc1559}to{box-shadow:0 0 #facc1500}}.notes-textarea.textarea-pulse{border-color:#facc1599;animation:1.2s ease-out forwards fieldPulse}.ocr-card{gap:14px;padding:14px}.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:600}.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-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:600}.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(#ffffff08,#ffffff1f);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 #facc1573}@keyframes ocrScan{0%{top:8%}to{top:92%}}.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:-.2px;font-size:22px;font-weight:600;line-height:1.2}.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);cursor:pointer;white-space:nowrap;border:none;flex-shrink:0;align-items:center;gap:4px;padding:0 14px;font-size:14px;font-weight:500;transition:background .15s,color .15s;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(--bg-4);overflow:hidden}.ocr-capture-top{align-items:center;gap:12px;padding:12px 14px;display:flex}.ocr-capture-thumb-wrap{background:var(--bg-3);border-radius:8px;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:#4ade80}.ocr-capture-status.error{color:#f87171}.ocr-capture-dismiss{background:var(--bg-4);width:28px;height:28px;color:var(--text-2);cursor:pointer;border:none;border-radius:99px;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s;display:flex}.ocr-capture-dismiss:hover{background:var(--bg-5,#363d46);color:var(--text-0)}.ocr-capture-actions{border-top:1px solid var(--bg-3);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;font-style:italic}.ocr-capture-btn-secondary{border-radius:var(--r-sm);border:1px solid var(--bg-4);color:var(--text-2);cursor:pointer;background:0 0;padding:7px 14px;font-size:13px;transition:background .15s,color .15s}.ocr-capture-btn-secondary:hover{background:var(--bg-3);color:var(--text-0)}.ocr-capture-btn-primary{border-radius:var(--r-sm);background:var(--ink);color:#0a0a0a;cursor:pointer;border:none;align-items:center;gap:5px;padding:7px 16px;font-size:13px;font-weight:600;transition:opacity .15s;display:flex}.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:600}.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{justify-content:center;align-items:center;gap:6px;display:flex;position:relative}.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:14px;grid-template-columns:1fr 1fr;gap:0;padding:4px;display:grid;position:relative}.notes-tab-btn{z-index:1;color:var(--text-2);-webkit-tap-highlight-color:transparent;border-radius:10px;justify-content:center;align-items:center;gap:6px;padding:9px 12px;font-size:13px;font-weight:600;transition:color .2s;display:inline-flex;position:relative}.notes-tab-btn.active{color:var(--text-0)}.notes-tab-check{background:var(--green,#2f7d4a);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;display:inline-flex}.notes-tab-indicator{background:var(--bg-0);border:1px solid var(--border);pointer-events:none;z-index:0;border-radius:10px;width:calc(50% - 4px);position:absolute;inset:4px;box-shadow:0 1px 4px #0000001f}.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;-webkit-tap-highlight-color:transparent;flex-direction:column;align-items:center;gap:10px;padding:24px 16px;transition:border-color .18s,background .18s;display:flex}.notes-img-card:hover{background:var(--ink-dim);border-color:#facc154d}.notes-img-card-icon{background:var(--bg-3);border:1px solid var(--border);width:48px;height:48px;color:var(--text-1);border-radius:12px;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);grid-template-columns:110px 1fr;align-items:start;gap:12px;padding:12px;display:grid}.notes-capture-preview-wrap{background:var(--bg-3);border:1px solid var(--border);border-radius:10px;flex-shrink:0;width:110px;height:110px;position:relative;overflow:hidden}.notes-capture-img{object-fit:cover;width:100%;height:100%;display:block}.notes-capture-remove{color:#fff;-webkit-tap-highlight-color:transparent;background:#0000008c;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;transition:background .15s;display:flex;position:absolute;top:5px;right:5px}.notes-capture-remove:hover{background:#000c}.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(--green,#2f7d4a);font-weight:500}.notes-capture-status.error{color:var(--red,#e55);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);-webkit-tap-highlight-color:transparent;align-items:center;gap:5px;margin-top:4px;font-size:12px;transition:color .15s;display:inline-flex}.notes-img-replace-btn:hover{color:var(--text-1)}.ocr-capture-btn-secondary,.ocr-capture-btn-primary{border-radius:10px;min-height:36px;padding:0 13px;font-size:13px;font-weight:600}.ocr-capture-btn-secondary{background:var(--bg-3);color:var(--text-1);border:1px solid var(--border);transition:background .15s}.ocr-capture-btn-secondary:hover{background:var(--bg-4)}.ocr-capture-btn-primary{background:var(--ink);color:#fff;justify-content:center;align-items:center;gap:7px;transition:opacity .15s;display:inline-flex}.ocr-capture-btn-primary:hover{opacity:.88}.ocr-capture-wait{color:var(--text-2);font-size:13px}@media (width<=480px){.notes-image-empty{grid-template-columns:1fr 1fr}.notes-capture-card{grid-template-columns:90px 1fr}.notes-capture-preview-wrap{width:90px;height:90px}.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:.05em;margin:0;font-size:13px;font-weight:600}.gender-chips{gap:8px;display:flex}.gender-chip{background:var(--bg-2);border:1.5px solid var(--bg-4);color:var(--text-2);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:7px;padding:11px 10px;font-size:13px;font-weight:500;transition:background .15s,border-color .15s,color .15s;display:flex}.gender-chip:hover{background:var(--bg-3);color:var(--text-0)}.gender-chip.active{background:var(--ink-dim);border-color:var(--ink);color:var(--ink);font-weight:600}.gender-chip-emoji{font-size:15px;line-height:1}.song-card{background:var(--bg-2);border-radius:var(--r-lg);text-align:left;-webkit-tap-highlight-color:transparent;border:none;flex-direction:column;width:100%;transition:border-color .2s;display:flex;overflow:hidden}.sc-art{background:var(--bg-3);align-items:flex-end;height:90px;display:flex;position:relative;overflow:hidden}.sc-art-waveform{opacity:.35;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.sc-art-overlay{background:var(--bg-2);position:absolute;inset:0}.sc-genre-badge{text-transform:uppercase;letter-spacing:.8px;color:var(--text-1);background:var(--bg-1);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:none;border-radius:99px;padding:2px 7px;font-size:13px;font-weight:600;position:absolute;top:9px;right:9px}.sc-info{flex-direction:column;gap:7px;padding:11px 12px 13px;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:500;line-height:1.25;display:-webkit-box;overflow:hidden}.sc-meta{flex-wrap:wrap;gap:5px;display:flex}.sc-meta-pill{color:var(--text-2);background:var(--bg-3);border-radius:99px;padding:2px 7px;font-size:13px;font-weight:400}.sc-strength-bar{background:var(--bg-4);border-radius:99px;height:2px;overflow:hidden}.sc-strength-fill{background:var(--ink);height:100%;transition:width .6s var(--ease-out);border-radius:99px}.song-card-compact{background:var(--bg-2);border-radius:var(--r-md);text-align:left;-webkit-tap-highlight-color:transparent;border:none;align-items:center;gap:11px;width:100%;padding:10px 12px;transition:border-color .2s;display:flex}.sc-compact-art{background:var(--bg-3);width:40px;height:40px;color:var(--text-1);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sc-compact-info{flex-direction:column;flex:1;gap:2px;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:13px;font-weight:500;overflow:hidden}.sc-compact-genre{color:var(--text-2);text-transform:capitalize;font-size:13px;font-style:italic}.sc-compact-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.sc-compact-count{color:var(--text-2);font-size:13px}.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}.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) + 20px) 20px 12px;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:-.15px;margin:0;font-size:24px;font-weight:600}.lib-subtitle{color:var(--text-2);margin:4px 0 0;font-size:13px}.lib-header-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.view-toggle,.lib-settings-btn{width:32px;height:32px;color:var(--text-2);cursor:pointer;background:0 0;border:none;border-radius:7px;justify-content:center;align-items:center;transition:color .2s,background .2s;display:flex}.view-toggle.active{color:var(--ink);background:var(--ink-dim)}.view-toggle:hover,.lib-settings-btn:hover{color:var(--text-0);background:var(--bg-2)}.lib-settings-btn{background:var(--bg-2)}.lib-tabs{border-bottom:1px solid var(--border);gap:4px;margin-bottom:4px;padding:0 16px 4px;display:flex}.lib-tab{color:var(--text-2);border-radius:var(--r-sm) var(--r-sm) 0 0;cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:9px 12px;font-size:13px;font-weight:500;transition:color .2s;display:flex;position:relative}.lib-tab.active{color:var(--text-0)}.lib-tab.active:after{content:"";background:var(--ink);border-radius:2px 2px 0 0;height:1.5px;position:absolute;bottom:-1px;left:0;right:0}.lib-tab-count{background:var(--bg-3);color:var(--text-2);border-radius:99px;padding:1px 6px;font-size:13px}.lib-search-wrap{padding:0 16px 14px}.lib-search{align-items:center;display:flex;position:relative}.lib-search-icon{color:var(--text-3);pointer-events:none;position:absolute;left:13px}.lib-search-input{background:var(--bg-2);border-radius:var(--r-md);width:100%;color:var(--text-0);-webkit-appearance:none;border:none;outline:none;padding:10px 14px 10px 38px;font-size:14px;transition:border-color .2s,box-shadow .2s}.lib-search-input:focus{border-color:var(--ink);box-shadow:none}.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:20px;height:20px;color:var(--text-2);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:13px;display:flex;position:absolute;right:10px}.lib-content{flex:1;padding:0 16px;overflow-y:auto}.lib-skeleton-wrap{padding-bottom:16px}.lib-hero-wrap{padding-bottom:14px}.continue-card{background:radial-gradient(circle at top right, #ffb8001f, transparent 38%), var(--bg-2);border:1px solid #ffffff08;border-radius:18px;align-items:center;gap:14px;padding:16px;display:flex}.continue-card-copy{flex:1;min-width:0}.continue-card-kicker{letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);margin-bottom:8px;font-size:11px;font-weight:700}.continue-card-title{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.02em;margin:0;font-size:22px;line-height:1.15}.continue-card-sub{color:var(--text-2);margin:7px 0 0;font-size:13px}.continue-card-actions{flex-wrap:wrap;gap:10px;margin-top:16px;display:flex}.continue-play-btn,.continue-practice-btn{cursor:pointer;border:none;border-radius:12px;transition:opacity .15s,background .15s,color .15s}.continue-play-btn{background:var(--ink);color:var(--bg-0);align-items:center;gap:7px;padding:11px 16px;font-size:13px;font-weight:700;display:inline-flex}.continue-play-btn:hover{opacity:.88}.continue-practice-btn{background:var(--bg-3);color:var(--text-1);padding:11px 14px;font-size:13px;font-weight:600}.continue-practice-btn:hover{background:var(--bg-4);color:var(--text-0)}.continue-card-art{flex-shrink:0;justify-content:center;align-items:center;width:78px;display:flex}.continue-disc{background:radial-gradient(circle,#ffffff14 0 10%,#0000 10% 100%),repeating-radial-gradient(circle,#ffffff0d 0 1px,#00000014 1px 3px),#1d1d1d;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;display:flex;box-shadow:inset 0 0 0 1px #ffffff0d,0 10px 22px #0000002e}.continue-disc-inner{background:var(--ink);border-radius:50%;width:15px;height:15px;box-shadow:inset 0 0 0 3px #ffffff29}.lib-grid{grid-template-columns:1fr 1fr;gap:10px;padding-bottom:16px;display:grid}.lib-list{flex-direction:column;gap:7px;padding-bottom:16px;display:flex}.lib-empty{flex-direction:column;align-items:center;gap:10px;padding:80px 24px;display:flex}.lib-empty-text{color:var(--text-2);text-align:center;font-size:14px;font-style:italic}.lib-empty-sub{color:var(--text-3);text-align:center;margin-top:-4px;font-size:13px;line-height:1.5}.lib-empty-btn{background:var(--ink);color:var(--bg-0);border-radius:var(--r-md);font-size:14px;font-weight:600;font-family:var(--font-display);-webkit-tap-highlight-color:transparent;cursor:pointer;border:none;margin-top:4px;padding:11px 24px;transition:opacity .15s}.lib-empty-btn:hover{opacity:.88}.playlist-row{background:var(--bg-2);border-radius:var(--r-md);-webkit-tap-highlight-color:transparent;text-align:left;cursor:pointer;border:none;align-items:center;gap:12px;width:100%;padding:13px;transition:border-color .2s;display:flex}.playlist-row--archived{opacity:.6}.pl-icon{background:var(--ink-dim);width:34px;height:34px;color:var(--ink);border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.pl-icon--archived{background:var(--bg-3);color:var(--text-2)}.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:500;overflow:hidden}.pl-count{color:var(--text-2);font-size:13px;font-style:italic}.lib-archived-section{flex-direction:column;gap:6px;margin-top:8px;display:flex}.lib-archived-toggle{color:var(--text-2);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;align-items:center;gap:6px;padding:6px 2px;font-size:14px;font-weight:600;display:flex}.pl-unarchive-btn{color:var(--ink);background:var(--ink-dim);cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:99px;flex-shrink:0;padding:4px 10px;font-size:13px;font-weight:600}.pl-new-btn{border-radius:var(--r-md);background:var(--bg-2);border:1.5px dashed var(--bg-4);width:100%;color:var(--text-2);cursor:pointer;align-items:center;gap:7px;padding:12px 16px;font-size:14px;font-weight:500;transition:background .15s,border-color .15s,color .15s;display:flex}.pl-new-btn:hover{background:var(--bg-3);border-color:var(--ink-dim);color:var(--text-0)}.pl-create-row{align-items:center;gap:8px;margin-top:8px;display:flex}.pl-create-row--inline{margin-top:0;padding:4px 0}.pl-create-input{background:var(--bg-2);border:1.5px solid var(--ink-dim);border-radius:var(--r-md);color:var(--text-0);outline:none;flex:1;padding:10px 13px;font-size:14px;transition:border-color .15s}.pl-create-input:focus{border-color:var(--ink)}.pl-create-input::placeholder{color:var(--text-3)}.pl-create-cancel{border-radius:var(--r-sm);border:1px solid var(--bg-4);color:var(--text-2);cursor:pointer;white-space:nowrap;background:0 0;padding:9px 12px;font-size:13px;transition:background .15s}.pl-create-cancel:hover{background:var(--bg-3)}.pl-create-save{border-radius:var(--r-sm);background:var(--ink);color:var(--bg-0);cursor:pointer;white-space:nowrap;border:none;padding:9px 16px;font-size:13px;font-weight:600;transition:opacity .15s}.pl-create-save:disabled{opacity:.45;cursor:default}.pl-create-save:not(:disabled):hover{opacity:.88}@media (width<=420px){.lib-header{align-items:stretch}.lib-header-actions{gap:5px}.continue-card{gap:12px;padding:14px}.continue-card-title{font-size:20px}.continue-card-art{width:64px}.continue-disc{width:58px;height:58px}.continue-card-actions{flex-direction:column;align-items:stretch}}.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:600}.practice-back{background:var(--surface-1);width:36px;height:36px;color:var(--text-1);cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s;display:flex}.practice-back:hover{background:var(--surface-2);color:var(--red);-webkit-tap-highlight-color:transparent;background:#c47a6a1a;border:1.5px solid #c47a6a4d;border-radius:99px;align-items:center;gap:6px;padding:7px 16px;font-size:13px;font-weight:600;transition:background .2s,border-color .2s;display:flex}.practice-exit:hover{background:#c47a6a2e}.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-radius:var(--r-lg);border:none;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-dim);border-radius:var(--r-md);border:1px solid #facc1529;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:#fff}.start-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:15px;font-weight:600;transition:opacity .2s}.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);border-radius:99px;width:6px;height:6px;transition:background .3s,width .3s}.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 .55s 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:none;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);-webkit-tap-highlight-color:transparent;border:1.5px solid #facc1540;border-radius:99px;flex-shrink:0;align-items:center;gap:4px;padding:8px;transition:background .15s,transform .1s;display:flex}.hint-btn-corner:hover{background:#facc1529}.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:.6px;color:var(--text-2);font-size:13px;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(--green)}.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:99px;align-items:center;gap:5px;width:fit-content;padding:4px 10px;font-size:13px;transition:color .2s;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;font-style:italic;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 #facc1521;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,var(--bg-0));border-radius:var(--r-md);border:none;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:.4px;align-items:center;gap:7px;font-size:13px;font-weight:600;display:flex}.hint-count-badge{background:var(--ink-dim);color:var(--ink);border-radius:99px;padding:1px 7px;font-size:13px;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:6px;padding:6px 10px;font-size:14px;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;font-style:italic}.grade-area{flex-direction:column;gap:9px;display:flex}.grade-prompt{text-transform:uppercase;letter-spacing:.6px;color:var(--text-2);text-align:center;font-size:13px;font-weight:600}.grade-btns{gap:8px;display:flex}.grade-btn{border-radius:var(--r-md);-webkit-tap-highlight-color:transparent;border:1px solid #0000;flex-direction:column;flex:1;align-items:center;gap:6px;padding:14px 4px;transition:background .15s,transform .1s;display:flex}.g-icon{justify-content:center;align-items:center;line-height:1;display:flex}.g-label{text-align:center;font-size:13px;font-weight:600;line-height:1.3}.g-missed{color:var(--red);background:#facc151a;border-color:#facc1533}.g-cue{background:var(--ink-dim);color:var(--ink);border-color:#facc1538}.g-knew{color:var(--green);background:#9ca3af1a;border-color:#9ca3af2e}.g-missed:active{background:#facc152e}.g-cue:active{background:#facc1529}.g-knew:active{background:#9ca3af2e}.done-screen{text-align:center;flex-direction:column;align-items:center;gap:14px;padding:28px 0;display:flex;overflow-y:auto}.done-badge{background:var(--ink-dim);border-radius:50%;justify-content:center;align-items:center;width:58px;height:58px;display:flex}.done-title{font-family:var(--font-display);color:var(--text-0);font-size:26px;font-weight:600}.done-subtitle{color:var(--text-2);margin-top:-8px;font-size:13px;font-style:italic}.score-cards{gap:7px;width:100%;display:flex}.score-card{background:var(--bg-2);border-radius:var(--r-md);border:none;flex-direction:column;flex:1;align-items:center;gap:3px;padding:13px 4px;display:flex}.sc-num{font-family:var(--font-display);font-size:30px;font-weight:600;line-height:1}.sc-label{font-size:13px;font-weight:600}.sc-hint{color:var(--text-3);font-size:13px}.sc-green .sc-num,.sc-green .sc-label{color:var(--green)}.sc-amber .sc-num,.sc-amber .sc-label{color:var(--ink)}.sc-red .sc-num,.sc-red .sc-label{color:var(--red)}.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;padding:13px;font-size:14px;font-weight:600}.done-cta-finish{background:var(--ink);color:var(--bg-0)}.done-cta-secondary{background:var(--bg-3);color:var(--text-1)}.empty-nudge{background:var(--ink-dim);border-radius:var(--r-md);border:1px solid #facc1529;align-items:flex-start;gap:12px;padding:14px 15px;font-size:20px;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:var(--bg-0);border-radius:var(--r-md);font-size:13px;font-weight:600;font-family:var(--font-display);-webkit-tap-highlight-color:transparent;align-self:flex-start;margin-top:4px;padding:9px 18px;transition:opacity .15s}.en-create-btn:hover{opacity:.88}.practice-error{color:var(--red);border-radius:var(--r-sm);background:#facc1514;border:1px solid #facc152e;padding:10px 14px;font-size:13px}.card-back{background:var(--bg-2)}.done-badge{background:var(--ink-dim);border:1px solid #facc152e}.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}.sheet-backdrop{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:200;background:#0009;position:fixed;inset:0}.playlist-sheet{z-index:201;background:var(--bg-2);border-radius:var(--r-xl) var(--r-xl) 0 0;padding:12px 20px calc(20px + env(safe-area-inset-bottom));border:none;flex-direction:column;gap:13px;max-width:480px;max-height:75dvh;margin:0 auto;display:flex;position:fixed;bottom:0;left:0;right:0}.ps-handle{background:var(--bg-4);border-radius:99px;width:32px;height:3px;margin:0 auto 4px}.ps-header{justify-content:space-between;align-items:flex-start;display:flex}.ps-title{font-family:var(--font-display);color:var(--text-0);font-size:16px;font-weight:600}.ps-subtitle{color:var(--text-2);white-space:nowrap;text-overflow:ellipsis;max-width:240px;margin-top:2px;font-size:14px;font-style:italic;overflow:hidden}.ps-close{color:var(--text-2);background:var(--bg-3);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:13px;display:flex}.ps-new-btn{background:var(--bg-3);border:1px dashed var(--border-md);border-radius:var(--r-md);color:var(--ink);text-align:left;align-items:center;gap:10px;width:100%;padding:11px 13px;font-size:13px;font-weight:500;transition:background .2s,border-color .2s;display:flex}.ps-new-btn:hover{background:var(--bg-4)}.ps-new-icon{font-size:17px;font-weight:300;line-height:1}.ps-create-form{flex-direction:column;gap:8px;display:flex;overflow:hidden}.ps-input{background:var(--bg-3);background:var(--bg-3);border-radius:var(--r-md);width:100%;color:var(--text-0);box-shadow:none;border:none;outline:none;padding:10px 13px;font-size:14px}.ps-input::placeholder{color:var(--text-3)}.ps-create-actions{gap:7px;display:flex}.ps-btn-cancel{color:var(--text-2);background:var(--bg-3);border-radius:var(--r-md);padding:9px 14px;font-size:13px;font-weight:400}.ps-btn-create{color:#fff;background:var(--ink);border-radius:var(--r-md);font-size:13px;font-weight:600;font-family:var(--font-display);flex:1;padding:9px;transition:opacity .2s}.ps-btn-create:disabled{opacity:.45}.ps-list{flex-direction:column;flex:1;gap:6px;display:flex;overflow-y:auto}.ps-loading{flex-direction:column;gap:7px;display:flex}.ps-empty{color:var(--text-2);text-align:center;padding:16px 0;font-size:13px;font-style:italic}.ps-playlist-row{background:var(--bg-3);border-radius:var(--r-md);text-align:left;-webkit-tap-highlight-color:transparent;border:none;align-items:center;gap:11px;width:100%;padding:11px 13px;transition:border-color .2s,background .2s;display:flex}.ps-playlist-row:hover:not(:disabled){border-color:var(--border-md)}.ps-playlist-row.ps-added{background:#9ca3af0f;border-color:#9ca3af40}.ps-playlist-row:disabled{cursor:default}.ps-pl-icon{background:var(--bg-4);width:30px;height:30px;color:var(--text-2);border-radius:7px;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:13px;font-weight:500;overflow:hidden}.ps-pl-count{color:var(--text-2);font-size:13px;font-style:italic}.ps-pl-action{flex-shrink:0}.ps-check{color:var(--green);font-size:15px;font-weight:600}.ps-plus{color:var(--ink);font-size:18px;font-weight:300;line-height:1}.ps-spinner{font-size:13px}.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}.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}.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}.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}@keyframes pc-spin{to{transform:rotate(360deg)}}.pc-spinner{transform-origin:50%;animation:.75s linear infinite pc-spin}.pc-play-btn{cursor:pointer;color:var(--bg-0);background:var(--ink);-webkit-tap-highlight-color:transparent;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:opacity .15s,background .2s;display:flex;position:relative}.pc-play-btn__ring{pointer-events:none;background:0 0;border:1.5px solid #0000;border-radius:50%;transition:border-color .2s;position:absolute;inset:-4px}.pc-play-btn:hover:not(:disabled) .pc-play-btn__ring{border-color:var(--ink-glow)}.pc-play-btn:disabled{opacity:.5;cursor:not-allowed}.pc-play-btn--error{background:color-mix(in srgb, var(--red) 80%, var(--bg-3))}.pc-play-btn--lg{width:60px;height:60px}.pc-play-btn--sm{width:38px;height:38px}.pc-scrubber{flex-direction:column;gap:4px;width:100%;display:flex}.pc-scrubber__track{appearance:none;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%);border-radius:99px;outline:none;width:100%;height:3px;transition:height .15s}.pc-scrubber__track:hover{height:4px}.pc-scrubber__track::-webkit-slider-thumb{-webkit-appearance:none;background:var(--ink);cursor:pointer;width:14px;height:14px;box-shadow:0 0 0 3px var(--ink-dim);border-radius:50%;transition:transform .12s,box-shadow .12s}.pc-scrubber__track::-webkit-slider-thumb:hover{box-shadow:0 0 0 5px var(--ink-glow);transform:scale(1.25)}.pc-scrubber__track:active::-webkit-slider-thumb{box-shadow:0 0 0 5px var(--ink-glow);transform:scale(1.25)}.pc-scrubber__track::-moz-range-thumb{background:var(--ink);cursor:pointer;border:none;border-radius:50%;width:14px;height:14px}.pc-scrubber__times{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;gap:16px;width:100%;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;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s,opacity .15s;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-icon-btn--skip{flex-direction:column;gap:1px;height:48px}.pc-skip-label{color:var(--text-2);letter-spacing:.03em;font-size:9.5px;font-weight:700;line-height:1}.pc-controls__queue-row{justify-content:space-between;align-items:center;gap:8px;padding:0 2px;display:flex}.pc-queue-label{color:var(--text-3);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:12px;overflow:hidden}.pc-repeat-btn{border:1.5px solid var(--bg-4);color:var(--text-2);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border-radius:99px;flex-shrink:0;align-items:center;gap:5px;padding:6px 12px;font-size:12px;font-weight:600;transition:color .15s,border-color .15s,background .15s;display:inline-flex}.pc-repeat-btn:hover{color:var(--text-0);border-color:var(--bg-4);background:var(--bg-3)}.pc-repeat-btn--on{color:var(--ink);border-color:var(--ink-dim);background:var(--ink-dim)}.pc-repeat-btn--on:hover{background:color-mix(in srgb, var(--ink) 18%, var(--bg-2))}.pc-error{color:var(--red);text-align:center;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-hero{background:hsl(var(--hue,35) 28% 18%);flex-shrink:0;height:220px;position:relative;overflow:hidden}.sd-hero-skeleton{background:var(--bg-2)}.sd-hero-noise{opacity:.055;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px;position:absolute;inset:0}.sd-nav-btn{top:calc(env(safe-area-inset-top) + 14px);z-index:10;-webkit-backdrop-filter:blur(12px);width:34px;height:34px;color:var(--text-0);-webkit-tap-highlight-color:transparent;background:#0e11158c;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;transition:background .2s,transform .12s;display:flex;position:absolute}.sd-nav-btn:active{transform:scale(.91)}.sd-back{left:16px}.sd-report-btn{color:var(--text-2);right:96px}.sd-share-btn{right:56px}.sd-delete-btn{color:var(--red);right:16px}.sd-btn-disabled{opacity:.35;cursor:not-allowed;pointer-events:none}.sd-waveform-visual{opacity:.18;pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.anim-wave{align-items:center;gap:5px;display:flex}.aw-bar{width:4px;height:calc(var(--h) * 80px);background:var(--text-0);border-radius:99px}.aw-bar.playing{animation:1.1s ease-in-out infinite waveform}.sd-hero-info{position:absolute;bottom:18px;left:20px;right:20px}.sd-genre{text-transform:uppercase;letter-spacing:1.2px;color:var(--text-1);margin-bottom:5px;font-size:11px;font-weight:700;display:block}.sd-title{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.2px;font-size:24px;font-weight:600;line-height:1.15}.sd-queue-caption{color:var(--text-2);margin:5px 0 0;font-size:13px}.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:var(--bg-0);border-radius:var(--r-md);font-family:var(--font-display);-webkit-tap-highlight-color:transparent;flex:1;justify-content:center;align-items:center;gap:8px;padding:13px 16px;font-size:14px;font-weight:600;transition:opacity .15s;display:flex}.sd-practice-btn:hover{opacity:.88}.sd-pack-btn{background:var(--bg-2);border-radius:var(--r-md);width:46px;height:46px;color:var(--text-1);-webkit-tap-highlight-color:transparent;border:none;flex-shrink:0;justify-content:center;align-items:center;transition:background .2s,color .2s;display:flex}.sd-pack-btn:hover{background:var(--bg-3);color:var(--ink)}.sd-tabs-section{flex-direction:column;flex:1;padding:0 20px;display:flex}.sd-tabs{border-bottom:1px solid var(--bg-4);gap:4px;margin-bottom:16px;display:flex}.sd-tab{color:var(--text-2);-webkit-tap-highlight-color:transparent;align-items:center;gap:6px;padding:10px 14px;font-size:13px;font-weight:500;transition:color .2s;display:flex;position:relative}.sd-tab.active{color:var(--text-0)}.tab-indicator{background:var(--ink);border-radius:99px 99px 0 0;height:1.5px;position:absolute;bottom:-1px;left:0;right:0}.tab-badge{background:var(--bg-3);color:var(--text-2);border-radius:99px;padding:1px 6px;font-size:11px}.lyrics-panel{flex-direction:column;display:flex}.lyrics-section-label{text-transform:uppercase;letter-spacing:1.2px;color:var(--ink);opacity:.65;font-size:11px;font-weight:700;font-family:var(--font-body);margin-top:14px;margin-bottom:4px}.concepts-panel{flex-direction:column;gap:7px;padding-bottom:24px;display:flex}.concept-item{background:var(--bg-2);border-radius:var(--r-md);border:none;align-items:center;gap:12px;padding:11px 14px;display:flex}.ci-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.concept-item.importance-high .ci-dot{background:var(--ink)}.concept-item.importance-medium .ci-dot{background:var(--sage)}.concept-item.importance-low .ci-dot{background:var(--text-3)}.ci-title{color:var(--text-0);font-size:14px;font-weight:400}.empty-tab{color:var(--text-2);text-align:center;padding:32px 0;font-size:14px;font-style:italic}.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);-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;-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-loading{min-height:100dvh;color:var(--text-2);flex-direction:column;justify-content:center;align-items:center;gap:14px;font-size:14px;font-style:italic;display:flex}.shared-error-screen{min-height:100dvh;padding:calc(env(safe-area-inset-top) + 16px) 24px 24px;flex-direction:column;display:flex}.shared-back-btn{color:var(--text-2);-webkit-tap-highlight-color:transparent;align-items:center;gap:6px;width:fit-content;margin-bottom:40px;font-size:13px;transition:color .2s;display:flex}.shared-back-btn:hover{color:var(--text-0)}.shared-error-body{text-align:center;flex-direction:column;align-items:center;gap:10px;margin:auto;display:flex}.shared-error-body h2{font-family:var(--font-display);color:var(--text-0);font-size:20px;font-weight:600}.shared-error-body p{color:var(--text-1);max-width:280px;font-size:14px;font-style:italic;line-height:1.65}.shared-screen{flex-direction:column;min-height:100dvh;padding-bottom:40px;display:flex}.shared-hero{background:hsl(var(--hue,35) 28% 18%);flex-shrink:0;height:240px;position:relative;overflow:hidden}.shared-hero-noise{opacity:.055;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px;position:absolute;inset:0}.shared-back-btn-hero{top:calc(env(safe-area-inset-top) + 14px);z-index:10;-webkit-backdrop-filter:blur(12px);width:34px;height:34px;color:var(--text-0);-webkit-tap-highlight-color:transparent;background:#0e11158c;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;transition:background .2s,transform .12s;display:flex;position:absolute;left:16px}.shared-back-btn-hero:active{transform:scale(.91)}.shared-badge{top:calc(env(safe-area-inset-top) + 14px);color:var(--text-1);-webkit-backdrop-filter:blur(10px);background:#0e111599;border:1px solid #ffffff1a;border-radius:99px;align-items:center;gap:5px;padding:5px 10px;font-size:12px;font-weight:500;display:flex;position:absolute;right:16px}.shared-hero-info{position:absolute;bottom:18px;left:20px;right:20px}.shared-genre{text-transform:uppercase;letter-spacing:1.2px;color:var(--text-1);margin-bottom:5px;font-size:11px;font-weight:700;display:block}.shared-title{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.2px;margin:0;font-size:24px;font-weight:600;line-height:1.15}.shared-summary{color:var(--text-1);margin-top:5px;font-size:14px;font-style:italic;line-height:1.5}.save-banner{background:var(--bg-2);border-radius:var(--r-lg);margin:12px 16px 0;padding:14px 16px}.save-banner-prompt{justify-content:space-between;align-items:center;gap:14px;display:flex}.save-banner-text{flex:1;min-width:0}.save-banner-title{color:var(--text-0);font-size:14px;font-weight:500;font-family:var(--font-display);margin:0}.save-banner-sub{color:var(--text-2);margin:3px 0 0;font-size:13px;font-style:italic}.save-btn{background:var(--ink);color:var(--bg-0);border-radius:var(--r-md);font-size:13px;font-weight:600;font-family:var(--font-display);white-space:nowrap;-webkit-tap-highlight-color:transparent;flex-shrink:0;align-items:center;gap:6px;padding:9px 14px;transition:opacity .15s;display:flex}.save-btn:hover{opacity:.88}.save-btn:disabled{opacity:.5}.save-banner-saved{color:var(--green);align-items:center;gap:8px;font-size:14px;font-weight:500;display:flex}.save-go-btn{color:var(--ink);-webkit-tap-highlight-color:transparent;margin-left:auto;font-size:13px;font-weight:600}.shared-player{padding:20px 20px 8px}.shared-tabs-section{flex-direction:column;flex:1;margin-top:8px;padding:0 20px;display:flex}.report-footer{justify-content:center;margin-top:auto;padding:24px 20px 36px;display:flex}.report-footer-btn{color:var(--text-3);-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}.pl-detail{flex-direction:column;min-height:100dvh;padding-bottom:40px;display:flex;overflow-y:auto}.pl-detail-header{padding:calc(env(safe-area-inset-top) + 18px) 16px 14px;z-index:10;background:var(--bg-0);border-bottom:1px solid var(--border);align-items:center;gap:10px;display:flex;position:sticky;top:0}.pl-detail-back{background:var(--bg-2);width:34px;height:34px;color:var(--text-0);-webkit-tap-highlight-color:transparent;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,transform .12s;display:flex}.pl-detail-back:active{background:var(--bg-3);transform:scale(.91)}.pl-detail-title-wrap{flex:1;min-width:0}.pl-detail-name{color:var(--text-0);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:1.25rem;font-weight:700;overflow:hidden}.pl-detail-count{color:var(--text-2);margin:2px 0 0;font-size:.75rem}.pl-detail-edit-btn{background:var(--bg-2);color:var(--text-1);cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:99px;flex-shrink:0;align-items:center;gap:5px;padding:6px 12px;font-size:.8rem;font-weight:600;transition:background .15s,color .15s,transform .12s;display:flex}.pl-detail-edit-btn:hover{background:var(--bg-3);color:var(--text-0)}.pl-detail-edit-btn:active{transform:scale(.94)}.pl-detail-rename{flex-direction:column;gap:8px;display:flex}.pl-detail-name-input{background:var(--bg-2);border:1.5px solid var(--ink);color:var(--text-0);border-radius:8px;outline:none;width:100%;padding:7px 10px;font-size:1rem;font-weight:600}.pl-detail-rename-actions{gap:8px;display:flex}.pl-detail-save-btn{background:var(--ink);color:#fff;cursor:pointer;border:none;border-radius:7px;padding:6px 14px;font-size:.8rem;font-weight:700;transition:opacity .15s}.pl-detail-save-btn:disabled{opacity:.5;cursor:not-allowed}.pl-detail-cancel-btn{background:var(--bg-2);color:var(--text-2);cursor:pointer;border:none;border-radius:7px;padding:6px 12px;font-size:.8rem;font-weight:600}.pl-detail-content{flex:1;padding:14px 16px 0}.pl-detail-actions{background:var(--bg-2);border:none;border-radius:16px;flex-direction:column;gap:10px;margin-bottom:14px;padding:14px;display:flex}.pl-detail-play-all-btn{background:var(--ink);color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;min-height:46px;padding:0 16px;font-size:.95rem;font-weight:700;transition:transform .12s,opacity .15s,background .15s;display:inline-flex}.pl-detail-play-all-btn:hover{background:var(--ink-soft)}.pl-detail-play-all-btn:active{transform:scale(.98)}.pl-detail-play-all-btn:disabled{opacity:.45;cursor:not-allowed}.pl-detail-actions-note{color:var(--text-2);margin:0;font-size:.8rem;line-height:1.45}.pl-detail-list{flex-direction:column;gap:8px;display:flex}.pl-detail-song-row{align-items:center;gap:6px;display:flex}.pl-detail-song-card{flex:1;min-width:0}.pl-song-menu-wrap{flex-shrink:0;position:relative}.pl-song-menu-btn{width:32px;height:32px;color:var(--text-2);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.pl-song-menu-btn:hover{background:var(--bg-3);color:var(--text-1)}.pl-song-menu-btn:active{transform:scale(.92)}.pl-song-menu-dropdown{z-index:50;background:var(--bg-2);box-shadow:none;transform-origin:100% 0;border:none;border-radius:10px;min-width:180px;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden}.pl-song-menu-item{width:100%;color:var(--text-1);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:11px 14px;font-size:.85rem;font-weight:500;transition:background .12s;display:flex}.pl-song-menu-item:hover{background:var(--bg-3)}.pl-song-menu-item:disabled{opacity:.45;cursor:not-allowed}.pl-song-menu-item--danger{color:var(--red)}.pl-song-menu-item--danger:hover{background:#d960601a}.pl-detail-empty{text-align:center;flex-direction:column;align-items:center;gap:14px;padding:60px 24px;display:flex}.pl-detail-empty-text{color:var(--text-2);max-width:280px;font-size:.88rem;line-height:1.5}.pl-empty-icon{background:var(--bg-3);border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;display:flex}.pl-detail-empty-sub{color:var(--text-3);margin-top:-6px;font-size:13px;line-height:1.5}.pl-add-songs-btn{background:var(--ink);color:var(--bg-0);border-radius:var(--r-md);cursor:pointer;border:none;justify-content:center;align-items:center;gap:7px;padding:12px 24px;font-size:14px;font-weight:600;transition:opacity .15s;display:flex}.pl-add-songs-btn:hover{opacity:.88}.pl-add-songs-btn--inline{background:var(--bg-3);color:var(--text-1);border-radius:var(--r-sm);padding:8px 14px;font-size:13px}.pl-add-songs-btn--inline:hover{opacity:1;background:var(--bg-4);color:var(--text-0)}.pl-detail-actions-row{justify-content:flex-end;display:flex}.add-songs-backdrop{z-index:200;background:#0000008c;position:fixed;inset:0}.add-songs-sheet{z-index:201;background:var(--bg-1);max-height:80dvh;padding-bottom:calc(env(safe-area-inset-bottom) + 16px);border-radius:24px 24px 0 0;flex-direction:column;display:flex;position:fixed;bottom:0;left:0;right:0}.add-songs-handle{background:var(--bg-4);border-radius:99px;flex-shrink:0;width:36px;height:4px;margin:12px auto 0}.add-songs-header{flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:14px 20px 10px;display:flex}.add-songs-title{color:var(--text-0);margin:0;font-size:16px;font-weight:700}.add-songs-sub{color:var(--text-3);margin:3px 0 0;font-size:12px}.add-songs-close{background:var(--bg-3);width:30px;height:30px;color:var(--text-2);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s;display:flex}.add-songs-close:hover{background:var(--bg-4)}.add-songs-search-wrap{flex-shrink:0;margin:0 20px 10px;position:relative}.add-songs-search-icon{color:var(--text-3);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.add-songs-search{background:var(--bg-2);border-radius:var(--r-md);width:100%;color:var(--text-0);box-sizing:border-box;border:none;outline:none;padding:10px 12px 10px 34px;font-size:14px}.add-songs-search::placeholder{color:var(--text-3)}.add-songs-list{flex-direction:column;flex:1;gap:4px;padding:0 12px;display:flex;overflow-y:auto}.add-songs-empty{text-align:center;color:var(--text-3);margin:0;padding:32px 0;font-size:13px}.add-songs-row{border-radius:var(--r-md);cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:12px 10px;transition:background .12s;display:flex}.add-songs-row:hover{background:var(--bg-2)}.add-songs-row.selected{background:var(--ink-pale)}.add-songs-row.already-in{opacity:.5;cursor:default}.add-songs-row-check{border:1.5px solid var(--bg-4);width:22px;height:22px;color:var(--bg-0);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,border-color .15s;display:flex}.add-songs-row.selected .add-songs-row-check,.add-songs-row.already-in .add-songs-row-check{background:var(--ink);border-color:var(--ink)}.add-songs-row-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.add-songs-row-title{color:var(--text-0);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.add-songs-row-badge{color:var(--text-3);font-size:11px}.add-songs-footer{flex-shrink:0;padding:12px 20px 0}.add-songs-confirm{background:var(--ink);width:100%;color:var(--bg-0);border-radius:var(--r-md);cursor:pointer;border:none;padding:14px;font-size:15px;font-weight:700;transition:opacity .15s}.add-songs-confirm:disabled{opacity:.35;cursor:default}.add-songs-confirm:not(:disabled):hover{opacity:.88}.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;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:600}.settings-body{flex-direction:column;flex:1;gap:6px;padding:14px 0 40px;display:flex;overflow-y:auto}.settings-section{flex-direction:column;gap:0;margin:0 0 4px;display:flex}.settings-section-label{text-transform:uppercase;letter-spacing:.7px;color:var(--text-2);padding:8px 20px 4px;font-size:13px;font-weight:600}.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);-webkit-tap-highlight-color:transparent;justify-content:space-between;align-items:center;width:100%;min-height:48px;padding:13px 20px;transition:background .15s;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;font-style:italic}.sr-badge{color:var(--ink);background:var(--ink-dim);border-radius:99px;padding:2px 8px;font-size:13px;font-weight:600}.sr-logout,.sr-danger{color:var(--red)}.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;font-style:italic;line-height:1.55}.settings-error{color:var(--red);border-radius:var(--r-sm);background:#facc1514;margin:0 20px;padding:8px 12px;font-size:13px}.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:600}.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)}.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(--red);width:100%;color:var(--text-0);border-radius:var(--r-md);font-family:var(--font-display);padding:13px;font-size:14px;font-weight:600;transition:opacity .2s}.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;font-style:italic;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{background:var(--bg-3);color:var(--text-1);-webkit-tap-highlight-color:transparent;border:none;border-radius:99px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:400;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.category-chip.active{background:var(--ink-dim);color:var(--ink);border-color:#facc1538}.contact-field{flex-direction:column;gap:6px;display:flex}.contact-label{text-transform:uppercase;letter-spacing:.6px;color:var(--text-2);font-size:13px;font-weight:600}.contact-input,.contact-textarea{background:var(--bg-2);border-radius:var(--r-md);width:100%;color:var(--text-0);border:none;outline:none;padding:11px 13px;font-size:14px;transition:border-color .2s,box-shadow .2s}.contact-input:focus,.contact-textarea:focus{border-color:var(--ink);box-shadow:none}.contact-input::placeholder,.contact-textarea::placeholder{color:var(--text-3)}.contact-textarea{resize:none;line-height:1.65}.contact-submit{background:var(--ink);color:#fff;border-radius:var(--r-md);font-family:var(--font-display);padding:13px;font-size:14px;font-weight:600;transition:opacity .2s,background .15s}.contact-submit:disabled{opacity:.45}.contact-submit:not(:disabled):hover{background:var(--ink-soft)}.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:600}.contact-sent p{color:var(--text-1);font-size:14px}.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:36px;height:36px;color:var(--text-2);background:var(--bg-2);-webkit-tap-highlight-color:transparent;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:color .18s,background .18s;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);border-radius:99px;min-width:6px;height:6px;transition:width .3s,background .3s}.ob-skip{color:var(--text-3);-webkit-tap-highlight-color:transparent;letter-spacing:.1px;flex-shrink:0;padding:8px 4px 8px 16px;font-size:13px;font-weight:500;transition:color .18s}.ob-skip:active{color:var(--text-0)}.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-eyebrow{letter-spacing:1.2px;text-transform:uppercase;color:var(--ink);opacity:.8;font-size:11px;font-weight:700}.ob-title{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.5px;font-size:26px;font-weight:700;line-height:1.16}.ob-body-text{color:var(--text-1);font-size:14px;line-height:1.65}.ob-muted{color:var(--text-3);font-style:italic}.ob-insight{background:var(--bg-2);border-radius:var(--r-md);border-left:3px solid var(--ink);color:var(--text-1);align-items:flex-start;gap:10px;padding:13px 14px;font-size:13px;line-height:1.5;display:flex}.ob-insight--urgent{border-left-color:#f97316}.ob-insight>svg{color:var(--ink);flex-shrink:0;margin-top:1px}.ob-insight--urgent>svg{color:#f97316}.ob-footer{background:var(--bg-0);border-top:1px solid #ffffff0a;flex-direction:column;flex-shrink:0;align-items:center;gap:4px;padding:14px 20px 12px;display:flex}.ob-cta{background:var(--ink);color:#000;border-radius:var(--r-md);width:100%;height:54px;font-family:var(--font-display);letter-spacing:-.2px;-webkit-tap-highlight-color:transparent;justify-content:center;align-items:center;gap:8px;font-size:15px;font-weight:800;transition:filter .15s,opacity .2s;display:flex;position:relative;overflow:hidden}.ob-cta:after{content:"";pointer-events:none;background:linear-gradient(135deg,#ffffff1f 0%,#0000 60%);position:absolute;inset:0}.ob-cta:active{filter:brightness(.88)}.ob-cta--dim{cursor:default}.ob-cta-spinner{border:2.5px solid #0000004d;border-top-color:#000;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite ob-spin}@keyframes ob-spin{to{transform:rotate(360deg)}}.ob-fine{color:var(--text-3);letter-spacing:.1px;padding:4px 0 2px;font-size:12px}.slide-value-prop{position:relative;overflow:hidden}.vp-glow{pointer-events:none;background:radial-gradient(circle,#facc1514 0%,#0000 70%);width:320px;height:320px;position:absolute;top:-80px;left:50%;transform:translate(-50%)}.vp-body{flex-direction:column;flex:1;justify-content:center;gap:24px;padding:36px 26px 28px;display:flex}.vp-brand{font-family:var(--font-display);letter-spacing:3px;text-transform:uppercase;color:var(--ink);font-size:13px;font-weight:900}.vp-wave-wrap{flex-direction:column;align-items:flex-start;gap:8px;display:flex}.vp-wave{align-items:center;gap:3px;height:52px;display:flex}.vp-bar{background:var(--ink);border-radius:99px;width:3px;animation:1.6s ease-in-out infinite ob-wave}@keyframes ob-wave{0%,to{transform:scaleY(.3)}50%{transform:scaleY(1)}}.vp-wave-label{letter-spacing:.8px;text-transform:uppercase;color:var(--text-3);font-size:11px;font-weight:600}.vp-headline{font-family:var(--font-display);color:var(--text-0);letter-spacing:-.9px;font-size:34px;font-weight:800;line-height:1.1}.vp-headline em{color:var(--ink);font-style:italic}.vp-sub{color:var(--text-2);font-size:16px;line-height:1.55}.vp-proof{background:var(--bg-2);border-radius:var(--r-md);align-items:center;gap:10px;padding:12px 14px;display:flex}.vp-proof-icons{color:var(--ink);flex-shrink:0;align-items:center;gap:2px;display:flex}.vp-proof-text{color:var(--text-1);flex:1;font-size:13px;line-height:1.4}.pressure-list{flex-direction:column;gap:9px;margin-top:2px;display:flex}.pressure-row{background:var(--bg-2);border-radius:var(--r-md);text-align:left;-webkit-tap-highlight-color:transparent;border:1.5px solid #0000;align-items:center;gap:13px;padding:15px;transition:border-color .18s,background .18s;display:flex}.pressure-row--on{border-color:var(--ink);background:var(--ink-pale)}.pressure-icon{background:var(--bg-3);width:36px;height:36px;color:var(--text-2);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;transition:background .18s,color .18s;display:flex}.pressure-row--on .pressure-icon{background:var(--ink-dim);color:var(--ink)}.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);font-size:13px;line-height:1.3}.pressure-radio{border:1.5px solid var(--bg-4);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:23px;height:23px;display:flex}.subject-grid{grid-template-columns:1fr 1fr;gap:9px;margin-top:2px;display:grid}.subject-chip{background:var(--bg-2);border-radius:var(--r-md);text-align:left;-webkit-tap-highlight-color:transparent;border:1.5px solid #0000;flex-direction:column;align-items:flex-start;gap:8px;padding:14px 13px;transition:border-color .18s,background .18s;display:flex;position:relative}.subject-chip--on{border-color:var(--ink);background:var(--ink-pale)}.subject-icon{color:var(--text-2);justify-content:center;align-items:center;transition:color .18s;display:flex}.subject-chip--on .subject-icon{color:var(--ink)}.subject-label{color:var(--text-0);font-size:12.5px;font-weight:500;line-height:1.3}.subject-check{background:var(--ink);border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;display:flex;position:absolute;top:8px;right:8px}.subject-tally{color:var(--ink);text-align:center;padding:2px 0;font-size:13px;font-weight:600}.genre-list{flex-direction:column;gap:8px;margin-top:2px;display:flex}.genre-row{background:var(--bg-2);border-radius:var(--r-md);text-align:left;-webkit-tap-highlight-color:transparent;border:1.5px solid #0000;align-items:center;gap:13px;padding:13px 14px;transition:border-color .18s,background .18s;display:flex}.genre-row--on{border-color:var(--ink);background:var(--ink-pale)}.genre-icon{background:var(--bg-3);width:36px;height:36px;color:var(--text-2);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;transition:background .18s,color .18s;display:flex}.genre-row--on .genre-icon{background:var(--ink-dim);color:var(--ink)}.genre-info{flex-direction:column;flex:1;gap:2px;display:flex}.genre-label{color:var(--text-0);font-size:15px;font-weight:600;line-height:1.2}.genre-sub{color:var(--text-2);font-size:12px;line-height:1.3}.genre-radio{border:1.5px solid var(--bg-4);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;display:flex}.examdate-field-wrap{flex-direction:column;gap:10px;display:flex}.examdate-input{background:var(--bg-2);border:1.5px solid var(--bg-4);border-radius:var(--r-md);width:100%;font-family:var(--font-body);color:var(--text-0);appearance:none;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;outline:none;padding:16px;font-size:15px;font-weight:500;transition:border-color .2s}.examdate-input:focus{border-color:var(--ink)}.examdate-input::placeholder{color:var(--text-3);font-weight:400}.countdown-badge{letter-spacing:.2px;padding:2px 0 0 4px;font-size:13px;font-weight:700}.examdate-why{background:var(--bg-2);border-radius:var(--r-md);color:var(--text-2);align-items:flex-start;gap:10px;padding:13px 14px;font-size:13px;line-height:1.5;display:flex}.examdate-why>svg{color:var(--ink);flex-shrink:0;margin-top:1px}.slide-success .slide-body{gap:18px}.success-spark{background:var(--ink-pale);border:1.5px solid var(--ink-dim);width:72px;height:72px;color:var(--ink);border-radius:20px;justify-content:center;align-items:center;display:flex}.success-title{font-size:30px}.success-card{background:var(--bg-2);border-radius:var(--r-lg);border:1.5px solid var(--bg-3);overflow:hidden}.success-card-row{align-items:flex-start;gap:13px;padding:14px 15px;display:flex}.success-card-icon{width:28px;height:28px;color:var(--ink);flex-shrink:0;justify-content:center;align-items:center;padding-top:2px;display:flex}.success-card-label{letter-spacing:.8px;text-transform:uppercase;color:var(--text-3);margin-bottom:3px;font-size:11px;font-weight:700}.success-card-value{color:var(--text-0);font-size:14px;font-weight:500;line-height:1.4}.success-card-divider{background:var(--bg-3);height:1px}.success-next{color:var(--ink);align-items:flex-start;gap:10px;padding:2px 0;font-size:13px;font-weight:500;line-height:1.5;display:flex}.success-next>svg{flex-shrink:0;margin-top:2px}.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{margin-bottom:4px;font-size:52px;line-height:1}.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{letter-spacing:.1px;-webkit-tap-highlight-color:transparent;border-radius:14px;width:100%;padding:15px 20px;font-size:16px;font-weight:600;transition:opacity .15s,transform .12s}.age-gate-btn:active{opacity:.8;transform:scale(.98)}.age-gate-btn--yes{background:var(--ink);color:var(--bg-0)}.age-gate-btn--no{background:var(--bg-2);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{font-size:48px;line-height:1}.age-blocked-title{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}.bottom-nav{z-index:100;padding-bottom:env(safe-area-inset-bottom);background:var(--bg-1);border-top:1px solid var(--border);position:fixed;bottom:0;left:0;right:0}.bottom-nav-inner{justify-content:space-around;align-items:center;max-width:480px;margin:0 auto;padding:8px 8px 12px;display:flex}.nav-item{color:var(--text-2);-webkit-tap-highlight-color:transparent;flex-direction:column;flex:1;align-items:center;gap:4px;padding:6px 0;transition:color .2s;display:flex;position:relative}.nav-item.active{color:var(--ink)}.nav-icon-wrap{justify-content:center;align-items:center;width:44px;height:30px;display:flex;position:relative}.nav-pill{background:var(--ink-dim);border:1px solid #facc152e;border-radius:99px;position:absolute;inset:0}.nav-icon{z-index:1;justify-content:center;align-items:center;line-height:0;display:flex;position:relative}.nav-label{letter-spacing:.1px;font-size:13px;font-weight:500;font-family:var(--font-body)}.bottom-nav{-webkit-backdrop-filter:blur(16px);background:#111315f0;border-top:none}.mini-player{bottom:calc(var(--nav-h) + env(safe-area-inset-bottom) + 6px);z-index:200;background:var(--bg-2);border:1px solid var(--bg-4);border-radius:18px;width:auto;max-width:464px;margin:0 auto;position:fixed;left:8px;right:8px;overflow:hidden;box-shadow:0 8px 32px #00000073,inset 0 1px #ffffff0a}@media (width>=768px){.mini-player{width:464px;bottom:16px;left:calc(50% - 232px);transform:none}}.mp-progress{background:var(--bg-4);height:2px}.mp-progress-fill{background:var(--ink);border-radius:99px;height:100%;transition:width .5s linear}.mp-body{align-items:center;gap:8px;padding:9px 10px 9px 12px;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:10px;min-width:0;padding:0;display:flex}.mp-disc{flex-shrink:0;width:34px;height:34px}@keyframes mp-disc-spin{to{transform:rotate(360deg)}}.mp-disc--spinning{animation:3s linear infinite mp-disc-spin}.mp-text{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.mp-title{color:var(--text-0);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;line-height:1.35;overflow:hidden}.mp-sub{color:var(--text-3);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.mp-controls{flex-shrink:0;align-items:center;gap:2px;display:flex}.mp-icon-btn{width:34px;height:34px;color:var(--text-1);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:10px;justify-content:center;align-items:center;transition:background .12s,color .12s,opacity .15s;display:flex}.mp-icon-btn:hover{background:var(--bg-3);color:var(--text-0)}.mp-icon-btn:disabled{opacity:.25;cursor:default}.mp-icon-btn--close{color:var(--text-3);margin-left:4px}.mp-icon-btn--close:hover{color:var(--text-1);background:var(--bg-3)}.app-shell{flex-direction:column;min-height:100dvh;display:flex;position:relative}.app-shell--has-player{--mp-h:62px}@media (width>=768px){body{background:var(--bg-0)}.app-shell{flex-direction:row;justify-content:center;align-items:stretch;min-height:100dvh;overflow:visible}.page-wrapper{width:480px;min-width:480px;max-width:480px;position:relative;overflow:hidden}.top-nav{display:flex}.bottom-nav{display:none}}@media (width<=767px){.top-nav{display:none}}.top-nav{z-index:200;-webkit-backdrop-filter:blur(16px);background:#111315eb;border-bottom:1px solid #facc150f;justify-content:center;align-items:center;width:480px;height:60px;position:fixed;top:0;left:50%;transform:translate(-50%)}.top-nav-inner{justify-content:space-between;align-items:center;width:100%;max-width:480px;height:100%;padding:0 20px;display:flex}.top-nav-logo{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text-0);font-size:1.25rem;font-weight:900;line-height:1}.top-nav-logo span{color:var(--ink)}.top-nav-tabs{align-items:center;gap:2px;display:flex}.top-nav-tab{color:var(--text-2);font-size:.875rem;font-weight:500;font-family:var(--font-body);border-radius:8px;align-items:center;gap:7px;padding:7px 14px;transition:color .15s,background .15s;display:flex}.top-nav-tab:hover{color:var(--text-0);background:var(--bg-3)}.top-nav-tab.active{color:var(--ink);background:var(--ink-dim);font-weight:600}.top-nav-tab svg{flex-shrink:0}.page-wrapper,.page-transition-inner{flex-direction:column;flex:1;min-height:100dvh;display:flex}@media (width>=768px){.page-wrapper{background:var(--bg-0);min-height:100dvh;padding-top:60px}}.splash{background:var(--bg-0);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.splash-logo{flex-direction:column;align-items:center;gap:12px;display:flex}.splash-name{font-family:var(--font-display);letter-spacing:-.3px;color:var(--text-0);font-size:26px;font-weight:900}.deletion-banner{z-index:120;flex-shrink:0;position:relative;overflow:hidden}.deletion-banner-inner{padding:calc(env(safe-area-inset-top) + 8px) 16px 8px;background:#f8717114;border-bottom:1px solid #f8717124;justify-content:space-between;align-items:center;gap:12px;display:flex}.deletion-banner-text{color:var(--red);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(--red);white-space:nowrap;background:#f871711f;border:none;border-radius:99px;flex-shrink:0;padding:5px 14px;font-size:13px;font-weight:600;transition:background .2s}.deletion-banner-cancel:hover{background:#f8717138}.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:#facc150f;border-bottom:1px solid #facc151a;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}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.pending-draft-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.pending-draft-cancel{color:var(--text-2);background:var(--bg-3);border:none;border-radius:99px;padding:5px 12px;font-size:13px;transition:color .15s,background .15s}.pending-draft-cancel:hover{color:var(--text-0);background:var(--bg-4)}.pending-draft-dismiss{color:var(--bg-0);background:var(--ink);border-radius:99px;padding:5px 14px;font-size:13px;font-weight:600;transition:opacity .15s}.pending-draft-dismiss:hover{opacity:.85}@media (width>=768px){.page-wrapper{isolation:isolate}.settings-screen,.onboarding-screen{overflow-y:auto;width:100%!important;height:100%!important;position:absolute!important;inset:0!important}.paywall-overlay,.playlist-sheet-overlay,.share-sheet-overlay,.sd-delete-overlay{position:absolute!important;inset:0!important}}.offline-banner{z-index:999;width:100%;max-width:480px;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%)}
