@import"https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap";.badge-icon-wrap[data-v-4499e115] svg{display:block}.badge-celebrate-overlay[data-v-c3432467]{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:24px;background:#0f172a8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.badge-celebrate-confetti[data-v-c3432467]{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none}.confetti-piece[data-v-c3432467]{position:absolute;top:-12px;width:10px;height:14px;border-radius:2px;opacity:.9;animation-name:confetti-fall-c3432467;animation-timing-function:linear;animation-iteration-count:infinite}@keyframes confetti-fall-c3432467{0%{transform:translateY(-10vh) rotate(0);opacity:1}to{transform:translateY(110vh) rotate(720deg);opacity:.35}}.badge-celebrate-card[data-v-c3432467]{position:relative;width:min(100%,380px);padding:32px 28px 28px;text-align:center;background:#fff;border-radius:20px;box-shadow:0 24px 60px #0f172a33,0 0 0 1px #34d39940;animation:badge-pop-c3432467 .45s cubic-bezier(.34,1.56,.64,1)}.badge-celebrate-glow[data-v-c3432467]{position:absolute;top:-40px;right:-40px;bottom:-40px;left:-40px;background:radial-gradient(circle at 50% 30%,rgba(52,211,153,.35),transparent 65%);pointer-events:none;z-index:-1}.badge-celebrate-kicker[data-v-c3432467]{margin:0 0 4px;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#059669}.badge-celebrate-title[data-v-c3432467]{margin:0 0 16px;font-size:22px;color:var(--ink, #0f172a)}.badge-celebrate-icon[data-v-c3432467]{font-size:56px;line-height:1;margin-bottom:12px;animation:badge-bounce-c3432467 1.2s ease-in-out infinite}.badge-celebrate-name[data-v-c3432467]{margin:0 0 8px;font-size:18px;font-weight:700;color:var(--ink, #0f172a)}.badge-celebrate-desc[data-v-c3432467]{margin:0 0 20px;font-size:13px;line-height:1.5;color:var(--ink3, #64748b)}.badge-celebrate-btn[data-v-c3432467]{min-width:140px}.badge-celebrate-more[data-v-c3432467]{margin:12px 0 0;font-size:11px;color:var(--ink3, #64748b)}@keyframes badge-pop-c3432467{0%{opacity:0;transform:scale(.85) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes badge-bounce-c3432467{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-6px) scale(1.06)}}.badge-celebrate-enter-active[data-v-c3432467],.badge-celebrate-leave-active[data-v-c3432467]{transition:opacity .25s ease}.badge-celebrate-enter-from[data-v-c3432467],.badge-celebrate-leave-to[data-v-c3432467]{opacity:0}.choice-card[data-v-810955bf]{display:flex;min-height:160px;flex-direction:column;align-items:flex-start;gap:10px;border:1px solid var(--border);border-radius:8px;background:var(--bg);padding:18px;text-align:left;transition:border-color .15s ease,transform .15s ease}.choice-card[data-v-810955bf]:hover:enabled{border-color:#34d399;transform:translateY(-1px)}.choice-card[data-v-810955bf]:disabled{cursor:wait;opacity:.7}.choice-card__icon[data-v-810955bf]{display:inline-flex;height:34px;width:34px;align-items:center;justify-content:center;border-radius:8px;border:1px solid var(--border);background:var(--bg-interactive);color:var(--ink);font-size:12px;font-weight:800}.choice-card__title[data-v-810955bf]{font-size:15px;font-weight:800;color:var(--ink)}.choice-card__body[data-v-810955bf]{font-size:13px;line-height:1.5;color:var(--ink3)}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:var(--font-body);font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.\!container{width:100%!important}.container{width:100%}@media (min-width: 640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media (min-width: 768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media (min-width: 1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media (min-width: 1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media (min-width: 1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.hl-grammar-error{border-radius:.125rem;--tw-bg-opacity: 1;background-color:rgb(254 202 202 / var(--tw-bg-opacity, 1));padding-left:.125rem;padding-right:.125rem;--tw-text-opacity: 1;color:rgb(127 29 29 / var(--tw-text-opacity, 1))}.hl-vocab-weak{border-radius:.125rem;--tw-bg-opacity: 1;background-color:rgb(254 240 138 / var(--tw-bg-opacity, 1));padding-left:.125rem;padding-right:.125rem;--tw-text-opacity: 1;color:rgb(113 63 18 / var(--tw-text-opacity, 1))}.hl-vocab-strong{border-radius:.125rem;--tw-bg-opacity: 1;background-color:rgb(187 247 208 / var(--tw-bg-opacity, 1));padding-left:.125rem;padding-right:.125rem;--tw-text-opacity: 1;color:rgb(20 83 45 / var(--tw-text-opacity, 1))}.gap-wrapper{display:inline-flex;align-items:center;gap:.125rem;vertical-align:baseline}.spotify-panel__tabs>.gap-wrapper{min-width:-moz-max-content;min-width:max-content}.gap-num{display:inline-flex;height:18px;min-width:18px;flex-shrink:0;align-items:center;justify-content:center;border-radius:9999px;--tw-bg-opacity: 1;background-color:rgb(52 211 153 / var(--tw-bg-opacity, 1));vertical-align:middle;font-size:10px;font-weight:700;line-height:1;--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.spotify-panel__tabs>.gap-num{min-width:-moz-max-content;min-width:max-content}.gap-input{display:inline-block;min-width:88px;max-width:160px;border-width:0px;border-bottom-width:2px;--tw-border-opacity: 1;border-bottom-color:rgb(23 23 23 / var(--tw-border-opacity, 1));background-color:transparent;padding-left:.25rem;padding-right:.25rem;padding-bottom:.125rem;padding-top:1px;vertical-align:baseline;font-family:inherit;font-size:.875rem;line-height:1.25rem;--tw-text-opacity: 1;color:rgb(23 23 23 / var(--tw-text-opacity, 1));outline:2px solid transparent;outline-offset:2px;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:ease;transition-duration:.15s}.gap-input:focus{--tw-border-opacity: 1;border-bottom-color:rgb(52 211 153 / var(--tw-border-opacity, 1))}.gap-input:disabled{cursor:not-allowed;opacity:.6}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{top:0;right:0;bottom:0;left:0}.inset-x-0{left:0;right:0}.inset-y-0{top:0;bottom:0}.-right-0\.5{right:-.125rem}.-right-12{right:-3rem}.-right-4{right:-1rem}.-right-6{right:-1.5rem}.-right-8{right:-2rem}.-top-0\.5{top:-.125rem}.-top-12{top:-3rem}.-top-6{top:-1.5rem}.-top-8{top:-2rem}.bottom-0{bottom:0}.bottom-0\.5{bottom:.125rem}.bottom-4{bottom:1rem}.left-0{left:0}.left-1\/2{left:50%}.left-14{left:3.5rem}.left-2\.5{left:.625rem}.left-3{left:.75rem}.left-4{left:1rem}.left-\[calc\(100\%\+8px\)\]{left:calc(100% + 8px)}.right-0{right:0}.right-1{right:.25rem}.right-2\.5{right:.625rem}.right-3{right:.75rem}.right-3\.5{right:.875rem}.right-4{right:1rem}.start-full{inset-inline-start:100%}.top-0{top:0}.top-1\/2{top:50%}.top-10{top:2.5rem}.top-12{top:3rem}.top-20{top:5rem}.top-3{top:.75rem}.top-3\.5{top:.875rem}.top-4{top:1rem}.z-10{z-index:10}.z-20{z-index:20}.z-40{z-index:40}.z-50{z-index:50}.z-\[10000\]{z-index:10000}.z-\[100\]{z-index:100}.z-\[150\]{z-index:150}.z-\[160\]{z-index:160}.z-\[200\]{z-index:200}.z-\[500\]{z-index:500}.z-\[600\]{z-index:600}.z-\[700\]{z-index:700}.z-\[9000\]{z-index:9000}.col-span-2{grid-column:span 2 / span 2}.col-span-3{grid-column:span 3 / span 3}.m-0{margin:0}.mx-1{margin-left:.25rem;margin-right:.25rem}.mx-auto{margin-left:auto;margin-right:auto}.my-0\.5{margin-top:.125rem;margin-bottom:.125rem}.my-1\.5{margin-top:.375rem;margin-bottom:.375rem}.-mt-0\.5{margin-top:-.125rem}.mb-0\.5{margin-bottom:.125rem}.mb-1{margin-bottom:.25rem}.mb-1\.5{margin-bottom:.375rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-3\.5{margin-bottom:.875rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mb-7{margin-bottom:1.75rem}.mb-8{margin-bottom:2rem}.ml-0{margin-left:0}.ml-0\.5{margin-left:.125rem}.ml-1{margin-left:.25rem}.ml-1\.5{margin-left:.375rem}.ml-2{margin-left:.5rem}.ml-3{margin-left:.75rem}.ml-auto{margin-left:auto}.mr-0\.5{margin-right:.125rem}.mr-1{margin-right:.25rem}.mr-1\.5{margin-right:.375rem}.mr-2{margin-right:.5rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-16{margin-top:4rem}.mt-2{margin-top:.5rem}.mt-2\.5{margin-top:.625rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mt-auto{margin-top:auto}.line-clamp-1{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.aspect-\[5\/2\]{aspect-ratio:5/2}.aspect-square{aspect-ratio:1 / 1}.aspect-video{aspect-ratio:16 / 9}.h-0\.5{height:.125rem}.h-1{height:.25rem}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-12{height:3rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-20{height:5rem}.h-24{height:6rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-40{height:10rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-7{height:1.75rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[18px\]{height:18px}.h-\[63px\]{height:63px}.h-auto{height:auto}.h-full{height:100%}.h-px{height:1px}.h-screen{height:100vh}.max-h-72{max-height:18rem}.max-h-80{max-height:20rem}.max-h-\[320px\]{max-height:320px}.max-h-\[420px\]{max-height:420px}.max-h-\[720px\]{max-height:720px}.max-h-\[740px\]{max-height:740px}.max-h-\[760px\]{max-height:760px}.max-h-\[80vh\]{max-height:80vh}.max-h-\[min\(420px\,50vh\)\]{max-height:min(420px,50vh)}.max-h-\[min\(560px\,calc\(100vh-24px\)\)\]{max-height:min(560px,calc(100vh - 24px))}.min-h-0{min-height:0px}.min-h-16{min-height:4rem}.min-h-20{min-height:5rem}.min-h-24{min-height:6rem}.min-h-28{min-height:7rem}.min-h-32{min-height:8rem}.min-h-36{min-height:9rem}.min-h-\[100px\]{min-height:100px}.min-h-\[110px\]{min-height:110px}.min-h-\[120px\]{min-height:120px}.min-h-\[14px\]{min-height:14px}.min-h-\[260px\]{min-height:260px}.min-h-\[280px\]{min-height:280px}.min-h-\[320px\]{min-height:320px}.min-h-\[44px\]{min-height:44px}.min-h-\[58px\]{min-height:58px}.min-h-\[620px\]{min-height:620px}.min-h-\[70px\]{min-height:70px}.min-h-\[720px\]{min-height:720px}.min-h-\[90px\]{min-height:90px}.min-h-\[inherit\]{min-height:inherit}.min-h-\[min\(460px\,52vh\)\]{min-height:min(460px,52vh)}.min-h-screen{min-height:100vh}.w-0\.5{width:.125rem}.w-1{width:.25rem}.w-1\.5{width:.375rem}.w-10{width:2.5rem}.w-11{width:2.75rem}.w-12{width:3rem}.w-14{width:3.5rem}.w-16{width:4rem}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-20{width:5rem}.w-24{width:6rem}.w-28{width:7rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-3\/4{width:75%}.w-32{width:8rem}.w-4{width:1rem}.w-40{width:10rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-64{width:16rem}.w-7{width:1.75rem}.w-8{width:2rem}.w-80{width:20rem}.w-9{width:2.25rem}.w-\[18px\]{width:18px}.w-\[220px\]{width:220px}.w-\[min\(100vw-2rem\,360px\)\]{width:min(100vw - 2rem,360px)}.w-\[min\(420px\,calc\(100vw-24px\)\)\]{width:min(420px,calc(100vw - 24px))}.w-\[min\(440px\,calc\(100\%-2rem\)\)\]{width:min(440px,calc(100% - 2rem))}.w-full{width:100%}.w-px{width:1px}.min-w-0{min-width:0px}.min-w-\[100px\]{min-width:100px}.min-w-\[1080px\]{min-width:1080px}.min-w-\[120px\]{min-width:120px}.min-w-\[140px\]{min-width:140px}.min-w-\[16px\]{min-width:16px}.min-w-\[480px\]{min-width:480px}.min-w-\[520px\]{min-width:520px}.min-w-\[640px\]{min-width:640px}.min-w-\[760px\]{min-width:760px}.min-w-\[80px\]{min-width:80px}.min-w-\[900px\]{min-width:900px}.min-w-\[90px\]{min-width:90px}.min-w-\[980px\]{min-width:980px}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-6xl{max-width:72rem}.max-w-7xl{max-width:80rem}.max-w-\[1400px\]{max-width:1400px}.max-w-\[1600px\]{max-width:1600px}.max-w-\[200px\]{max-width:200px}.max-w-\[220px\]{max-width:220px}.max-w-\[300px\]{max-width:300px}.max-w-\[4\.5rem\]{max-width:4.5rem}.max-w-\[400px\]{max-width:400px}.max-w-\[75\%\]{max-width:75%}.max-w-\[800px\]{max-width:800px}.max-w-\[85\%\]{max-width:85%}.max-w-\[88\%\]{max-width:88%}.max-w-full{max-width:100%}.max-w-md{max-width:28rem}.max-w-none{max-width:none}.max-w-sm{max-width:24rem}.max-w-xl{max-width:36rem}.max-w-xs{max-width:20rem}.flex-1{flex:1 1 0%}.flex-\[2\]{flex:2}.flex-shrink{flex-shrink:1}.flex-shrink-0{flex-shrink:0}.shrink{flex-shrink:1}.shrink-0{flex-shrink:0}.border-collapse{border-collapse:collapse}.-translate-x-1\/2{--tw-translate-x: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-x-full{--tw-translate-x: -100%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-0{--tw-translate-x: 0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-rotate-90{--tw-rotate: -90deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rotate-180{--tw-rotate: 180deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-110{--tw-scale-x: 1.1;--tw-scale-y: 1.1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-95{--tw-scale-x: .95;--tw-scale-y: .95;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes bounce{0%,to{transform:translateY(-25%);animation-timing-function:cubic-bezier(.8,0,1,1)}50%{transform:none;animation-timing-function:cubic-bezier(0,0,.2,1)}}.animate-bounce{animation:bounce 1s infinite}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.cursor-col-resize{cursor:col-resize}.cursor-default{cursor:default}.cursor-grab{cursor:grab}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.cursor-text{cursor:text}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.select-text{-webkit-user-select:text;-moz-user-select:text;user-select:text}.resize-none{resize:none}.resize-y{resize:vertical}.resize{resize:both}.list-disc{list-style-type:disc}.list-none{list-style-type:none}.grid-flow-col{grid-auto-flow:column}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-cols-7{grid-template-columns:repeat(7,minmax(0,1fr))}.grid-rows-7{grid-template-rows:repeat(7,minmax(0,1fr))}.flex-row-reverse{flex-direction:row-reverse}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.items-baseline{align-items:baseline}.items-stretch{align-items:stretch}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.justify-items-center{justify-items:center}.gap-0{gap:0px}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-2\.5{gap:.625rem}.gap-3{gap:.75rem}.gap-3\.5{gap:.875rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.gap-\[3px\]{gap:3px}.gap-x-1{-moz-column-gap:.25rem;column-gap:.25rem}.gap-x-4{-moz-column-gap:1rem;column-gap:1rem}.gap-x-6{-moz-column-gap:1.5rem;column-gap:1.5rem}.gap-x-8{-moz-column-gap:2rem;column-gap:2rem}.gap-y-0\.5{row-gap:.125rem}.gap-y-1{row-gap:.25rem}.gap-y-10{row-gap:2.5rem}.gap-y-2{row-gap:.5rem}.gap-y-5{row-gap:1.25rem}.space-y-0\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.125rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.125rem * var(--tw-space-y-reverse))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.375rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.375rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.25rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.divide-x>:not([hidden])~:not([hidden]){--tw-divide-x-reverse: 0;border-right-width:calc(1px * var(--tw-divide-x-reverse));border-left-width:calc(1px * calc(1 - var(--tw-divide-x-reverse)))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse: 0;border-top-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(1px * var(--tw-divide-y-reverse))}.divide-\[var\(--border\)\]>:not([hidden])~:not([hidden]){border-color:var(--border)}.self-end{align-self:flex-end}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-visible{overflow:visible}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.overscroll-contain{overscroll-behavior:contain}.scroll-smooth{scroll-behavior:smooth}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-normal{white-space:normal}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-line{white-space:pre-line}.whitespace-pre-wrap{white-space:pre-wrap}.break-words{overflow-wrap:break-word}.\!rounded-full{border-radius:9999px!important}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-3xl{border-radius:1.5rem}.rounded-\[10px\]{border-radius:10px}.rounded-\[20px\]{border-radius:20px}.rounded-\[var\(--r\)\]{border-radius:var(--r)}.rounded-\[var\(--r-sm\)\]{border-radius:var(--r-sm)}.rounded-\[var\(--radius-comfortable\)\]{border-radius:var(--radius-comfortable)}.rounded-\[var\(--radius-standard\)\]{border-radius:var(--radius-standard)}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-none{border-radius:0}.rounded-sm{border-radius:.125rem}.rounded-xl{border-radius:.75rem}.rounded-bl-md{border-bottom-left-radius:.375rem}.rounded-tl-none{border-top-left-radius:0}.rounded-tl-sm{border-top-left-radius:.125rem}.rounded-tr-none{border-top-right-radius:0}.rounded-tr-sm{border-top-right-radius:.125rem}.border{border-width:1px}.border-0{border-width:0px}.border-2{border-width:2px}.border-4{border-width:4px}.border-\[1\.5px\]{border-width:1.5px}.border-b{border-bottom-width:1px}.border-b-0{border-bottom-width:0px}.border-b-2{border-bottom-width:2px}.border-l{border-left-width:1px}.border-l-4{border-left-width:4px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-t-2{border-top-width:2px}.border-dashed{border-style:dashed}.border-none{border-style:none}.\!border-emerald-400{--tw-border-opacity: 1 !important;border-color:rgb(52 211 153 / var(--tw-border-opacity, 1))!important}.\!border-rose-400{--tw-border-opacity: 1 !important;border-color:rgb(251 113 133 / var(--tw-border-opacity, 1))!important}.border-\[\#111\]{--tw-border-opacity: 1;border-color:rgb(17 17 17 / var(--tw-border-opacity, 1))}.border-\[\#34d39955\]{border-color:#34d39955}.border-\[\#34d399\]{--tw-border-opacity: 1;border-color:rgb(52 211 153 / var(--tw-border-opacity, 1))}.border-\[\#d1d5db\]{--tw-border-opacity: 1;border-color:rgb(209 213 219 / var(--tw-border-opacity, 1))}.border-\[\#e11d48\]{--tw-border-opacity: 1;border-color:rgb(225 29 72 / var(--tw-border-opacity, 1))}.border-\[\#f43f5e33\]{border-color:#f43f5e33}.border-\[\#f43f5e44\]{border-color:#f43f5e44}.border-\[\#f59e0b33\]{border-color:#f59e0b33}.border-\[\#fecaca\]{--tw-border-opacity: 1;border-color:rgb(254 202 202 / var(--tw-border-opacity, 1))}.border-\[rgba\(144\,96\,10\,0\.2\)\]{border-color:#90600a33}.border-\[var\(--blue-l\)\]{border-color:var(--blue-l)}.border-\[var\(--border\)\]{border-color:var(--border)}.border-\[var\(--border-button\)\]{border-color:var(--border-button)}.border-\[var\(--border2\)\]{border-color:var(--border2)}.border-\[var\(--ink\)\]{border-color:var(--ink)}.border-\[var\(--rose\)\]{border-color:var(--rose)}.border-\[var\(--rose-l\)\]{border-color:var(--rose-l)}.border-\[var\(--spotify-green\)\]{border-color:var(--spotify-green)}.border-\[var\(--spotify-green-dark\)\]{border-color:var(--spotify-green-dark)}.border-\[var\(--text-negative\)\]{border-color:var(--text-negative)}.border-\[var\(--text-warning\)\]{border-color:var(--text-warning)}.border-amber-100{--tw-border-opacity: 1;border-color:rgb(254 243 199 / var(--tw-border-opacity, 1))}.border-amber-200{--tw-border-opacity: 1;border-color:rgb(253 230 138 / var(--tw-border-opacity, 1))}.border-amber-300{--tw-border-opacity: 1;border-color:rgb(252 211 77 / var(--tw-border-opacity, 1))}.border-amber-400{--tw-border-opacity: 1;border-color:rgb(251 191 36 / var(--tw-border-opacity, 1))}.border-blue-100{--tw-border-opacity: 1;border-color:rgb(219 234 254 / var(--tw-border-opacity, 1))}.border-blue-400{--tw-border-opacity: 1;border-color:rgb(96 165 250 / var(--tw-border-opacity, 1))}.border-emerald-100{--tw-border-opacity: 1;border-color:rgb(209 250 229 / var(--tw-border-opacity, 1))}.border-emerald-200{--tw-border-opacity: 1;border-color:rgb(167 243 208 / var(--tw-border-opacity, 1))}.border-emerald-300{--tw-border-opacity: 1;border-color:rgb(110 231 183 / var(--tw-border-opacity, 1))}.border-emerald-400{--tw-border-opacity: 1;border-color:rgb(52 211 153 / var(--tw-border-opacity, 1))}.border-emerald-500{--tw-border-opacity: 1;border-color:rgb(16 185 129 / var(--tw-border-opacity, 1))}.border-gray-100{--tw-border-opacity: 1;border-color:rgb(243 244 246 / var(--tw-border-opacity, 1))}.border-gray-200{--tw-border-opacity: 1;border-color:rgb(229 231 235 / var(--tw-border-opacity, 1))}.border-gray-300{--tw-border-opacity: 1;border-color:rgb(209 213 219 / var(--tw-border-opacity, 1))}.border-gray-700{--tw-border-opacity: 1;border-color:rgb(55 65 81 / var(--tw-border-opacity, 1))}.border-green-700{--tw-border-opacity: 1;border-color:rgb(21 128 61 / var(--tw-border-opacity, 1))}.border-rose-200{--tw-border-opacity: 1;border-color:rgb(254 205 211 / var(--tw-border-opacity, 1))}.border-rose-300{--tw-border-opacity: 1;border-color:rgb(253 164 175 / var(--tw-border-opacity, 1))}.border-rose-400{--tw-border-opacity: 1;border-color:rgb(251 113 133 / var(--tw-border-opacity, 1))}.border-sky-200{--tw-border-opacity: 1;border-color:rgb(186 230 253 / var(--tw-border-opacity, 1))}.border-slate-100{--tw-border-opacity: 1;border-color:rgb(241 245 249 / var(--tw-border-opacity, 1))}.border-slate-200{--tw-border-opacity: 1;border-color:rgb(226 232 240 / var(--tw-border-opacity, 1))}.border-transparent{border-color:transparent}.border-white\/10{border-color:#ffffff1a}.border-yellow-300{--tw-border-opacity: 1;border-color:rgb(253 224 71 / var(--tw-border-opacity, 1))}.border-l-\[\#34d399\]{--tw-border-opacity: 1;border-left-color:rgb(52 211 153 / var(--tw-border-opacity, 1))}.border-l-\[\#6366f1\]{--tw-border-opacity: 1;border-left-color:rgb(99 102 241 / var(--tw-border-opacity, 1))}.border-l-\[var\(--spotify-green\)\]{border-left-color:var(--spotify-green)}.border-t-transparent{border-top-color:transparent}.\!bg-\[var\(--bg-interactive\)\]{background-color:var(--bg-interactive)!important}.\!bg-emerald-50{--tw-bg-opacity: 1 !important;background-color:rgb(236 253 245 / var(--tw-bg-opacity, 1))!important}.\!bg-rose-50{--tw-bg-opacity: 1 !important;background-color:rgb(255 241 242 / var(--tw-bg-opacity, 1))!important}.bg-\[\#0891b2\]{--tw-bg-opacity: 1;background-color:rgb(8 145 178 / var(--tw-bg-opacity, 1))}.bg-\[\#0ea5e9\]{--tw-bg-opacity: 1;background-color:rgb(14 165 233 / var(--tw-bg-opacity, 1))}.bg-\[\#0f0f1a\]{--tw-bg-opacity: 1;background-color:rgb(15 15 26 / var(--tw-bg-opacity, 1))}.bg-\[\#111\]{--tw-bg-opacity: 1;background-color:rgb(17 17 17 / var(--tw-bg-opacity, 1))}.bg-\[\#2563eb\]{--tw-bg-opacity: 1;background-color:rgb(37 99 235 / var(--tw-bg-opacity, 1))}.bg-\[\#34d39911\]{background-color:#34d39911}.bg-\[\#34d399\]{--tw-bg-opacity: 1;background-color:rgb(52 211 153 / var(--tw-bg-opacity, 1))}.bg-\[\#7c3aed\]{--tw-bg-opacity: 1;background-color:rgb(124 58 237 / var(--tw-bg-opacity, 1))}.bg-\[\#d1d5db\]\/20{background-color:#d1d5db33}.bg-\[\#d97706\]{--tw-bg-opacity: 1;background-color:rgb(217 119 6 / var(--tw-bg-opacity, 1))}.bg-\[\#dcfce7\]{--tw-bg-opacity: 1;background-color:rgb(220 252 231 / var(--tw-bg-opacity, 1))}.bg-\[\#e11d48\]{--tw-bg-opacity: 1;background-color:rgb(225 29 72 / var(--tw-bg-opacity, 1))}.bg-\[\#e8f5f0\]{--tw-bg-opacity: 1;background-color:rgb(232 245 240 / var(--tw-bg-opacity, 1))}.bg-\[\#ecfdf5\]{--tw-bg-opacity: 1;background-color:rgb(236 253 245 / var(--tw-bg-opacity, 1))}.bg-\[\#ecfeff\]{--tw-bg-opacity: 1;background-color:rgb(236 254 255 / var(--tw-bg-opacity, 1))}.bg-\[\#ef4444\]{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity, 1))}.bg-\[\#eff6ff\]{--tw-bg-opacity: 1;background-color:rgb(239 246 255 / var(--tw-bg-opacity, 1))}.bg-\[\#f0fdf4\]{--tw-bg-opacity: 1;background-color:rgb(240 253 244 / var(--tw-bg-opacity, 1))}.bg-\[\#f43f5e08\]{background-color:#f43f5e08}.bg-\[\#f43f5e\]{--tw-bg-opacity: 1;background-color:rgb(244 63 94 / var(--tw-bg-opacity, 1))}.bg-\[\#f59e0b08\]{background-color:#f59e0b08}.bg-\[\#f59e0b\]{--tw-bg-opacity: 1;background-color:rgb(245 158 11 / var(--tw-bg-opacity, 1))}.bg-\[\#f5f3ff\]{--tw-bg-opacity: 1;background-color:rgb(245 243 255 / var(--tw-bg-opacity, 1))}.bg-\[\#fee2e2\]{--tw-bg-opacity: 1;background-color:rgb(254 226 226 / var(--tw-bg-opacity, 1))}.bg-\[\#fef2f2\]{--tw-bg-opacity: 1;background-color:rgb(254 242 242 / var(--tw-bg-opacity, 1))}.bg-\[\#fef3c7\]{--tw-bg-opacity: 1;background-color:rgb(254 243 199 / var(--tw-bg-opacity, 1))}.bg-\[\#fef9c3\]{--tw-bg-opacity: 1;background-color:rgb(254 249 195 / var(--tw-bg-opacity, 1))}.bg-\[\#fef9ee\]{--tw-bg-opacity: 1;background-color:rgb(254 249 238 / var(--tw-bg-opacity, 1))}.bg-\[\#fff7ed\]{--tw-bg-opacity: 1;background-color:rgb(255 247 237 / var(--tw-bg-opacity, 1))}.bg-\[var\(--amber\)\]{background-color:var(--amber)}.bg-\[var\(--amber-bg\)\]{background-color:var(--amber-bg)}.bg-\[var\(--bg\)\]{background-color:var(--bg)}.bg-\[var\(--bg-base\)\]{background-color:var(--bg-base)}.bg-\[var\(--bg-interactive\)\]{background-color:var(--bg-interactive)}.bg-\[var\(--bg-surface\)\]{background-color:var(--bg-surface)}.bg-\[var\(--bg2\)\]{background-color:var(--bg2)}.bg-\[var\(--blue\)\]{background-color:var(--blue)}.bg-\[var\(--blue-bg\)\]{background-color:var(--blue-bg)}.bg-\[var\(--border\)\]{background-color:var(--border)}.bg-\[var\(--border2\)\]{background-color:var(--border2)}.bg-\[var\(--gold-bg\)\]{background-color:var(--gold-bg)}.bg-\[var\(--green\)\]{background-color:var(--green)}.bg-\[var\(--green-bg\)\]{background-color:var(--green-bg)}.bg-\[var\(--green-l\)\]{background-color:var(--green-l)}.bg-\[var\(--ink\)\]{background-color:var(--ink)}.bg-\[var\(--ink3\)\]{background-color:var(--ink3)}.bg-\[var\(--rose-bg\)\]{background-color:var(--rose-bg)}.bg-\[var\(--spotify-green\)\]{background-color:var(--spotify-green)}.bg-\[var\(--spotify-green-dark\)\]{background-color:var(--spotify-green-dark)}.bg-\[var\(--surface\)\]{background-color:var(--surface)}.bg-\[var\(--violet\)\]{background-color:var(--violet)}.bg-\[var\(--violet-bg\)\]{background-color:var(--violet-bg)}.bg-amber-100{--tw-bg-opacity: 1;background-color:rgb(254 243 199 / var(--tw-bg-opacity, 1))}.bg-amber-200{--tw-bg-opacity: 1;background-color:rgb(253 230 138 / var(--tw-bg-opacity, 1))}.bg-amber-50{--tw-bg-opacity: 1;background-color:rgb(255 251 235 / var(--tw-bg-opacity, 1))}.bg-black\/40{background-color:#0006}.bg-black\/45{background-color:#00000073}.bg-black\/50{background-color:#00000080}.bg-black\/60{background-color:#0009}.bg-blue-100{--tw-bg-opacity: 1;background-color:rgb(219 234 254 / var(--tw-bg-opacity, 1))}.bg-blue-50{--tw-bg-opacity: 1;background-color:rgb(239 246 255 / var(--tw-bg-opacity, 1))}.bg-emerald-100{--tw-bg-opacity: 1;background-color:rgb(209 250 229 / var(--tw-bg-opacity, 1))}.bg-emerald-200{--tw-bg-opacity: 1;background-color:rgb(167 243 208 / var(--tw-bg-opacity, 1))}.bg-emerald-300{--tw-bg-opacity: 1;background-color:rgb(110 231 183 / var(--tw-bg-opacity, 1))}.bg-emerald-400{--tw-bg-opacity: 1;background-color:rgb(52 211 153 / var(--tw-bg-opacity, 1))}.bg-emerald-50{--tw-bg-opacity: 1;background-color:rgb(236 253 245 / var(--tw-bg-opacity, 1))}.bg-emerald-500{--tw-bg-opacity: 1;background-color:rgb(16 185 129 / var(--tw-bg-opacity, 1))}.bg-emerald-600{--tw-bg-opacity: 1;background-color:rgb(5 150 105 / var(--tw-bg-opacity, 1))}.bg-emerald-700{--tw-bg-opacity: 1;background-color:rgb(4 120 87 / var(--tw-bg-opacity, 1))}.bg-gray-100{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.bg-gray-200{--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.bg-gray-50{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.bg-gray-900{--tw-bg-opacity: 1;background-color:rgb(17 24 39 / var(--tw-bg-opacity, 1))}.bg-green-100{--tw-bg-opacity: 1;background-color:rgb(220 252 231 / var(--tw-bg-opacity, 1))}.bg-green-200{--tw-bg-opacity: 1;background-color:rgb(187 247 208 / var(--tw-bg-opacity, 1))}.bg-purple-50{--tw-bg-opacity: 1;background-color:rgb(250 245 255 / var(--tw-bg-opacity, 1))}.bg-red-500{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity, 1))}.bg-rose-100{--tw-bg-opacity: 1;background-color:rgb(255 228 230 / var(--tw-bg-opacity, 1))}.bg-rose-200{--tw-bg-opacity: 1;background-color:rgb(254 205 211 / var(--tw-bg-opacity, 1))}.bg-rose-50{--tw-bg-opacity: 1;background-color:rgb(255 241 242 / var(--tw-bg-opacity, 1))}.bg-sky-50{--tw-bg-opacity: 1;background-color:rgb(240 249 255 / var(--tw-bg-opacity, 1))}.bg-slate-100{--tw-bg-opacity: 1;background-color:rgb(241 245 249 / var(--tw-bg-opacity, 1))}.bg-slate-50{--tw-bg-opacity: 1;background-color:rgb(248 250 252 / var(--tw-bg-opacity, 1))}.bg-transparent{background-color:transparent}.bg-violet-50{--tw-bg-opacity: 1;background-color:rgb(245 243 255 / var(--tw-bg-opacity, 1))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.bg-white\/15{background-color:#ffffff26}.bg-white\/5{background-color:#ffffff0d}.bg-yellow-100{--tw-bg-opacity: 1;background-color:rgb(254 249 195 / var(--tw-bg-opacity, 1))}.bg-yellow-200{--tw-bg-opacity: 1;background-color:rgb(254 240 138 / var(--tw-bg-opacity, 1))}.bg-yellow-400\/10{background-color:#facc151a}.bg-yellow-50{--tw-bg-opacity: 1;background-color:rgb(254 252 232 / var(--tw-bg-opacity, 1))}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.bg-gradient-to-t{background-image:linear-gradient(to top,var(--tw-gradient-stops))}.from-\[var\(--green-bg\)\]{--tw-gradient-from: var(--green-bg) var(--tw-gradient-from-position);--tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-amber-400{--tw-gradient-from: #fbbf24 var(--tw-gradient-from-position);--tw-gradient-to: rgb(251 191 36 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-amber-50{--tw-gradient-from: #fffbeb var(--tw-gradient-from-position);--tw-gradient-to: rgb(255 251 235 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-black\/35{--tw-gradient-from: rgb(0 0 0 / .35) var(--tw-gradient-from-position);--tw-gradient-to: rgb(0 0 0 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-blue-50{--tw-gradient-from: #eff6ff var(--tw-gradient-from-position);--tw-gradient-to: rgb(239 246 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-cyan-50{--tw-gradient-from: #ecfeff var(--tw-gradient-from-position);--tw-gradient-to: rgb(236 254 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-emerald-50{--tw-gradient-from: #ecfdf5 var(--tw-gradient-from-position);--tw-gradient-to: rgb(236 253 245 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-emerald-500{--tw-gradient-from: #10b981 var(--tw-gradient-from-position);--tw-gradient-to: rgb(16 185 129 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-indigo-50{--tw-gradient-from: #eef2ff var(--tw-gradient-from-position);--tw-gradient-to: rgb(238 242 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-orange-50{--tw-gradient-from: #fff7ed var(--tw-gradient-from-position);--tw-gradient-to: rgb(255 247 237 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-pink-50{--tw-gradient-from: #fdf2f8 var(--tw-gradient-from-position);--tw-gradient-to: rgb(253 242 248 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-teal-50{--tw-gradient-from: #f0fdfa var(--tw-gradient-from-position);--tw-gradient-to: rgb(240 253 250 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-violet-50{--tw-gradient-from: #f5f3ff var(--tw-gradient-from-position);--tw-gradient-to: rgb(245 243 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.via-white{--tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), #fff var(--tw-gradient-via-position), var(--tw-gradient-to)}.to-\[var\(--bg-surface\)\]{--tw-gradient-to: var(--bg-surface) var(--tw-gradient-to-position)}.to-amber-50{--tw-gradient-to: #fffbeb var(--tw-gradient-to-position)}.to-cyan-50{--tw-gradient-to: #ecfeff var(--tw-gradient-to-position)}.to-emerald-400{--tw-gradient-to: #34d399 var(--tw-gradient-to-position)}.to-green-50{--tw-gradient-to: #f0fdf4 var(--tw-gradient-to-position)}.to-orange-500{--tw-gradient-to: #f97316 var(--tw-gradient-to-position)}.to-purple-50{--tw-gradient-to: #faf5ff var(--tw-gradient-to-position)}.to-rose-50{--tw-gradient-to: #fff1f2 var(--tw-gradient-to-position)}.to-sky-50{--tw-gradient-to: #f0f9ff var(--tw-gradient-to-position)}.to-teal-50{--tw-gradient-to: #f0fdfa var(--tw-gradient-to-position)}.to-transparent{--tw-gradient-to: transparent var(--tw-gradient-to-position)}.to-violet-50{--tw-gradient-to: #f5f3ff var(--tw-gradient-to-position)}.to-yellow-50{--tw-gradient-to: #fefce8 var(--tw-gradient-to-position)}.fill-\[var\(--ink\)\]{fill:var(--ink)}.fill-\[var\(--ink2\)\]{fill:var(--ink2)}.fill-\[var\(--ink3\)\]{fill:var(--ink3)}.object-contain{-o-object-fit:contain;object-fit:contain}.object-cover{-o-object-fit:cover;object-fit:cover}.\!p-0{padding:0!important}.p-0{padding:0}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-2{padding:.5rem}.p-2\.5{padding:.625rem}.p-3{padding:.75rem}.p-3\.5{padding:.875rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.p-\[18px\]{padding:18px}.px-0\.5{padding-left:.125rem;padding-right:.125rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-3\.5{padding-left:.875rem;padding-right:.875rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-7{padding-left:1.75rem;padding-right:1.75rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-10{padding-top:2.5rem;padding-bottom:2.5rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-14{padding-top:3.5rem;padding-bottom:3.5rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-20{padding-top:5rem;padding-bottom:5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-3\.5{padding-top:.875rem;padding-bottom:.875rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pb-0\.5{padding-bottom:.125rem}.pb-16{padding-bottom:4rem}.pb-2{padding-bottom:.5rem}.pb-2\.5{padding-bottom:.625rem}.pb-3{padding-bottom:.75rem}.pb-4{padding-bottom:1rem}.pl-2{padding-left:.5rem}.pl-4{padding-left:1rem}.pl-7{padding-left:1.75rem}.pl-8{padding-left:2rem}.pl-9{padding-left:2.25rem}.pr-3{padding-right:.75rem}.pr-4{padding-right:1rem}.pt-0\.5{padding-top:.125rem}.pt-1{padding-top:.25rem}.pt-2{padding-top:.5rem}.pt-24{padding-top:6rem}.pt-3{padding-top:.75rem}.pt-3\.5{padding-top:.875rem}.pt-4{padding-top:1rem}.pt-5{padding-top:1.25rem}.pt-6{padding-top:1.5rem}.pt-8{padding-top:2rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.align-baseline{vertical-align:baseline}.align-top{vertical-align:top}.align-middle{vertical-align:middle}.font-display{font-family:var(--font-title)}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.font-serif{font-family:ui-serif,Georgia,Cambria,Times New Roman,Times,serif}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-5xl{font-size:3rem;line-height:1}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[12px\]{font-size:12px}.text-\[13\.5px\]{font-size:13.5px}.text-\[13px\]{font-size:13px}.text-\[14px\]{font-size:14px}.text-\[15px\]{font-size:15px}.text-\[17px\]{font-size:17px}.text-\[18px\]{font-size:18px}.text-\[28px\]{font-size:28px}.text-\[32px\]{font-size:32px}.text-\[8px\]{font-size:8px}.text-\[9px\]{font-size:9px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.\!font-bold{font-weight:700!important}.font-black{font-weight:900}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.not-italic{font-style:normal}.tabular-nums{--tw-numeric-spacing: tabular-nums;font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.leading-5{line-height:1.25rem}.leading-6{line-height:1.5rem}.leading-\[1\.55\]{line-height:1.55}.leading-\[1\.65\]{line-height:1.65}.leading-\[1\.8\]{line-height:1.8}.leading-\[2\]{line-height:2}.leading-none{line-height:1}.leading-relaxed{line-height:1.625}.leading-snug{line-height:1.375}.leading-tight{line-height:1.25}.tracking-\[0\.08em\]{letter-spacing:.08em}.tracking-tight{letter-spacing:-.025em}.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}.tracking-widest{letter-spacing:.1em}.\!text-\[var\(--text-base\)\]{color:var(--text-base)!important}.\!text-amber-600{--tw-text-opacity: 1 !important;color:rgb(217 119 6 / var(--tw-text-opacity, 1))!important}.\!text-emerald-900{--tw-text-opacity: 1 !important;color:rgb(6 78 59 / var(--tw-text-opacity, 1))!important}.\!text-rose-800{--tw-text-opacity: 1 !important;color:rgb(159 18 57 / var(--tw-text-opacity, 1))!important}.text-\[\#047857\]{--tw-text-opacity: 1;color:rgb(4 120 87 / var(--tw-text-opacity, 1))}.text-\[\#059669\]{--tw-text-opacity: 1;color:rgb(5 150 105 / var(--tw-text-opacity, 1))}.text-\[\#065f46\]{--tw-text-opacity: 1;color:rgb(6 95 70 / var(--tw-text-opacity, 1))}.text-\[\#0891b2\]{--tw-text-opacity: 1;color:rgb(8 145 178 / var(--tw-text-opacity, 1))}.text-\[\#0ea5e9\]{--tw-text-opacity: 1;color:rgb(14 165 233 / var(--tw-text-opacity, 1))}.text-\[\#0f0f1a\]{--tw-text-opacity: 1;color:rgb(15 15 26 / var(--tw-text-opacity, 1))}.text-\[\#2563eb\]{--tw-text-opacity: 1;color:rgb(37 99 235 / var(--tw-text-opacity, 1))}.text-\[\#34d399\]{--tw-text-opacity: 1;color:rgb(52 211 153 / var(--tw-text-opacity, 1))}.text-\[\#6366f1\]{--tw-text-opacity: 1;color:rgb(99 102 241 / var(--tw-text-opacity, 1))}.text-\[\#7c3aed\]{--tw-text-opacity: 1;color:rgb(124 58 237 / var(--tw-text-opacity, 1))}.text-\[\#854d0e\]{--tw-text-opacity: 1;color:rgb(133 77 14 / var(--tw-text-opacity, 1))}.text-\[\#92400e\]{--tw-text-opacity: 1;color:rgb(146 64 14 / var(--tw-text-opacity, 1))}.text-\[\#991b1b\]{--tw-text-opacity: 1;color:rgb(153 27 27 / var(--tw-text-opacity, 1))}.text-\[\#b45309\]{--tw-text-opacity: 1;color:rgb(180 83 9 / var(--tw-text-opacity, 1))}.text-\[\#b91c1c\]{--tw-text-opacity: 1;color:rgb(185 28 28 / var(--tw-text-opacity, 1))}.text-\[\#d97706\]{--tw-text-opacity: 1;color:rgb(217 119 6 / var(--tw-text-opacity, 1))}.text-\[\#dc2626\]{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}.text-\[\#f43f5e\]{--tw-text-opacity: 1;color:rgb(244 63 94 / var(--tw-text-opacity, 1))}.text-\[\#f59e0b\]{--tw-text-opacity: 1;color:rgb(245 158 11 / var(--tw-text-opacity, 1))}.text-\[var\(--amber\)\]{color:var(--amber)}.text-\[var\(--blue\)\]{color:var(--blue)}.text-\[var\(--border\)\]{color:var(--border)}.text-\[var\(--cta-accent\)\]{color:var(--cta-accent)}.text-\[var\(--gold\)\]{color:var(--gold)}.text-\[var\(--green\)\]{color:var(--green)}.text-\[var\(--ink\)\]{color:var(--ink)}.text-\[var\(--ink2\)\]{color:var(--ink2)}.text-\[var\(--ink3\)\]{color:var(--ink3)}.text-\[var\(--rose\)\]{color:var(--rose)}.text-\[var\(--spotify-green\)\]{color:var(--spotify-green)}.text-\[var\(--spotify-green-dark\)\]{color:var(--spotify-green-dark)}.text-\[var\(--text-announcement\)\]{color:var(--text-announcement)}.text-\[var\(--text-badge\)\]{color:var(--text-badge)}.text-\[var\(--text-base\)\]{color:var(--text-base)}.text-\[var\(--text-body\)\]{color:var(--text-body)}.text-\[var\(--text-button\)\]{color:var(--text-button)}.text-\[var\(--text-caption\)\]{color:var(--text-caption)}.text-\[var\(--text-feature\)\]{color:var(--text-feature)}.text-\[var\(--text-negative\)\]{color:var(--text-negative)}.text-\[var\(--text-section-title\)\]{color:var(--text-section-title)}.text-\[var\(--text-small\)\]{color:var(--text-small)}.text-\[var\(--text-subdued\)\]{color:var(--text-subdued)}.text-\[var\(--text-warning\)\]{color:var(--text-warning)}.text-\[var\(--violet\)\]{color:var(--violet)}.text-amber-500{--tw-text-opacity: 1;color:rgb(245 158 11 / var(--tw-text-opacity, 1))}.text-amber-600{--tw-text-opacity: 1;color:rgb(217 119 6 / var(--tw-text-opacity, 1))}.text-amber-700{--tw-text-opacity: 1;color:rgb(180 83 9 / var(--tw-text-opacity, 1))}.text-amber-800{--tw-text-opacity: 1;color:rgb(146 64 14 / var(--tw-text-opacity, 1))}.text-amber-900{--tw-text-opacity: 1;color:rgb(120 53 15 / var(--tw-text-opacity, 1))}.text-amber-900\/80{color:#78350fcc}.text-base{color:var(--bg-base)}.text-black{--tw-text-opacity: 1;color:rgb(0 0 0 / var(--tw-text-opacity, 1))}.text-blue-700{--tw-text-opacity: 1;color:rgb(29 78 216 / var(--tw-text-opacity, 1))}.text-blue-800{--tw-text-opacity: 1;color:rgb(30 64 175 / var(--tw-text-opacity, 1))}.text-blue-900\/90{color:#1e3a8ae6}.text-emerald-600{--tw-text-opacity: 1;color:rgb(5 150 105 / var(--tw-text-opacity, 1))}.text-emerald-700{--tw-text-opacity: 1;color:rgb(4 120 87 / var(--tw-text-opacity, 1))}.text-emerald-800{--tw-text-opacity: 1;color:rgb(6 95 70 / var(--tw-text-opacity, 1))}.text-emerald-900{--tw-text-opacity: 1;color:rgb(6 78 59 / var(--tw-text-opacity, 1))}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.text-gray-800{--tw-text-opacity: 1;color:rgb(31 41 55 / var(--tw-text-opacity, 1))}.text-gray-900{--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity, 1))}.text-green-700{--tw-text-opacity: 1;color:rgb(21 128 61 / var(--tw-text-opacity, 1))}.text-green-800{--tw-text-opacity: 1;color:rgb(22 101 52 / var(--tw-text-opacity, 1))}.text-purple-700{--tw-text-opacity: 1;color:rgb(126 34 206 / var(--tw-text-opacity, 1))}.text-red-500{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity, 1))}.text-red-600{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}.text-rose-600{--tw-text-opacity: 1;color:rgb(225 29 72 / var(--tw-text-opacity, 1))}.text-rose-700{--tw-text-opacity: 1;color:rgb(190 18 60 / var(--tw-text-opacity, 1))}.text-rose-800{--tw-text-opacity: 1;color:rgb(159 18 57 / var(--tw-text-opacity, 1))}.text-rose-900{--tw-text-opacity: 1;color:rgb(136 19 55 / var(--tw-text-opacity, 1))}.text-sky-900{--tw-text-opacity: 1;color:rgb(12 74 110 / var(--tw-text-opacity, 1))}.text-slate-400{--tw-text-opacity: 1;color:rgb(148 163 184 / var(--tw-text-opacity, 1))}.text-slate-500{--tw-text-opacity: 1;color:rgb(100 116 139 / var(--tw-text-opacity, 1))}.text-slate-600{--tw-text-opacity: 1;color:rgb(71 85 105 / var(--tw-text-opacity, 1))}.text-slate-700{--tw-text-opacity: 1;color:rgb(51 65 85 / var(--tw-text-opacity, 1))}.text-slate-800{--tw-text-opacity: 1;color:rgb(30 41 59 / var(--tw-text-opacity, 1))}.text-slate-900{--tw-text-opacity: 1;color:rgb(15 23 42 / var(--tw-text-opacity, 1))}.text-violet-700{--tw-text-opacity: 1;color:rgb(109 40 217 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.text-white\/40{color:#fff6}.text-white\/45{color:#ffffff73}.text-white\/50{color:#ffffff80}.text-white\/60{color:#fff9}.text-white\/70{color:#ffffffb3}.text-white\/80{color:#fffc}.text-yellow-800{--tw-text-opacity: 1;color:rgb(133 77 14 / var(--tw-text-opacity, 1))}.underline{text-decoration-line:underline}.line-through{text-decoration-line:line-through}.no-underline{text-decoration-line:none}.decoration-\[var\(--rose\)\]{text-decoration-color:var(--rose)}.decoration-\[var\(--spotify-green\)\]{text-decoration-color:var(--spotify-green)}.decoration-slate-200{text-decoration-color:#e2e8f0}.decoration-2{text-decoration-thickness:2px}.underline-offset-2{text-underline-offset:2px}.underline-offset-4{text-underline-offset:4px}.placeholder-\[var\(--ink3\)\]::-moz-placeholder{color:var(--ink3)}.placeholder-\[var\(--ink3\)\]::placeholder{color:var(--ink3)}.opacity-0{opacity:0}.opacity-30{opacity:.3}.opacity-40{opacity:.4}.opacity-50{opacity:.5}.opacity-55{opacity:.55}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-80{opacity:.8}.opacity-90{opacity:.9}.shadow-2xl{--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / .25);--tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[-4px_0_20px_rgba\(0\,0\,0\,0\.08\)\]{--tw-shadow: -4px 0 20px rgba(0,0,0,.08);--tw-shadow-colored: -4px 0 20px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[-4px_0_24px_rgba\(0\,0\,0\,0\.1\)\]{--tw-shadow: -4px 0 24px rgba(0,0,0,.1);--tw-shadow-colored: -4px 0 24px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_24px_80px_rgba\(0\,0\,0\,0\.18\)\]{--tw-shadow: 0 24px 80px rgba(0,0,0,.18);--tw-shadow-colored: 0 24px 80px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-none{--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[var\(--shadow-heavy\)\]{--tw-shadow-color: var(--shadow-heavy);--tw-shadow: var(--tw-shadow-colored)}.shadow-\[var\(--shadow-medium\)\]{--tw-shadow-color: var(--shadow-medium);--tw-shadow: var(--tw-shadow-colored)}.shadow-\[var\(--shadow-sm\)\]{--tw-shadow-color: var(--shadow-sm);--tw-shadow: var(--tw-shadow-colored)}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.ring{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-1{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-2{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-\[\#34d399\]{--tw-ring-opacity: 1;--tw-ring-color: rgb(52 211 153 / var(--tw-ring-opacity, 1))}.ring-\[rgba\(124\,106\,247\,0\.35\)\]{--tw-ring-color: rgba(124,106,247,.35)}.ring-\[var\(--rose\)\]{--tw-ring-color: var(--rose)}.ring-\[var\(--spotify-green\)\]{--tw-ring-color: var(--spotify-green)}.ring-amber-300{--tw-ring-opacity: 1;--tw-ring-color: rgb(252 211 77 / var(--tw-ring-opacity, 1))}.ring-rose-300{--tw-ring-opacity: 1;--tw-ring-color: rgb(253 164 175 / var(--tw-ring-opacity, 1))}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.blur-2xl{--tw-blur: blur(40px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur{--tw-backdrop-blur: blur(8px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:ease;transition-duration:.2s}.transition-\[background\,border-color\,color\]{transition-property:background,border-color,color;transition-timing-function:ease;transition-duration:.2s}.transition-\[background\,border-color\]{transition-property:background,border-color;transition-timing-function:ease;transition-duration:.2s}.transition-\[background\,color\,border-color\]{transition-property:background,color,border-color;transition-timing-function:ease;transition-duration:.2s}.transition-\[background\,color\]{transition-property:background,color;transition-timing-function:ease;transition-duration:.2s}.transition-\[border-color\,box-shadow\,transform\]{transition-property:border-color,box-shadow,transform;transition-timing-function:ease;transition-duration:.2s}.transition-\[border-color\,box-shadow\]{transition-property:border-color,box-shadow;transition-timing-function:ease;transition-duration:.2s}.transition-\[color\,transform\]{transition-property:color,transform;transition-timing-function:ease;transition-duration:.2s}.transition-\[width\]{transition-property:width;transition-timing-function:ease;transition-duration:.2s}.transition-all{transition-property:all;transition-timing-function:ease;transition-duration:.2s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:ease;transition-duration:.2s}.transition-opacity{transition-property:opacity;transition-timing-function:ease;transition-duration:.2s}.transition-shadow{transition-property:box-shadow;transition-timing-function:ease;transition-duration:.2s}.transition-transform{transition-property:transform;transition-timing-function:ease;transition-duration:.2s}.duration-150{transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.duration-500{transition-duration:.5s}.duration-700{transition-duration:.7s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}.scrollbar-hide{-ms-overflow-style:none;scrollbar-width:none}.scrollbar-hide::-webkit-scrollbar{display:none}[data-theme=light] .spotify-panel,[data-theme=light] .ct-card{border-color:#121212!important;border-width:1.5px}[data-theme=dark] .bg-white,[data-theme=dark] .ct-card{background-color:var(--bg-surface)!important}[data-theme=dark] .bg-slate-50,[data-theme=dark] .bg-gray-50,[data-theme=dark] .bg-slate-100,[data-theme=dark] .bg-gray-100{background-color:var(--bg-interactive)!important}[data-theme=dark] .text-slate-900,[data-theme=dark] .text-slate-800,[data-theme=dark] .text-slate-700,[data-theme=dark] .text-gray-900,[data-theme=dark] .text-gray-800,[data-theme=dark] .text-gray-700{color:var(--text-base)!important}[data-theme=dark] .text-slate-600,[data-theme=dark] .text-slate-500,[data-theme=dark] .text-slate-400,[data-theme=dark] .text-gray-600,[data-theme=dark] .text-gray-500,[data-theme=dark] .text-gray-400{color:var(--text-subdued)!important}[data-theme=dark] .border-slate-200,[data-theme=dark] .border-slate-100,[data-theme=dark] .border-gray-200{border-color:var(--border-button)!important}.text-green-700,.text-green-800,.text-emerald-600,.text-emerald-700,.text-emerald-800{color:var(--spotify-green)!important}[data-theme=dark] .\!bg-emerald-50,[data-theme=dark] .bg-emerald-50,[data-theme=dark] .bg-green-50,[data-theme=dark] .bg-green-100{background-color:var(--green-bg)!important}[data-theme=dark] .border-emerald-500,[data-theme=dark] .border-emerald-600{border-color:var(--spotify-green)!important}.\[-ms-overflow-style\:none\]{-ms-overflow-style:none}.\[scrollbar-color\:var\(--border-button\)_transparent\]{scrollbar-color:var(--border-button) transparent}.\[scrollbar-width\:none\]{scrollbar-width:none}.\[scrollbar-width\:thin\]{scrollbar-width:thin}.modal-enter-active .modal-box,.modal-leave-active .modal-box{transition-property:transform;transition-timing-function:ease;transition-duration:.2s}.modal-enter-from .modal-box,.modal-leave-to .modal-box{--tw-translate-y: .625rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}:root{--spotify-green: #1ed760;--spotify-green-dark: #1db954;--bg-base: #121212;--bg-surface: #181818;--bg-interactive: #1f1f1f;--text-base: #ffffff;--text-subdued: #b3b3b3;--text-bright: #cbcbcb;--text-emphasis: #fdfdfd;--text-negative: #f3727f;--text-warning: #ffa42b;--text-announcement: #539df5;--surface-card: #252525;--surface-card-alt: #272727;--border-button: #4d4d4d;--border-outlined: #7c7c7c;--separator: #b3b3b3;--surface-light: #eeeeee;--shadow-heavy: rgba(0, 0, 0, .5) 0px 8px 24px;--shadow-medium: rgba(0, 0, 0, .3) 0px 8px 8px;--shadow-inset-border: rgb(18, 18, 18) 0px 1px 0px, rgb(124, 124, 124) 0px 0px 0px 1px inset;--radius-minimal: 2px;--radius-subtle: 4px;--radius-standard: 6px;--radius-comfortable: 8px;--radius-panel: 10px;--radius-large: 100px;--radius-pill: 500px;--radius-full-pill: 9999px;--radius-circle: 50%;--text-section-title: 1.5rem;--text-feature: 1.125rem;--text-body: 1rem;--text-button: .875rem;--text-caption: .875rem;--text-small: .75rem;--text-badge: .66rem;--text-micro: .625rem;--tracking-button: 1.4px;--tracking-button-wide: 2px;--font-title: "Open Sans", "Helvetica Neue", helvetica, arial, sans-serif;--font-body: "Open Sans", "Helvetica Neue", helvetica, arial, sans-serif;--font-mono: "Consolas", "Courier New", monospace;--container-max: 1200px;--navbar-height: 64px;--section-padding-y: 80px;--transition-base: .2s ease;--accent: var(--spotify-green);--bg: var(--bg-base);--bg2: var(--bg-interactive);--surface: var(--bg-surface);--surface2: var(--surface-card);--border: var(--border-button);--border2: var(--border-outlined);--ink: var(--text-base);--ink2: var(--text-subdued);--ink3: var(--text-bright);--purple: var(--spotify-green);--purple-l: var(--spotify-green);--purple-d: var(--spotify-green-dark);--purple-bg: rgba(30, 215, 96, .12);--green: var(--spotify-green-dark);--green-l: var(--spotify-green);--green-bg: rgba(30, 215, 96, .12);--amber: var(--text-warning);--amber-l: var(--text-warning);--amber-bg: rgba(255, 164, 43, .12);--blue: var(--text-announcement);--blue-l: var(--text-announcement);--blue-bg: rgba(83, 157, 245, .12);--rose: var(--text-negative);--rose-l: var(--text-negative);--rose-bg: rgba(243, 114, 127, .12);--violet: var(--spotify-green);--violet-l: var(--spotify-green);--violet-bg: rgba(30, 215, 96, .12);--gold: var(--text-warning);--gold-l: var(--text-warning);--gold-bg: rgba(255, 164, 43, .12);--shadow-sm: var(--shadow-medium);--shadow: var(--shadow-medium);--shadow-lg: var(--shadow-heavy);--r: var(--radius-comfortable);--r-sm: var(--radius-standard);--r-lg: var(--radius-panel);--font-display: var(--font-title);--bubble-assistant-bg: var(--surface-card);--bubble-user-bg: var(--spotify-green);--bubble-user-text: #000000;--header-accent-bg: rgba(30, 215, 96, .12);--catbot-header-bg: color-mix(in srgb, var(--spotify-green) 14%, var(--bg-surface));--catbot-title-color: var(--text-base);--catbot-subtitle-color: var(--text-subdued);--catbot-bubble-assistant-bg: var(--bg-interactive);--catbot-bubble-assistant-text: var(--text-base);--section-white: var(--bg-surface);--section-cream: var(--bg-interactive);--section-sky: var(--surface-card);--hero-bg: var(--bg-interactive);--hero-heading: var(--text-base);--hero-subtitle: var(--text-subdued);--cta-accent: var(--spotify-green);--cta-accent-text: #000000}[data-theme=light]{--bg-base: #f5f5f5;--bg-surface: #ffffff;--bg-interactive: #eeeeee;--text-base: #121212;--text-subdued: #6a6a6a;--text-bright: #535353;--text-emphasis: #000000;--surface-card: #ffffff;--surface-card-alt: #fafafa;--border-button: #e5e7eb;--border-outlined: #d1d5db;--separator: #9ca3af;--shadow-heavy: rgba(0, 0, 0, .12) 0px 8px 24px;--shadow-medium: rgba(0, 0, 0, .08) 0px 4px 12px;--shadow-inset-border: rgb(255, 255, 255) 0px 1px 0px, rgb(209, 213, 219) 0px 0px 0px 1px inset;--purple-bg: rgba(30, 215, 96, .1);--green-bg: rgba(30, 215, 96, .1);--amber-bg: rgba(255, 164, 43, .1);--blue-bg: rgba(83, 157, 245, .1);--rose-bg: rgba(243, 114, 127, .1);--violet-bg: rgba(30, 215, 96, .1);--gold-bg: rgba(255, 164, 43, .1);--bubble-assistant-bg: #ffffff;--bubble-user-bg: var(--spotify-green);--bubble-user-text: #000000;--header-accent-bg: rgba(30, 215, 96, .08);--catbot-header-bg: color-mix(in srgb, var(--spotify-green) 10%, var(--bg-surface));--catbot-title-color: var(--text-base);--catbot-subtitle-color: var(--text-subdued);--catbot-bubble-assistant-bg: color-mix(in srgb, var(--spotify-green) 8%, var(--bg-surface));--catbot-bubble-assistant-text: var(--text-base);--section-white: #ffffff;--section-cream: #eeeeee;--section-sky: #eeeeee;--hero-bg: var(--bg-surface);--hero-heading: var(--text-base);--hero-subtitle: var(--text-subdued);--cta-accent: var(--spotify-green);--cta-accent-text: #000000;--border-button: #121212;--border-outlined: #292929}html{color-scheme:dark}[data-theme=light]{color-scheme:light}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px}body{font-family:var(--font-body);font-size:var(--text-body);font-weight:400;line-height:normal;background:var(--bg-base);color:var(--text-base);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-family:var(--font-title);font-weight:600;color:var(--text-base);line-height:normal}[data-theme=light] h1,[data-theme=light] h2,[data-theme=light] h3,[data-theme=light] h4,[data-theme=light] h5,[data-theme=light] h6{color:var(--text-emphasis)}.page-header{margin-bottom:1.5rem}.page-header h1{font-family:var(--font-display);font-size:var(--text-section-title);font-weight:700;color:var(--ink);line-height:normal}.page-header .page-subtitle{font-size:var(--text-caption);color:var(--ink2);margin-top:4px}.page-header--row{display:flex;flex-wrap:wrap;align-items:flex-end;gap:12px}.hub-page{margin:-16px -16px 0;width:calc(100% + 32px)}@media (min-width: 768px){.hub-page{margin:-24px -24px 0;width:calc(100% + 48px)}}.spotify-panel{border-radius:var(--radius-panel);border:1px solid var(--border-button);background:var(--bg-surface);overflow:hidden;box-shadow:var(--shadow-medium)}.spotify-panel__header{padding:20px 24px 16px;border-bottom:1px solid var(--border-button)}.spotify-panel__tabs{padding:12px 20px;border-bottom:1px solid var(--border-button);background:var(--bg-base);overflow-x:auto;-webkit-overflow-scrolling:touch}.spotify-panel__tabs>.inline-flex{min-width:-moz-max-content;min-width:max-content}.spotify-panel__body{padding:20px 24px 24px;background:var(--bg-base)}.hub-card-stack{display:flex;flex-direction:column;gap:12px;padding:16px 20px 20px}.stat-pill-inline{display:inline-flex;align-items:center;gap:6px;border-radius:var(--radius-large);border:1px solid var(--border-button);background:var(--bg-interactive);padding:6px 12px;font-size:12px;color:var(--ink2)}.stat-pill-inline strong{color:var(--ink)}h1{font-size:var(--text-section-title)}h2{font-size:var(--text-feature);font-weight:600;line-height:1.3}h3{font-size:var(--text-body);font-weight:700}p,li{font-size:var(--text-body);color:var(--text-base)}small,.text-caption{font-size:var(--text-caption);color:var(--text-subdued)}a{color:var(--text-subdued);transition:color var(--transition-base)}a:hover{color:var(--text-base)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--ink3)}@keyframes fadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pulse-idle{0%,to{box-shadow:0 0 #e0578066}50%{box-shadow:0 0 0 14px #e0578000}}@keyframes pulse-record{0%,to{box-shadow:0 0 #ff3b3b80}50%{box-shadow:0 0 0 20px #ff3b3b00}}@keyframes waveBar{0%,to{transform:scaleY(.3)}50%{transform:scaleY(1)}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-enter-active{animation:fadeUp .3s ease both}.page-leave-active{animation:fadeIn .15s ease reverse both}.flashcard-container{perspective:1200px}.flashcard-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .6s cubic-bezier(.4,0,.2,1)}.flashcard-inner.flipped{transform:rotateY(180deg)}.card-face{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:var(--r);overflow:hidden}.card-back-face{transform:rotateY(180deg)}.waveform-bar{flex:1;border-radius:2px;background:#fff3;transition:background .15s;min-height:4px;transform-origin:bottom}.waveform-bar.played{background:var(--green-l)}.waveform-bar.current{background:#fff}.waveform-bar.playing{animation:waveBar .6s ease-in-out infinite}.record-btn-idle{animation:pulse-idle 2.5s infinite}.record-btn-active{background:#ff3b3b!important;animation:pulse-record 1s infinite}.heatmap-day{aspect-ratio:1;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500;cursor:pointer;transition:transform .15s,box-shadow .15s;background:var(--bg2);color:var(--ink3);position:relative}.heatmap-day:hover{transform:scale(1.12);z-index:2}.heatmap-day.empty{opacity:0;pointer-events:none}.heatmap-day.today{background:var(--ink);color:#fff;font-weight:700}.heatmap-day.done-1{background:#bbf7d0;color:var(--green)}.heatmap-day.done-2{background:var(--green-l);color:#fff}.heatmap-day.done-3{background:var(--green);color:#fff}.ctrl-btn{display:flex;height:2.25rem;width:2.25rem;flex-shrink:0;cursor:pointer;align-items:center;justify-content:center;border-radius:9999px;border-width:0px;font-size:15px;--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1));transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:ease;transition-duration:.2s;background:#ffffff1f}.ctrl-btn:hover{background:#ffffff38}.ctrl-btn.play{height:2.75rem;width:2.75rem;background:var(--green-l)}.ctrl-btn.play:hover{background:#3da771}.transcript-html mark{font-weight:600}.progress-fill-shimmer{position:relative;overflow:hidden}.progress-fill-shimmer:after{content:"";position:absolute;top:0;left:-100%;width:200%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.15) 50%,transparent 100%);animation:shimmer 2s infinite}@keyframes shimmer{to{left:100%}}.hl-yellow{background:#fef08a;border-radius:2px}.hl-green{background:#bbf7d0;border-radius:2px}.hl-rose{background:#fecdd3;border-radius:2px}.font-display{font-family:var(--font-display)}.font-mono{font-family:var(--font-mono)}.ct-card{background:var(--bg-surface);border:1px solid var(--border-button);border-radius:var(--radius-comfortable);box-shadow:var(--shadow-medium);transition:background var(--transition-base),box-shadow var(--transition-base),transform var(--transition-base),border-color var(--transition-base)}.ct-card:hover{background:var(--bg-interactive);box-shadow:var(--shadow-heavy);transform:translateY(-2px)}.ct-badge{display:inline-flex;align-items:center;border-radius:var(--radius-full-pill);padding:2px 10px;font-size:var(--text-badge);font-weight:600;line-height:1.33;text-transform:capitalize;background:#1ed76026;color:var(--spotify-green)}.ct-badge-black{background:var(--bg-interactive);color:var(--text-base)}.ct-badge-gray{background:var(--surface-card);color:var(--text-subdued)}.ct-btn,.btn,.sh-btn,.sh-tab,.theme-toggle-btn,.history-filter-btn{transition:var(--transition-base)}.ct-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border-radius:var(--radius-full-pill);padding:8px 16px;font-size:var(--text-button);font-weight:700;letter-spacing:.14px;cursor:pointer;transition:background var(--transition-base),color var(--transition-base),border-color var(--transition-base),transform var(--transition-base);border:1px solid transparent;background:var(--bg-interactive);color:var(--text-subdued)}.ct-btn:hover{background:var(--surface-card);color:var(--text-base)}.ct-btn-primary{background:var(--spotify-green);color:#000;border-color:transparent;text-transform:uppercase;letter-spacing:var(--tracking-button)}.ct-btn-primary:hover{background:var(--spotify-green-dark);color:#000;transform:scale(1.02)}.ct-btn-outline{background:transparent;color:var(--text-base);border:1px solid var(--border-outlined)}.ct-btn-outline:hover{background:var(--bg-interactive);border-color:var(--text-base)}.ct-input{border:none;border-radius:var(--radius-pill);padding:12px 20px;font-size:var(--text-button);outline:none;font-family:var(--font-body);background:var(--bg-interactive);color:var(--text-base);box-shadow:var(--shadow-inset-border);transition:box-shadow var(--transition-base),outline var(--transition-base)}.ct-input:focus{outline:1px solid var(--text-base);box-shadow:var(--shadow-inset-border)}.ct-input::-moz-placeholder{color:var(--text-subdued)}.ct-input::placeholder{color:var(--text-subdued)}.ct-select{width:100%;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;border-radius:var(--radius-pill);background:var(--bg-interactive) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23b3b3b3' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 16px center;padding:12px 40px 12px 16px;font-size:var(--text-button);font-family:inherit;font-weight:500;color:var(--text-base);outline:none;box-shadow:var(--shadow-inset-border);transition:box-shadow var(--transition-base),outline var(--transition-base)}.ct-select:focus{outline:1px solid var(--text-base)}.ct-select:disabled{cursor:not-allowed;opacity:.55}.card{background:var(--bg-surface);border:none;border-radius:var(--radius-comfortable);box-shadow:var(--shadow-medium);transition:background var(--transition-base),box-shadow var(--transition-base),transform var(--transition-base)}.card:hover{background:var(--bg-interactive);box-shadow:var(--shadow-heavy)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border-radius:var(--radius-full-pill);padding:8px 16px;font-size:var(--text-button);font-weight:700;cursor:pointer;border:1px solid transparent;transition:background var(--transition-base),color var(--transition-base),border-color var(--transition-base),transform var(--transition-base);background:var(--bg-interactive);color:var(--text-subdued)}.btn-primary{background:var(--spotify-green);color:#000;text-transform:uppercase;letter-spacing:var(--tracking-button)}.btn-primary:hover{background:var(--spotify-green-dark);transform:scale(1.02)}.btn-secondary{background:transparent;color:var(--text-base);border:1px solid var(--border-outlined)}.btn-secondary:hover{background:var(--bg-interactive)}.btn-danger{background:transparent;color:var(--text-negative);border:1px solid var(--text-negative)}.btn-danger:hover{background:var(--rose-bg)}.btn-sm{padding:5px 12px;font-size:var(--text-small)}.btn-lg{padding:12px 32px;font-size:var(--text-body)}.page-wrapper{padding:24px}@media (min-width: 640px){.page-wrapper{padding:32px}}@media (min-width: 1024px){.page-wrapper{padding:40px}}.container,.app-container{width:100%;max-width:var(--container-max);margin-left:auto;margin-right:auto;padding-left:24px;padding-right:24px}.app-navbar{height:var(--navbar-height);background:var(--bg-surface);border-bottom:1px solid var(--border-button)}.section-base{padding-top:var(--section-padding-y);padding-bottom:var(--section-padding-y);background:var(--bg-base)}.section-surface{padding-top:var(--section-padding-y);padding-bottom:var(--section-padding-y);background:var(--bg-surface)}.section-elevated{padding-top:var(--section-padding-y);padding-bottom:var(--section-padding-y);background:var(--bg-interactive)}.section-white{padding-top:var(--section-padding-y);padding-bottom:var(--section-padding-y);background:var(--section-white)}.section-cream{padding-top:var(--section-padding-y);padding-bottom:var(--section-padding-y);background:var(--section-cream)}.section-sky{padding-top:var(--section-padding-y);padding-bottom:var(--section-padding-y);background:var(--section-sky)}.section-hero{padding-top:var(--section-padding-y);padding-bottom:var(--section-padding-y);background:var(--hero-bg);color:var(--text-base)}.section-hero h1,.section-hero h2{color:var(--text-base);font-size:var(--text-section-title);font-weight:700;line-height:normal}.section-hero .hero-subtitle{font-size:var(--text-caption);color:var(--text-subdued);margin-top:4px}.section-hero .btn-primary,.section-hero .ct-btn-primary,.section-hero .btn-hero-cta{background:var(--cta-accent);color:var(--cta-accent-text);font-size:var(--text-button);font-weight:700;letter-spacing:var(--tracking-button);transition:var(--transition-base)}.section-hero .btn-primary:hover,.section-hero .ct-btn-primary:hover,.section-hero .btn-hero-cta:hover{filter:brightness(1.06)}.section-compact{padding-top:48px;padding-bottom:48px}.section-hero.section-compact h1{font-size:var(--text-section-title)}.wave-divider{display:block;width:100%;height:48px;line-height:0;overflow:hidden}.wave-divider svg{display:block;width:100%;height:48px}.exam-container{width:100%;max-width:1400px;margin-left:auto;margin-right:auto;padding-left:1.25rem;padding-right:1.25rem}@media (min-width: 640px){.exam-container{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width: 1024px){.exam-container{padding-left:2rem;padding-right:2rem}}.slide-enter-active,.slide-leave-active{transition:all .2s ease}.slide-enter-from,.slide-leave-to{opacity:0;transform:translate(20px)}.writing-prompt-html p{margin-bottom:.75rem;font-size:13px;line-height:1.65}.writing-prompt-html em{font-style:italic}.writing-prompt-html strong{font-weight:600}.vocab-mode .vocab-word{cursor:pointer}.vocab-mode .vocab-underline{text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--spotify-green);color:var(--spotify-green)}.answer-mark{border-radius:3px;background:#fef08a;padding:1px 2px;font-weight:600}.skill-search-wrap{position:relative;align-self:flex-start;width:100%;max-width:100%;min-width:0}@media (min-width: 640px){.skill-search-wrap{min-width:240px;width:auto}}.skill-search-icon{position:absolute;top:50%;left:.75rem;transform:translateY(-50%);color:var(--ink3);pointer-events:none}.skill-search-input{width:100%;border:none;border-radius:var(--radius-pill);background:var(--bg-interactive);padding:.5rem .75rem .5rem 2.1rem;font-size:var(--text-button);color:var(--text-base);outline:none;box-shadow:var(--shadow-inset-border);transition:box-shadow var(--transition-base),outline var(--transition-base)}.skill-search-input:focus{outline:1px solid var(--text-base)}.page-wrapper--constrained{max-width:1280px;margin-left:auto;margin-right:auto}.auth-page{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;background:var(--bg-base);color:var(--text-base)}.auth-page--centered{grid-template-columns:1fr;place-items:center;padding:24px}.auth-page--centered .auth-card{max-width:480px;width:100%;border-right:none;border:1px solid var(--border-button);border-radius:var(--radius-panel);box-shadow:var(--shadow-medium)}.auth-card{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:48px clamp(24px,5vw,64px);background:var(--bg-surface);border-right:1px solid var(--border-button)}.auth-card>*{width:100%;max-width:420px}.auth-logo{margin-bottom:32px}.logo-mark{font-size:24px;font-weight:700;color:var(--text-base);letter-spacing:-.02em}.logo-mark span{color:var(--spotify-green)}.logo-sub{font-size:11px;color:var(--text-subdued);letter-spacing:.1em;text-transform:uppercase;margin-top:4px}.auth-title{font-size:28px;font-weight:700;color:var(--text-base);margin-bottom:6px}.auth-sub{font-size:14px;color:var(--text-subdued);margin-bottom:28px;line-height:1.5}.auth-page .form-group{margin-bottom:16px}.auth-page .form-label{display:block;font-size:12px;font-weight:600;color:var(--text-subdued);margin-bottom:6px}.auth-page .form-input,.auth-page select.form-input{width:100%;padding:12px 18px;border:none;border-radius:var(--radius-comfortable);font-size:14px;font-family:inherit;color:var(--text-base);background:var(--bg-interactive);box-shadow:var(--shadow-inset-border);outline:none;transition:box-shadow var(--transition-base),outline var(--transition-base)}.auth-page .form-input::-moz-placeholder{color:var(--text-subdued)}.auth-page .form-input::placeholder{color:var(--text-subdued)}.auth-page .form-input:focus,.auth-page select.form-input:focus{outline:1px solid var(--spotify-green);box-shadow:var(--shadow-inset-border)}.auth-page .error-msg{font-size:13px;color:var(--text-negative);background:var(--rose-bg);padding:10px 14px;border-radius:var(--radius-comfortable);border:1px solid color-mix(in srgb,var(--text-negative) 25%,transparent);margin-bottom:12px}.auth-success-msg,.auth-page .success-msg{margin-bottom:12px;padding:10px 14px;border-radius:var(--radius-comfortable);border:1px solid color-mix(in srgb,var(--spotify-green) 35%,transparent);background:var(--green-bg);text-align:center;font-size:13px;color:var(--spotify-green-dark)}[data-theme=dark] .auth-success-msg,[data-theme=dark] .auth-page .success-msg{color:var(--spotify-green)}.auth-page .btn-primary{width:100%;padding:12px 24px;border-radius:var(--radius-full-pill);background:var(--spotify-green);color:#000;font-size:var(--text-button);font-weight:700;text-transform:uppercase;letter-spacing:var(--tracking-button);border:none;cursor:pointer;font-family:inherit;transition:background var(--transition-base),transform var(--transition-base);margin-top:4px}.auth-page .btn-primary:hover:not(:disabled){background:var(--spotify-green-dark);transform:scale(1.02)}.auth-page .btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-google-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:11px 18px;border:none;border-radius:var(--radius-full-pill);background:var(--bg-interactive);color:var(--text-base);font-size:14px;font-weight:600;cursor:pointer;box-shadow:var(--shadow-inset-border);transition:box-shadow var(--transition-base),outline var(--transition-base);margin-bottom:4px}.auth-google-btn:hover:not(:disabled){outline:1px solid var(--border-outlined)}.auth-google-btn:disabled{opacity:.6;cursor:not-allowed}.auth-divider{display:flex;align-items:center;gap:12px;margin:16px 0 8px;color:var(--text-subdued);font-size:12px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border-button)}.auth-footer{margin-top:24px;font-size:13px;color:var(--text-subdued);text-align:center}.auth-footer--stack{display:flex;flex-direction:column;align-items:center;gap:8px}.auth-link{color:var(--spotify-green);font-weight:600;text-decoration:none;margin-left:4px;background:none;border:none;cursor:pointer;font-family:inherit;font-size:inherit;padding:0}.auth-link:hover:not(:disabled){text-decoration:underline}.auth-link:disabled{opacity:.5;cursor:not-allowed}.auth-deco{display:flex;align-items:center;justify-content:center;padding:48px clamp(24px,5vw,60px);position:relative;overflow:hidden;background:linear-gradient(155deg,color-mix(in srgb,var(--spotify-green) 14%,var(--bg-interactive)) 0%,var(--bg-base) 55%,var(--bg-surface) 100%)}[data-theme=light] .auth-deco{background:linear-gradient(155deg,color-mix(in srgb,var(--spotify-green) 18%,var(--bg-interactive)) 0%,var(--bg-base) 50%,color-mix(in srgb,var(--spotify-green) 6%,var(--bg-surface)) 100%)}.auth-deco:before{content:"";position:absolute;bottom:-80px;right:-60px;width:400px;height:400px;background:radial-gradient(circle,color-mix(in srgb,var(--spotify-green) 22%,transparent) 0%,transparent 70%);pointer-events:none}.auth-deco:after{content:"";position:absolute;top:-80px;left:-60px;width:300px;height:300px;background:radial-gradient(circle,color-mix(in srgb,var(--text-announcement) 14%,transparent) 0%,transparent 70%);pointer-events:none}.deco-content{position:relative;z-index:1;max-width:400px}.deco-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--radius-full-pill);background:var(--green-bg);color:var(--spotify-green);font-size:12px;font-weight:600;margin-bottom:20px;border:1px solid color-mix(in srgb,var(--spotify-green) 30%,transparent)}.deco-title{font-size:clamp(28px,4vw,36px);font-weight:700;color:var(--text-base);line-height:1.2;margin-bottom:28px}.deco-features{display:flex;flex-direction:column;gap:12px}.deco-feature{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text-subdued)}.feature-check{width:20px;height:20px;border-radius:50%;background:var(--spotify-green);color:#000;display:flex;align-items:center;justify-content:center;flex-shrink:0}.auth-register .auth-card{padding:40px clamp(24px,5vw,56px)}.auth-register .auth-logo{margin-bottom:24px}.auth-register .auth-title{font-size:26px}.auth-register .auth-sub{font-size:13px;margin-bottom:24px}.auth-register .form-group{margin-bottom:14px}.auth-register .form-label{margin-bottom:5px}.auth-register .form-input{padding:11px 16px;font-size:13px}.auth-register .btn-primary{font-size:14px}.auth-register .auth-footer{margin-top:20px}.target-row{display:flex;gap:12px}.milestone-list{display:flex;flex-direction:column;gap:14px}.milestone{display:flex;align-items:center;gap:12px}.milestone-band{font-size:16px;font-weight:700;color:var(--spotify-green);width:36px;flex-shrink:0}.milestone-bar{flex:1;height:6px;background:color-mix(in srgb,var(--text-base) 12%,transparent);border-radius:99px;overflow:hidden}.milestone-fill{height:100%;background:linear-gradient(to right,var(--spotify-green),var(--text-announcement));border-radius:99px}.milestone-label{font-size:12px;color:var(--text-subdued);width:80px}.auth-verify-icon{display:flex;height:64px;width:64px;align-items:center;justify-content:center;border-radius:50%;background:var(--green-bg);border:1px solid color-mix(in srgb,var(--spotify-green) 40%,transparent);margin:0 auto 20px}@media (max-width: 768px){.auth-page{grid-template-columns:1fr}.auth-deco{display:none}.auth-card{padding:40px 24px;border-right:none;min-height:100vh}.target-row{flex-direction:column;gap:0}}.history-filter-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:20px;border:1.5px solid var(--border2);background:var(--surface);color:var(--ink2);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s}.history-filter-btn:hover{border-color:var(--spotify-green);color:var(--spotify-green)}.history-filter-btn.active{border-color:var(--spotify-green);background:var(--green-bg);color:var(--spotify-green);font-weight:700}.filter-icon{display:flex;align-items:center}.history-action-btn{display:inline-flex;align-items:center;gap:5px;margin-left:0;white-space:nowrap;border-radius:var(--r-sm);border:1px solid var(--border2);background:transparent;padding:6px 12px;font-size:12px;font-weight:600;color:var(--ink2);cursor:pointer;transition:all .15s;text-decoration:none}.history-action-btn:hover{background:var(--bg2)}.history-action-btn--primary{border-color:var(--spotify-green);background:var(--bg-surface);color:var(--spotify-green)}.history-action-btn--primary:hover{background:var(--bg-interactive)}[data-theme=dark] .history-action-btn--primary{border-color:var(--border2);background:var(--bg);color:var(--spotify-green)}@media (min-width: 640px){.history-action-btn{margin-left:8px}}.lb-page{max-width:700px;margin-left:auto;margin-right:auto;width:100%}.podium{display:flex;align-items:flex-end;justify-content:center;gap:12px;padding:0 16px}.podium-item{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;max-width:160px}.podium-crown{margin-bottom:-4px}.podium-avatar-wrap{position:relative}.podium-avatar{width:56px;height:56px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid var(--border)}.podium-avatar--large{width:68px;height:68px}.podium-rank{position:absolute;bottom:-4px;right:-4px;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;border:1.5px solid white}.rank-1{background:#f59e0b}.rank-2{background:#9ca3af}.rank-3{background:#b45309}.podium-name{font-size:12px;font-weight:500;color:var(--ink);text-align:center;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.podium-xp{font-size:11px;font-weight:600;color:var(--ink3)}.xp-gold{color:#d97706}.podium-bar{width:100%;border-radius:8px 8px 0 0}.bar-1{height:64px;background:linear-gradient(180deg,#fde68a,#f59e0b)}.bar-2{height:48px;background:linear-gradient(180deg,#e5e7eb,#9ca3af)}.bar-3{height:36px;background:linear-gradient(180deg,#fde8c8,#b45309)}.lb-row{display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border);padding:12px 20px;transition:background .15s}.lb-row:last-child{border-bottom:none}.lb-row:hover{background:var(--bg)}.lb-row--me{background:var(--green-bg)}.lb-rank{width:32px;text-align:right}.lb-rank-num{font-size:14px;font-weight:700;color:var(--ink3)}.lb-avatar{width:36px;height:36px;border-radius:50%;-o-object-fit:cover;object-fit:cover;flex-shrink:0}.lb-info{flex:1;min-width:0}.lb-name{font-size:13px;font-weight:600;color:var(--ink);display:flex;align-items:center;gap:6px}.lb-streak{font-size:11px;color:var(--ink3);display:flex;align-items:center;gap:3px;margin-top:2px}.lb-you-badge{font-size:10px;font-weight:700;background:#d1fae5;color:#065f46;padding:1px 6px;border-radius:20px}.lb-xp-col{display:flex;flex-direction:column;align-items:flex-end;gap:4px;min-width:100px}.lb-xp-bar-wrap{width:80px;height:4px;background:var(--bg2);border-radius:2px;overflow:hidden}.lb-xp-bar{height:100%;background:#34d399;border-radius:2px;transition:width .8s ease}.lb-xp-num{font-size:12px;font-weight:700;color:var(--ink2)}.profile-page{max-width:900px;margin-left:auto;margin-right:auto;width:100%}.profile-stack{display:flex;flex-direction:column;gap:14px}.profile-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:20px}@media (max-width: 767px){.profile-grid,.profile-page .form-row{grid-template-columns:1fr}.stats-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.profile-card{padding:20px}}.profile-page .card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-sm)}.profile-card{padding:28px}.avatar-section{display:flex;align-items:center;gap:16px;margin-bottom:16px}.avatar-wrapper{position:relative;width:72px;height:72px;border-radius:50%;flex-shrink:0}.avatar-img{width:72px;height:72px;border-radius:50%;-o-object-fit:cover;object-fit:cover;display:block}.avatar-upload-overlay{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:#00000073;display:flex;align-items:center;justify-content:center;color:#fff;opacity:0;cursor:pointer;transition:opacity .18s}.avatar-wrapper:hover .avatar-upload-overlay{opacity:1}.upload-status{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--ink3);margin-bottom:8px}.user-name{font-size:18px;font-weight:600;color:var(--ink)}.user-email{font-size:13px;color:var(--ink3);margin-top:2px}.user-level-badge{margin-top:6px;font-size:11px;font-weight:600;color:var(--green);display:flex;align-items:center;gap:4px}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding-top:20px;border-top:1px solid var(--border);margin-top:16px}.stat-box{text-align:center}.stat-val{font-size:24px;font-weight:700;color:var(--ink)}.stat-label{font-size:11px;color:var(--ink3);margin-top:2px}.profile-page .section-title{font-size:16px;font-weight:600;color:var(--ink)}.profile-page .form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.profile-page .form-label{font-size:12px;font-weight:600;color:var(--ink2)}.profile-page .form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.profile-page .form-input{padding:9px 12px;border:1.5px solid var(--border2);border-radius:var(--r-sm);font-size:13px;font-family:inherit;color:var(--ink);background:var(--bg);outline:none;transition:border-color .18s}.profile-page .form-input:focus{border-color:var(--green-l)}.profile-page .form-input:disabled{opacity:.5;cursor:not-allowed}.profile-page .form-actions{display:flex;justify-content:space-between;margin-top:20px}.profile-page .btn-primary{padding:9px 20px;border-radius:var(--r-sm);background:var(--green);color:#fff;font-size:13px;font-weight:600;border:none;cursor:pointer;font-family:inherit;transition:all .18s}.profile-page .btn-primary:hover{background:var(--spotify-green-dark)}.profile-page .btn-primary:disabled{opacity:.6;cursor:not-allowed}.profile-page .btn-danger{padding:9px 20px;border-radius:var(--r-sm);background:transparent;color:var(--rose);font-size:13px;font-weight:600;border:1px solid var(--rose-l);cursor:pointer;font-family:inherit;transition:all .18s}.profile-page .btn-danger:hover{background:var(--rose-bg)}.profile-page .error-msg{margin-top:10px;font-size:13px;color:var(--rose)}.profile-page .success-msg{margin-top:10px;font-size:13px;color:var(--green)}.avatar-info{flex:1;min-width:0}.profile-page .badges-section,.profile-password-card{padding:24px}.profile-ai-hint{margin:0 0 16px;font-size:12px;line-height:1.55;color:var(--ink3)}.profile-ai-note{margin:-8px 0 12px;font-size:11px;color:var(--ink3)}.profile-page .badges-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}.profile-page .badges-subtitle{margin:4px 0 0;font-size:12px;color:var(--ink3);max-width:420px}.profile-page .badges-progress-wrap{min-width:160px;flex:0 0 auto}.profile-page .badges-progress-label{display:flex;justify-content:space-between;gap:8px;font-size:12px;font-weight:600;margin-bottom:6px}.profile-page .badges-progress-bar{height:8px;border-radius:999px;background:var(--border);overflow:hidden}.profile-page .badges-progress-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--spotify-green),var(--spotify-green-dark));transition:width .4s ease}.profile-page .badges-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.profile-page .badges-filter-btn{padding:6px 12px;border-radius:999px;border:1px solid var(--border);background:var(--bg-surface);font-size:12px;font-weight:600;color:var(--ink2);cursor:pointer;font-family:inherit;transition:var(--transition-base)}.profile-page .badges-filter-btn:hover{border-color:var(--spotify-green);color:var(--ink)}.profile-page .badges-filter-btn.active{background:var(--green-bg);border-color:var(--spotify-green);color:var(--spotify-green)}.profile-page .badges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.profile-page .badge-card{display:flex;align-items:flex-start;gap:12px;padding:14px;border-radius:14px;border:1px solid var(--border);background:var(--bg-surface);position:relative;transition:transform var(--transition-base),box-shadow var(--transition-base);cursor:pointer;font-family:inherit;text-align:left;width:100%}.badge-hint-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;background:#0f172a73}.badge-hint-popover{width:min(100%,380px);padding:24px;background:#fff;border-radius:16px;box-shadow:0 20px 50px #0f172a2e;text-align:center}.badge-hint-icon{margin-bottom:12px;display:flex;justify-content:center}.badge-hint-title{margin:0 0 6px;font-size:18px;color:var(--ink)}.badge-hint-desc{margin:0 0 14px;font-size:13px;color:var(--ink3)}.badge-hint-box{text-align:left;padding:12px 14px;border-radius:10px;background:var(--bg);border:1px solid var(--border);font-size:12px;line-height:1.5;color:var(--ink2)}.badge-hint-label{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink3);margin-bottom:6px}.badge-hint-status{margin:12px 0 0;font-size:12px;font-weight:600;color:var(--ink3)}.badge-hint-status--done{color:#059669}.profile-page .badge-card--unlocked{border-color:var(--spotify-green);background:linear-gradient(145deg,var(--green-bg) 0%,var(--bg-surface) 55%);box-shadow:var(--shadow-sm)}.profile-page .badge-card--unlocked:hover{transform:translateY(-2px)}.profile-page .badge-card--locked{opacity:.72;filter:grayscale(.35)}.profile-page .badge-card-icon{font-size:28px;line-height:1;flex-shrink:0}.profile-page .badge-card-body{flex:1;min-width:0}.profile-page .badge-card-title{font-size:13px;font-weight:700;color:var(--ink);margin-bottom:4px}.profile-page .badge-card-desc{font-size:11px;line-height:1.45;color:var(--ink3)}.profile-page .badge-card-check{position:absolute;top:10px;right:10px;width:20px;height:20px;border-radius:50%;background:var(--spotify-green);color:#000;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}.profile-page .badge-card-lock{position:absolute;top:10px;right:10px;font-size:12px;opacity:.5}.quiz-header{margin-bottom:1.5rem}.quiz-back-link{font-size:.9rem;color:var(--color-text-muted);text-decoration:none;display:inline-block;margin-bottom:1rem}.quiz-back-link:hover{color:var(--color-primary)}.quiz-subject{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.quiz-subject h1{margin:0}.quiz-progress-top{margin-bottom:1.5rem}.quiz-progress-text{font-size:.82rem;display:block;margin-top:6px;text-align:right}.quiz-question-card{padding:2rem}.quiz-question-num{font-size:.8rem;font-weight:600;color:var(--color-primary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem}.quiz-question-text{font-size:1.2rem;font-weight:700;line-height:1.5;margin-bottom:1.75rem}.quiz-options-list{display:flex;flex-direction:column;gap:.75rem}.quiz-option-btn{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;width:100%;background:var(--color-surface-2);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;text-align:left;color:var(--color-text);font-family:inherit;font-size:.95rem;transition:all var(--transition-fast)}.quiz-option-btn:hover{border-color:var(--color-primary);background:#7c6af714}.quiz-option-btn.selected{border-color:var(--color-primary);background:#7c6af726}.quiz-option-letter{width:32px;height:32px;border-radius:50%;background:var(--color-surface);border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0;transition:all var(--transition-fast)}.quiz-option-btn.selected .quiz-option-letter{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.quiz-nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:1.5rem}.quiz-dot-indicators{display:flex;gap:6px}.quiz-dot{width:10px;height:10px;border-radius:50%;background:var(--color-surface-2);border:2px solid var(--color-border);cursor:pointer;transition:all .2s;padding:0}.quiz-dot.answered{background:#7c6af766;border-color:var(--color-primary)}.quiz-dot.active{background:var(--color-primary);border-color:var(--color-primary);transform:scale(1.3)}.quiz-runner .reading-passage{max-height:420px;overflow:auto;padding-right:8px}.quiz-runner .reading-paragraph{display:flex;gap:10px;padding:10px 12px;border-radius:12px;border:1px solid transparent;margin-bottom:10px;background:var(--surface)}.quiz-runner .reading-paragraph.is-highlight{border-color:#7c6af759;background:#7c6af714}.quiz-runner .para-tag{min-width:28px;height:22px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--ink2);border:1px solid var(--border2);background:var(--bg)}.passage-title{margin-bottom:12px}.passage-title h1,.passage-title h2,.passage-title h3,.passage-title h4,.passage-title h5,.passage-title h6{font-weight:700;line-height:1.4;color:var(--ink)}.gap-html table,.prose table{width:100%;border-collapse:collapse;margin-bottom:8px}.gap-html td,.gap-html th,.prose td,.prose th{padding:6px 10px;border:1px solid var(--border2);vertical-align:top;font-size:13px}.gap-html h4,.prose h4{text-align:center;font-weight:700;margin:4px 0}.vocab-page{min-height:0;background:transparent;padding:0}.vocab-page--sections .vocab-header{display:none}.vocab-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px;padding:20px 24px;background:#fff;border-radius:16px;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0000000a}.vocab-header__title{font-size:20px;font-weight:800;color:#0f172a}.vocab-header__sub{font-size:13px;color:#64748b;margin-top:2px}.vocab-header__stats{display:flex;gap:10px;flex-wrap:wrap}.stat-pill{display:flex;flex-direction:column;align-items:center;padding:8px 16px;border-radius:10px;border:1.5px solid #e2e8f0;background:#f8fafc;min-width:64px}.stat-pill--green{border-color:#15803d;background:#f0fdf4}.stat-pill--amber{border-color:#d97706;background:#fffbeb}.stat-num{font-size:18px;font-weight:800;color:#0f172a}.stat-lbl{font-size:10px;color:#64748b;text-transform:uppercase;letter-spacing:.06em;margin-top:1px}.stat-pill--green .stat-num{color:#15803d}.stat-pill--amber .stat-num{color:#d97706}.vocab-layout{display:flex;gap:20px;align-items:flex-start}@media (max-width: 767px){.vocab-layout{flex-direction:column;gap:16px}.vocab-sidebar{width:100%!important;flex:none!important}.vocab-main{width:100%;min-width:0}.field-grid{grid-template-columns:1fr!important}}.vocab-layout--study{flex-direction:row;align-items:stretch;gap:0}.vocab-layout--study .vocab-sidebar{min-width:180px;max-width:50%}.vocab-layout--study .vocab-main{min-width:260px}.vocab-layout--resizing{cursor:col-resize;-webkit-user-select:none;-moz-user-select:none;user-select:none}.split-handle{flex-shrink:0;width:10px;margin:0 4px;cursor:col-resize;border-radius:6px;background:transparent;transition:background .15s;position:relative}.split-handle:after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:3px;height:48px;border-radius:3px;background:#e2e8f0;transition:background .15s,height .15s}.split-handle:hover:after,.vocab-layout--resizing .split-handle:after{background:#15803d;height:64px}.vocab-layout--study .topic-list{max-height:min(520px,calc(100vh - 300px));overflow-y:auto}@media (max-width: 768px){.vocab-layout--study{flex-direction:column;gap:16px}.vocab-layout--study .split-handle{display:none}.vocab-layout--study .vocab-sidebar,.vocab-layout--study .vocab-main{flex:none!important;width:100%!important;max-width:none!important}}.vocab-sidebar{width:240px;flex-shrink:0;background:#fff;border-radius:16px;border:1px solid #e2e8f0;overflow:hidden;box-shadow:0 2px 8px #0000000a}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #f1f5f9}.sidebar-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#64748b}.sidebar-add-btn{width:28px;height:28px;border-radius:8px;border:1.5px solid #15803d;background:#f0fdf4;color:#15803d;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.sidebar-add-btn:hover{background:#15803d;color:#fff}.sidebar-loading,.sidebar-empty{padding:16px;font-size:13px;color:#94a3b8;text-align:center;line-height:1.6}.sidebar-error{color:#e11d48;display:flex;flex-direction:column;align-items:center}.link-btn{background:none;border:none;color:#15803d;cursor:pointer;font-weight:600}.topic-list{padding:8px;display:flex;flex-direction:column;gap:2px}.topic-item{display:flex;align-items:center;gap:4px;padding:10px;border-radius:10px;cursor:pointer;transition:all .15s;border:1.5px solid transparent}.topic-item:hover{background:#f8fafc}.topic-item.active{background:#f0fdf4;border-color:#15803d}.topic-item__body{flex:1;min-width:0}.topic-item__name{font-size:13px;font-weight:600;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.topic-item.active .topic-item__name{color:#15803d}.topic-item__count{font-size:10px;color:#94a3b8;margin-top:1px;display:block}.topic-item__menu{flex-shrink:0}.menu-btn{width:24px;height:24px;border-radius:6px;background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}.topic-item:hover .menu-btn{opacity:1}.menu-btn:hover{background:#f1f5f9;color:#475569}.vocab-main{flex:1;min-width:0;background:#fff;border-radius:16px;border:1px solid #e2e8f0;overflow:hidden;box-shadow:0 2px 8px #0000000a}.vocab-main--study{min-height:420px}.main-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #f1f5f9;gap:12px}.main-title{font-size:15px;font-weight:800;color:#0f172a}.main-sub{font-size:12px;color:#94a3b8;margin-top:2px}.main-header-actions{display:flex;align-items:center;gap:12px;flex-shrink:0;flex-wrap:wrap}.word-search-wrap{position:relative;display:flex;align-items:center}.word-search-icon{position:absolute;left:8px;color:#94a3b8;pointer-events:none}.word-search-input{padding:7px 28px 7px 26px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:12px;color:#0f172a;background:#f8fafc;outline:none;width:160px;transition:border-color .15s,width .2s}.word-search-input:focus{border-color:#15803d;width:200px}.word-search-clear{position:absolute;right:6px;background:none;border:none;cursor:pointer;color:#94a3b8;display:flex;align-items:center;padding:2px}.word-search-clear:hover{color:#0f172a}.view-tabs{display:inline-flex;gap:4px;border-radius:10px;border:1px solid var(--border);padding:3px;background:var(--bg-interactive)}.view-tab{padding:6px 14px;font-size:12px;font-weight:600;border:none;border-radius:8px;background:transparent;color:var(--ink3);cursor:pointer;transition:background .15s,color .15s}.view-tab.active{background:var(--spotify-green);color:#000}.add-word-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#15803d;color:#fff;border:none;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.add-word-btn:hover{background:#166534}.word-table{padding:0}.word-table-head{display:flex;gap:0;padding:0 20px;border-bottom:1px solid #f1f5f9;background:#f8fafc}.th{padding:10px 8px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8}.word-row{display:flex;align-items:center;gap:0;padding:0 20px;border-bottom:1px solid #f8fafc;transition:background .1s}.word-row:hover{background:#f8fafc}.td{padding:12px 8px;font-size:13px;color:#374151}.word-cell{display:flex;align-items:center;gap:6px}.word-text{font-weight:700;color:#0f172a}.tts-btn{padding:3px;background:none;border:none;cursor:pointer;color:#94a3b8;border-radius:4px;transition:all .1s}.tts-btn:hover{color:#15803d;background:#f0fdf4}.word-phonetic{font-size:11px;color:#94a3b8;font-style:italic;margin-top:1px}.word-type-pill{display:inline-block;margin-top:3px;padding:1px 8px;background:#dcfce7;color:#15803d;border-radius:6px;font-size:10px;font-weight:600;text-transform:uppercase}.meaning-vi{color:#15803d;font-weight:600}.example-text{color:#64748b;font-size:12px;font-style:italic}.srs-cell{display:flex;flex-direction:column;gap:2px;font-size:11px}.srs-due{color:#b45309;font-weight:700}.srs-ok{color:#64748b}.srs-meta{color:#94a3b8;font-size:10px}.mastery-select{border:1.5px solid #e2e8f0;border-radius:8px;padding:4px 8px;font-size:11px;font-weight:600;background:#f8fafc;cursor:pointer;outline:none;max-width:100%}.mastery--new{border-color:#e2e8f0;color:#94a3b8}.mastery--learning{border-color:#fbbf24;color:#d97706;background:#fffbeb}.mastery--mastered{border-color:#15803d;color:#15803d;background:#f0fdf4}.row-actions{display:flex;gap:4px}.row-action-btn{width:28px;height:28px;border-radius:6px;background:none;border:1px solid #e2e8f0;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#94a3b8;transition:all .15s}.row-action-btn:hover{border-color:#15803d;color:#15803d;background:#f0fdf4}.row-action-btn--del:hover{border-color:#e11d48;color:#e11d48;background:#fff1f2}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 20px;text-align:center}.empty-icon{color:#cbd5e1}.empty-title{font-size:14px;font-weight:600;color:#94a3b8}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;background:#0006;display:flex;align-items:center;justify-content:center;padding:16px}.modal-sm{background:#fff;border-radius:20px;width:100%;max-width:360px;box-shadow:0 24px 80px #0000002e;overflow:hidden}.modal-lg{background:#fff;border-radius:20px;width:100%;max-width:560px;box-shadow:0 24px 80px #0000002e;overflow:hidden}.modal-sm-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid #f1f5f9;font-size:14px;font-weight:700;color:#0f172a}.modal-sm-header button{background:none;border:none;cursor:pointer;color:#94a3b8;padding:4px;border-radius:6px}.modal-sm-header button:hover{background:#f1f5f9}.modal-sm-body{padding:16px 18px}.topic-input{width:100%;border:1.5px solid #e2e8f0;border-radius:10px;padding:10px 14px;font-size:14px;outline:none;font-family:inherit}.topic-input:focus{border-color:#15803d}.modal-lg-body{padding:16px 18px}.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.field{display:flex;flex-direction:column;gap:4px}.col-span-2{grid-column:span 2}.field label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#94a3b8}.field input,.field textarea{border:1.5px solid #e2e8f0;border-radius:10px;padding:8px 12px;font-size:13px;outline:none;font-family:inherit;resize:vertical}.field input:focus,.field textarea:focus{border-color:#15803d}.modal-sm-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 18px;border-top:1px solid #f1f5f9}.btn-cancel{padding:8px 16px;border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc;color:#475569;font-size:13px;cursor:pointer}.btn-green{padding:8px 20px;background:#15803d;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer}.btn-green:disabled{opacity:.4;cursor:not-allowed}.topic-ctx-menu{position:fixed;z-index:10100;background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:4px;box-shadow:0 8px 24px #00000026;min-width:140px}.topic-ctx-menu button{display:flex;align-items:center;gap:8px;width:100%;padding:8px 14px;text-align:left;background:none;border:none;border-radius:6px;font-size:13px;color:#374151;cursor:pointer}.topic-ctx-menu button:hover{background:#f1f5f9}.topic-ctx-menu button.danger{color:#e11d48}.topic-ctx-menu button.danger:hover{background:#fff1f2}.source-badge{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 6px;border-radius:4px;line-height:1.4}.source-badge--reading{background:#e0f2fe;color:#0369a1}.source-badge--listening{background:#fef3c7;color:#92400e}.modal-fade-enter-active,.modal-fade-leave-active{transition:opacity .2s}.modal-fade-enter-from,.modal-fade-leave-to{opacity:0}.popup-fade-enter-active,.popup-fade-leave-active{transition:opacity .15s,transform .15s}.popup-fade-enter-from,.popup-fade-leave-to{opacity:0;transform:scale(.95)}.score-summary{display:flex;align-items:center;gap:16px;padding:14px 18px;background:var(--bg-surface);border:1px solid var(--border);border-radius:14px;margin-bottom:4px;flex-wrap:wrap}.score-ring-wrap{position:relative;flex-shrink:0;width:80px;height:80px}.score-ring-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.score-stats{display:flex;gap:12px;flex-shrink:0}.score-stat{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 14px;border:1.5px solid var(--border);border-radius:10px;background:var(--bg-interactive);min-width:60px}.score-stat--correct{border-color:var(--spotify-green-dark);background:var(--green-bg)}.score-stat--wrong{border-color:var(--rose);background:var(--rose-bg)}.score-stat svg{color:var(--ink3)}.score-stat--correct svg{color:var(--spotify-green-dark)}.score-stat--wrong svg{color:var(--rose)}.score-stat-num{font-size:20px;font-weight:800;color:var(--ink)}.score-stat-lbl{font-size:10px;color:var(--ink3);text-transform:uppercase;letter-spacing:.05em}.score-stat--correct .score-stat-num{color:var(--spotify-green-dark)}.score-stat--wrong .score-stat-num{color:var(--rose)}.part-bars{flex:1;display:flex;flex-direction:column;gap:8px;min-width:160px}.part-bar-item{display:flex;align-items:center;gap:10px}.part-bar-item--clickable{cursor:pointer;padding:6px 8px;margin:-6px -8px;border-radius:8px;transition:background .15s}.part-bar-item--clickable:hover{background:var(--bg2)}.part-bar-item--active{background:var(--green-bg);outline:1px solid var(--spotify-green)}.part-bar-item--active .part-bar-label{color:var(--spotify-green-dark)}.part-bar-label{font-size:11px;font-weight:600;color:var(--ink3);white-space:nowrap;min-width:70px}.part-bar-track{flex:1;height:8px;background:var(--bg-interactive);border-radius:99px;overflow:hidden}.part-bar-fill{height:100%;border-radius:99px;transition:width 1s ease}.part-bar-pct{font-size:11px;font-weight:700;color:var(--ink2);min-width:36px;text-align:right}.review-page-header{background:color-mix(in srgb,var(--bg-surface) 92%,transparent)}.review-back-btn{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--ink3);background:none;border:none;cursor:pointer;padding:6px 10px;border-radius:8px;transition:all .15s}.review-back-btn:hover{background:var(--bg2);color:var(--ink)}.review-score-badge{display:flex;flex-direction:column;align-items:center;border:1px solid var(--border);border-radius:12px;padding:6px 16px;background:var(--bg)}.review-tools-rail{position:sticky;top:120px;align-self:flex-start}@media (max-width: 1023px){.review-layout{flex-direction:column!important}.review-tools-rail{position:static;align-self:stretch;display:flex;justify-content:center;width:100%}.review-split-left{width:100%!important;flex:none!important}.review-split-divider{display:none!important}}.app-main--with-sidebar{margin-left:0}@media (min-width: 1024px){.app-main--with-sidebar.app-main--collapsed{margin-left:64px}.app-main--with-sidebar.app-main--expanded{margin-left:220px}}.app-main__content{overflow-x:hidden}.review-question-card{border:1.5px solid var(--border);border-radius:12px;overflow:hidden;background:var(--bg-surface);transition:border-color .15s}.review-question-card--correct{border-left:4px solid var(--spotify-green)}.review-question-card--wrong{border-left:4px solid var(--rose)}.review-q-header{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border)}.review-q-num{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--ink3);letter-spacing:.06em}.review-q-badge{margin-left:auto;border-radius:99px;padding:2px 10px;font-size:10px;font-weight:700;text-transform:uppercase}.badge-correct{background:var(--green-bg);color:var(--spotify-green-dark)}.badge-wrong{background:var(--rose-bg);color:var(--rose)}.review-explain-btn{display:flex;align-items:center;gap:5px;padding:4px 10px;border-radius:8px;border:1px solid var(--spotify-green-dark);background:var(--green-bg);color:var(--spotify-green-dark);font-size:11px;font-weight:600;cursor:pointer;transition:all .15s}.review-explain-btn:hover,.review-explain-btn.active{background:var(--spotify-green);color:#000}.review-q-text{padding:10px 14px;font-size:13px;color:var(--ink);line-height:1.6;border-bottom:1px solid var(--border)}.review-q-stem{white-space:pre-wrap}.review-answers{padding:10px 14px}.review-answer-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:4px 0;font-size:12px}.review-answer-row--border{border-top:1px solid var(--border);padding-top:8px;margin-top:4px}.review-answer-label{color:var(--ink3)}.review-answer-val{font-weight:700;font-family:monospace}.val-correct{color:var(--spotify-green-dark)}.val-wrong{color:var(--rose)}.explain-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#0000008c;display:flex;align-items:flex-start;justify-content:center;padding:80px 16px 16px}@media (min-width: 640px){.explain-overlay{justify-content:flex-end}}.explain-box{width:min(100%,460px);max-height:calc(100vh - 100px);background:var(--bg-surface);border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow-heavy);display:flex;flex-direction:column;overflow:hidden}.explain-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--bg-interactive)}.explain-title{font-size:14px;font-weight:700;color:var(--ink)}.explain-goto-btn{border:1px solid var(--spotify-green);background:var(--green-bg);color:var(--spotify-green-dark);border-radius:999px;font-size:11px;font-weight:700;padding:4px 10px}.explain-close{background:none;border:none;cursor:pointer;color:var(--ink3);padding:4px;border-radius:6px}.explain-close:hover{background:var(--bg2)}.explain-body{flex:1;overflow-y:auto;padding:16px 18px;font-size:13px;line-height:1.7;color:var(--ink)}.explain-body u strong{color:var(--spotify-green-dark)}.explain-body .list-bullet1{padding-left:18px}.shadowing-studio{--sh-accent: var(--spotify-green);--sh-accent-dark: var(--spotify-green-dark);--sh-ink: var(--ink);--sh-surface: var(--bg-surface);background-color:var(--bg);background-image:linear-gradient(rgba(30,215,96,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(30,215,96,.06) 1px,transparent 1px);background-size:24px 24px;color:var(--sh-ink)}.sh-tab{border-radius:999px;padding:8px 16px;font-size:12px;font-weight:600;border:1px solid var(--border);background:var(--bg-surface);color:var(--ink2);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.sh-tab:hover{border-color:var(--sh-accent)}.sh-tab.is-active{background:var(--sh-accent);border-color:var(--sh-accent-dark);color:#000}.sh-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border-radius:10px;padding:10px 16px;font-size:12px;font-weight:700;cursor:pointer;border:1px solid var(--border);background:var(--bg-surface);color:var(--ink);transition:background .12s,border-color .12s}.sh-btn:hover{background:var(--bg-interactive)}.sh-btn-primary{background:var(--sh-accent, var(--spotify-green));border-color:var(--sh-accent-dark, var(--spotify-green-dark));color:#000!important;font-weight:700}.sh-btn-primary:hover{filter:brightness(1.08)}.sh-btn-primary:disabled{opacity:.5;color:#000!important}.sh-btn-block{width:100%}.sh-card{border-radius:14px;border:1px solid var(--border);background:var(--bg-surface);box-shadow:var(--shadow-sm)}.sh-panel-title{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--ink3)}.sh-transcript-card.is-active{border-color:var(--sh-accent);box-shadow:0 0 0 2px #1ed76059}.sh-transcript-body{word-wrap:break-word;overflow-wrap:break-word;white-space:normal}.sh-transcript-prose{display:block;width:100%;text-align:left}.sh-word-chip{display:inline-block;border-radius:8px;border:1px solid var(--border);background:var(--bg-interactive);padding:6px 12px;font-size:15px;font-weight:600;color:var(--ink)}.sh-focus-text{font-size:clamp(1.25rem,2.5vw,1.75rem);font-weight:700;line-height:1.5;color:var(--ink);text-align:center;word-break:normal;overflow-wrap:break-word}.sh-focus-text .shadowing-vocab-text.vocab-mode{justify-content:center}.sh-focus-card{min-height:120px}.sh-tab-panel{min-height:0;height:100%;width:100%}.sh-middle-panel{display:flex;flex-direction:column;min-height:0;height:100%;padding:16px;overflow:hidden}.sh-middle-panel>*{flex:1;min-height:0}.shadowing-transcript{max-width:none}.sh-studio-grid{display:flex;flex-direction:column;min-height:0}@media (min-width: 1024px){.sh-studio-grid{display:grid;grid-template-columns:3fr 2fr 3fr;grid-template-rows:minmax(0,1fr);align-items:stretch}.sh-studio-grid>*{min-height:0;max-height:100%}}.sh-left-col{display:flex;flex-direction:column;min-height:0;height:100%;max-height:100%;overflow:hidden}.sh-left-col-scroll{box-sizing:border-box;height:100%;max-height:100%;min-height:0;overflow-x:hidden;overflow-y:auto;padding:12px 14px 16px;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;scrollbar-gutter:stable}.sh-video-meta{margin-bottom:12px}.sh-video-title{margin:8px 0 0;font-size:13px;font-weight:700;line-height:1.5;color:#111;word-wrap:break-word;overflow-wrap:break-word;white-space:normal}.sh-video-shell{position:relative;width:100%;margin-bottom:14px;overflow:hidden;border-radius:12px;border:1px solid var(--border-button);background:#000;aspect-ratio:16 / 9;min-height:180px;z-index:1}.sh-video-player{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.sh-video-player iframe{display:block;width:100%!important;height:100%!important}.sh-left-controls{display:flex;flex-direction:column;gap:12px}@media (max-width: 1023px){.sh-left-col{max-height:50vh}}.shadowing-studio .sh-middle-panel{min-width:0;max-width:100%}.popup-fade-enter-active,.popup-fade-leave-active{transition:opacity .2s,transform .2s}.popup-fade-enter-from,.popup-fade-leave-to{opacity:0;transform:translate(20px)}.vocab-header,.vocab-sidebar,.vocab-main,.modal-sm,.modal-lg{background:var(--bg-surface)!important;border-color:var(--border)!important}.vocab-header__title,.main-title,.word-text,.topic-item__name,.modal-sm-header,.stat-num{color:var(--ink)!important}.vocab-header__sub,.main-sub,.sidebar-title,.th,.topic-item__count,.field label{color:var(--ink3)!important}.stat-pill{background:var(--bg-interactive)!important;border-color:var(--border)!important}.stat-pill--green{border-color:var(--spotify-green-dark)!important;background:var(--green-bg)!important}.stat-pill--green .stat-num,.topic-item.active .topic-item__name,.meaning-vi,.link-btn,.sidebar-add-btn,.add-word-btn,.view-tab.active,.word-type-pill{color:var(--spotify-green-dark)!important}.sidebar-add-btn,.topic-item.active,.mastery--mastered,.row-action-btn:hover,.tts-btn:hover{background:var(--green-bg)!important;border-color:var(--spotify-green-dark)!important}.topic-item:hover,.word-row:hover,.word-table-head{background:var(--bg-interactive)!important}.word-search-input,.view-tab,.mastery-select,.topic-input,.field input,.field textarea{background:var(--bg-interactive)!important;border-color:var(--border)!important;color:var(--ink)!important}.add-word-btn,.view-tab.active{background:var(--spotify-green)!important;color:#000!important}.add-word-btn:hover{background:var(--spotify-green-dark)!important}.chat-header-accent{background:var(--header-accent-bg)}.catbot-header{background:var(--catbot-header-bg)!important;border-color:color-mix(in srgb,var(--spotify-green) 35%,var(--border))!important}.catbot-title{color:var(--catbot-title-color)}.catbot-subtitle{color:var(--catbot-subtitle-color)}.catbot-bubble-assistant{background:var(--catbot-bubble-assistant-bg);color:var(--catbot-bubble-assistant-text);box-shadow:var(--shadow-medium)}.chat-bubble-assistant{background:var(--bubble-assistant-bg);color:var(--text-base);box-shadow:var(--shadow-medium)}.chat-bubble-user{background:var(--bubble-user-bg);color:var(--bubble-user-text)}.accent-hover:hover{border-color:var(--spotify-green);background:var(--green-bg)}.theme-toggle-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-circle);border:1px solid var(--border-button);background:var(--bg-interactive);color:var(--text-subdued);cursor:pointer;transition:background var(--transition-base),color var(--transition-base),border-color var(--transition-base)}.theme-toggle-btn:hover{color:var(--text-base);border-color:var(--spotify-green)}.first\:mt-1:first-child{margin-top:.25rem}.last\:mb-0:last-child{margin-bottom:0}.last\:border-0:last-child{border-width:0px}.last\:border-b-0:last-child{border-bottom-width:0px}.hover\:-translate-x-0\.5:hover{--tw-translate-x: -.125rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:-translate-y-0\.5:hover{--tw-translate-y: -.125rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:translate-x-0\.5:hover{--tw-translate-x: .125rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:scale-110:hover{--tw-scale-x: 1.1;--tw-scale-y: 1.1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:\!border-\[var\(--spotify-green\)\]:hover{border-color:var(--spotify-green)!important}.hover\:border-\[\#34d399\]:hover{--tw-border-opacity: 1;border-color:rgb(52 211 153 / var(--tw-border-opacity, 1))}.hover\:border-\[var\(--blue-l\)\]:hover{border-color:var(--blue-l)}.hover\:border-\[var\(--border2\)\]:hover{border-color:var(--border2)}.hover\:border-\[var\(--green-l\)\]:hover{border-color:var(--green-l)}.hover\:border-\[var\(--ink2\)\]:hover{border-color:var(--ink2)}.hover\:border-\[var\(--ink3\)\]:hover{border-color:var(--ink3)}.hover\:border-\[var\(--spotify-green\)\]:hover{border-color:var(--spotify-green)}.hover\:border-amber-300:hover{--tw-border-opacity: 1;border-color:rgb(252 211 77 / var(--tw-border-opacity, 1))}.hover\:border-blue-300:hover{--tw-border-opacity: 1;border-color:rgb(147 197 253 / var(--tw-border-opacity, 1))}.hover\:border-emerald-300:hover{--tw-border-opacity: 1;border-color:rgb(110 231 183 / var(--tw-border-opacity, 1))}.hover\:border-emerald-500:hover{--tw-border-opacity: 1;border-color:rgb(16 185 129 / var(--tw-border-opacity, 1))}.hover\:border-green-700:hover{--tw-border-opacity: 1;border-color:rgb(21 128 61 / var(--tw-border-opacity, 1))}.hover\:border-yellow-300:hover{--tw-border-opacity: 1;border-color:rgb(253 224 71 / var(--tw-border-opacity, 1))}.hover\:\!bg-\[var\(--spotify-green\)\]:hover{background-color:var(--spotify-green)!important}.hover\:bg-\[\#059669\]:hover{--tw-bg-opacity: 1;background-color:rgb(5 150 105 / var(--tw-bg-opacity, 1))}.hover\:bg-\[\#245c42\]:hover{--tw-bg-opacity: 1;background-color:rgb(36 92 66 / var(--tw-bg-opacity, 1))}.hover\:bg-\[\#2dd4a0\]:hover{--tw-bg-opacity: 1;background-color:rgb(45 212 160 / var(--tw-bg-opacity, 1))}.hover\:bg-\[\#34d39911\]:hover{background-color:#34d39911}.hover\:bg-\[\#34d399\]:hover{--tw-bg-opacity: 1;background-color:rgb(52 211 153 / var(--tw-bg-opacity, 1))}.hover\:bg-\[\#f0fdf4\]:hover{--tw-bg-opacity: 1;background-color:rgb(240 253 244 / var(--tw-bg-opacity, 1))}.hover\:bg-\[\#fee2e2\]:hover{--tw-bg-opacity: 1;background-color:rgb(254 226 226 / var(--tw-bg-opacity, 1))}.hover\:bg-\[var\(--bg\)\]:hover{background-color:var(--bg)}.hover\:bg-\[var\(--bg-interactive\)\]:hover{background-color:var(--bg-interactive)}.hover\:bg-\[var\(--bg2\)\]:hover{background-color:var(--bg2)}.hover\:bg-\[var\(--blue-bg\)\]:hover{background-color:var(--blue-bg)}.hover\:bg-\[var\(--border\)\]:hover{background-color:var(--border)}.hover\:bg-\[var\(--green-bg\)\]:hover{background-color:var(--green-bg)}.hover\:bg-\[var\(--rose-bg\)\]:hover{background-color:var(--rose-bg)}.hover\:bg-\[var\(--surface2\)\]:hover{background-color:var(--surface2)}.hover\:bg-amber-100:hover{--tw-bg-opacity: 1;background-color:rgb(254 243 199 / var(--tw-bg-opacity, 1))}.hover\:bg-amber-50:hover{--tw-bg-opacity: 1;background-color:rgb(255 251 235 / var(--tw-bg-opacity, 1))}.hover\:bg-blue-50:hover{--tw-bg-opacity: 1;background-color:rgb(239 246 255 / var(--tw-bg-opacity, 1))}.hover\:bg-emerald-200:hover{--tw-bg-opacity: 1;background-color:rgb(167 243 208 / var(--tw-bg-opacity, 1))}.hover\:bg-emerald-50\/20:hover{background-color:#ecfdf533}.hover\:bg-emerald-50\/30:hover{background-color:#ecfdf54d}.hover\:bg-emerald-50\/40:hover{background-color:#ecfdf566}.hover\:bg-emerald-600:hover{--tw-bg-opacity: 1;background-color:rgb(5 150 105 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-100:hover{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-800:hover{--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))}.hover\:bg-green-50:hover{--tw-bg-opacity: 1;background-color:rgb(240 253 244 / var(--tw-bg-opacity, 1))}.hover\:bg-rose-50:hover{--tw-bg-opacity: 1;background-color:rgb(255 241 242 / var(--tw-bg-opacity, 1))}.hover\:bg-slate-100:hover{--tw-bg-opacity: 1;background-color:rgb(241 245 249 / var(--tw-bg-opacity, 1))}.hover\:bg-slate-50:hover{--tw-bg-opacity: 1;background-color:rgb(248 250 252 / var(--tw-bg-opacity, 1))}.hover\:bg-yellow-50:hover{--tw-bg-opacity: 1;background-color:rgb(254 252 232 / var(--tw-bg-opacity, 1))}.hover\:\!text-\[var\(--bubble-user-text\)\]:hover{color:var(--bubble-user-text)!important}.hover\:text-\[\#059669\]:hover{--tw-text-opacity: 1;color:rgb(5 150 105 / var(--tw-text-opacity, 1))}.hover\:text-\[\#34d399\]:hover{--tw-text-opacity: 1;color:rgb(52 211 153 / var(--tw-text-opacity, 1))}.hover\:text-\[var\(--green\)\]:hover{color:var(--green)}.hover\:text-\[var\(--ink\)\]:hover{color:var(--ink)}.hover\:text-\[var\(--ink2\)\]:hover{color:var(--ink2)}.hover\:text-\[var\(--spotify-green\)\]:hover{color:var(--spotify-green)}.hover\:text-\[var\(--spotify-green-dark\)\]:hover{color:var(--spotify-green-dark)}.hover\:text-\[var\(--text-base\)\]:hover{color:var(--text-base)}.hover\:text-emerald-600:hover{--tw-text-opacity: 1;color:rgb(5 150 105 / var(--tw-text-opacity, 1))}.hover\:text-emerald-700:hover{--tw-text-opacity: 1;color:rgb(4 120 87 / var(--tw-text-opacity, 1))}.hover\:text-gray-900:hover{--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity, 1))}.hover\:text-red-700:hover{--tw-text-opacity: 1;color:rgb(185 28 28 / var(--tw-text-opacity, 1))}.hover\:text-rose-600:hover{--tw-text-opacity: 1;color:rgb(225 29 72 / var(--tw-text-opacity, 1))}.hover\:text-white:hover{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.hover\:underline:hover{text-decoration-line:underline}.hover\:no-underline:hover{text-decoration-line:none}.hover\:opacity-100:hover{opacity:1}.hover\:opacity-90:hover{opacity:.9}.hover\:shadow:hover{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\:shadow-md:hover{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\:shadow-\[var\(--shadow\)\]:hover{--tw-shadow-color: var(--shadow);--tw-shadow: var(--tw-shadow-colored)}.hover\:shadow-\[var\(--shadow-medium\)\]:hover{--tw-shadow-color: var(--shadow-medium);--tw-shadow: var(--tw-shadow-colored)}.hover\:ring-2:hover{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.hover\:ring-\[var\(--spotify-green\)\]:hover{--tw-ring-color: var(--spotify-green)}.hover\:ring-offset-1:hover{--tw-ring-offset-width: 1px}.hover\:ring-offset-\[var\(--bg-surface\)\]:hover{--tw-ring-offset-color: var(--bg-surface)}.hover\:brightness-105:hover{--tw-brightness: brightness(1.05);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.hover\:brightness-\[0\.98\]:hover{--tw-brightness: brightness(.98);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}[data-theme=dark] .hover\:bg-slate-50:hover,[data-theme=dark] .hover\:bg-slate-100:hover,[data-theme=dark] .hover\:bg-gray-100:hover{background-color:var(--bg-interactive)!important}[data-theme=dark] .hover\:text-gray-900:hover{color:var(--text-base)!important}.hover\:text-emerald-600:hover,.hover\:text-emerald-700:hover{color:var(--spotify-green)!important}[data-theme=dark] .hover\:bg-green-50:hover{background-color:var(--green-bg)!important}[data-theme=dark] .hover\:border-emerald-500:hover{border-color:var(--spotify-green)!important}.focus\:border-\[\#34d399\]:focus{--tw-border-opacity: 1;border-color:rgb(52 211 153 / var(--tw-border-opacity, 1))}.focus\:border-\[var\(--green-l\)\]:focus{border-color:var(--green-l)}.focus\:border-\[var\(--spotify-green\)\]:focus{border-color:var(--spotify-green)}.focus\:border-emerald-500:focus{--tw-border-opacity: 1;border-color:rgb(16 185 129 / var(--tw-border-opacity, 1))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-0:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-\[var\(--green-bg\)\]:focus{--tw-ring-color: var(--green-bg)}[data-theme=dark] .focus\:border-emerald-500:focus{border-color:var(--spotify-green)!important}.active\:scale-95:active{--tw-scale-x: .95;--tw-scale-y: .95;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.active\:opacity-70:active{opacity:.7}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:bg-gray-50:disabled{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.disabled\:opacity-30:disabled{opacity:.3}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:opacity-60:disabled{opacity:.6}[data-theme=dark] .disabled\:bg-gray-50:disabled{background-color:var(--bg-interactive)!important}.group:hover .group-hover\:-translate-x-0\.5{--tw-translate-x: -.125rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group:hover .group-hover\:translate-x-0\.5{--tw-translate-x: .125rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group:hover .group-hover\:translate-x-1{--tw-translate-x: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group:hover .group-hover\:scale-\[1\.03\]{--tw-scale-x: 1.03;--tw-scale-y: 1.03;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group:hover .group-hover\:border-\[var\(--spotify-green\)\]{border-color:var(--spotify-green)}.group:hover .group-hover\:bg-\[\#34d399\]{--tw-bg-opacity: 1;background-color:rgb(52 211 153 / var(--tw-bg-opacity, 1))}.group:hover .group-hover\:bg-\[var\(--bg2\)\]{background-color:var(--bg2)}.group:hover .group-hover\:bg-\[var\(--green-bg\)\]{background-color:var(--green-bg)}.group:hover .group-hover\:bg-\[var\(--spotify-green\)\]{background-color:var(--spotify-green)}.group:hover .group-hover\:text-\[var\(--ink2\)\]{color:var(--ink2)}.group:hover .group-hover\:text-\[var\(--spotify-green\)\]{color:var(--spotify-green)}.group:hover .group-hover\:opacity-100{opacity:1}.group:hover .group-hover\:brightness-110{--tw-brightness: brightness(1.1);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}@media not all and (min-width: 1024px){.max-lg\:absolute{position:absolute}.max-lg\:inset-0{top:0;right:0;bottom:0;left:0}.max-lg\:z-40{z-index:40}.max-lg\:max-h-\[42vh\]{max-height:42vh}.max-lg\:min-h-\[40vh\]{min-height:40vh}.max-lg\:border-t-0{border-top-width:0px}}@media (min-width: 640px){.sm\:left-4{left:1rem}.sm\:col-span-2{grid-column:span 2 / span 2}.sm\:block{display:block}.sm\:inline{display:inline}.sm\:flex{display:flex}.sm\:inline-flex{display:inline-flex}.sm\:hidden{display:none}.sm\:w-64{width:16rem}.sm\:w-auto{width:auto}.sm\:max-w-\[200px\]{max-width:200px}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:flex-col{flex-direction:column}.sm\:items-center{align-items:center}.sm\:justify-end{justify-content:flex-end}.sm\:justify-center{justify-content:center}.sm\:gap-1\.5{gap:.375rem}.sm\:gap-3{gap:.75rem}.sm\:gap-3\.5{gap:.875rem}.sm\:gap-8{gap:2rem}.sm\:self-center{align-self:center}.sm\:p-5{padding:1.25rem}.sm\:p-6{padding:1.5rem}.sm\:p-8{padding:2rem}.sm\:px-10{padding-left:2.5rem;padding-right:2.5rem}.sm\:px-3{padding-left:.75rem;padding-right:.75rem}.sm\:px-5{padding-left:1.25rem;padding-right:1.25rem}.sm\:px-8{padding-left:2rem;padding-right:2rem}.sm\:px-9{padding-left:2.25rem;padding-right:2.25rem}.sm\:px-\[18px\]{padding-left:18px;padding-right:18px}.sm\:py-4{padding-top:1rem;padding-bottom:1rem}.sm\:py-6{padding-top:1.5rem;padding-bottom:1.5rem}.sm\:py-7{padding-top:1.75rem;padding-bottom:1.75rem}.sm\:text-2xl{font-size:1.5rem;line-height:2rem}.sm\:text-3xl{font-size:1.875rem;line-height:2.25rem}.sm\:text-4xl{font-size:2.25rem;line-height:2.5rem}.sm\:text-5xl{font-size:3rem;line-height:1}.sm\:text-\[13px\]{font-size:13px}.sm\:text-\[17px\]{font-size:17px}.sm\:text-base{font-size:1rem;line-height:1.5rem}.sm\:text-xl{font-size:1.25rem;line-height:1.75rem}.sm\:text-base{color:var(--bg-base)}}@media (min-width: 768px){.md\:col-span-1{grid-column:span 1 / span 1}.md\:col-span-2{grid-column:span 2 / span 2}.md\:block{display:block}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.md\:grid-cols-\[160px_1fr\]{grid-template-columns:160px 1fr}.md\:grid-cols-\[180px_1fr\]{grid-template-columns:180px 1fr}.md\:grid-cols-\[1fr_110px_1fr\]{grid-template-columns:1fr 110px 1fr}.md\:grid-cols-\[1fr_120px\]{grid-template-columns:1fr 120px}.md\:grid-cols-\[1fr_140px_140px_170px_150px\]{grid-template-columns:1fr 140px 140px 170px 150px}.md\:grid-cols-\[1fr_160px_160px_120px\]{grid-template-columns:1fr 160px 160px 120px}.md\:grid-cols-\[1fr_180px_120px\]{grid-template-columns:1fr 180px 120px}.md\:p-6{padding:1.5rem}.md\:px-6{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width: 1024px){.lg\:relative{position:relative}.lg\:col-span-2{grid-column:span 2 / span 2}.lg\:col-span-3{grid-column:span 3 / span 3}.lg\:ml-auto{margin-left:auto}.lg\:mt-0{margin-top:0}.lg\:block{display:block}.lg\:flex{display:flex}.lg\:hidden{display:none}.lg\:max-h-none{max-height:none}.lg\:w-16{width:4rem}.lg\:w-64{width:16rem}.lg\:w-80{width:20rem}.lg\:w-\[220px\]{width:220px}.lg\:w-\[340px\]{width:340px}.lg\:w-\[42\%\]{width:42%}.lg\:shrink-0{flex-shrink:0}.lg\:translate-x-0{--tw-translate-x: 0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.lg\:grid-cols-\[1fr_360px\]{grid-template-columns:1fr 360px}.lg\:grid-cols-\[340px_1fr\]{grid-template-columns:340px 1fr}.lg\:grid-cols-\[360px_1fr\]{grid-template-columns:360px 1fr}.lg\:grid-cols-\[420px_1fr\]{grid-template-columns:420px 1fr}.lg\:grid-cols-\[80px_1fr_120px\]{grid-template-columns:80px 1fr 120px}.lg\:flex-row{flex-direction:row}.lg\:items-center{align-items:center}.lg\:justify-between{justify-content:space-between}.lg\:gap-4{gap:1rem}.lg\:gap-6{gap:1.5rem}.lg\:border-b-0{border-bottom-width:0px}.lg\:border-l{border-left-width:1px}.lg\:border-r{border-right-width:1px}.lg\:border-t-0{border-top-width:0px}.lg\:border-\[var\(--border\)\]{border-color:var(--border)}.lg\:p-6{padding:1.5rem}}@media (min-width: 1280px){.xl\:col-span-2{grid-column:span 2 / span 2}.xl\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.xl\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.xl\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.xl\:grid-cols-8{grid-template-columns:repeat(8,minmax(0,1fr))}.xl\:grid-cols-\[1fr_340px\]{grid-template-columns:1fr 340px}.xl\:grid-cols-\[260px_280px_minmax\(0\,1fr\)\]{grid-template-columns:260px 280px minmax(0,1fr)}.xl\:grid-cols-\[320px_1fr\]{grid-template-columns:320px 1fr}.xl\:border-l{border-left-width:1px}.xl\:border-t-0{border-top-width:0px}}@media (prefers-color-scheme: dark){.dark\:bg-emerald-700\/70{background-color:#047857b3}.dark\:bg-emerald-900\/40{background-color:#064e3b66}}.\[\&\:\:-webkit-scrollbar-thumb\]\:rounded-sm::-webkit-scrollbar-thumb{border-radius:.125rem}.\[\&\:\:-webkit-scrollbar-thumb\]\:bg-\[var\(--border-outlined\)\]::-webkit-scrollbar-thumb{background-color:var(--border-outlined)}.\[\&\:\:-webkit-scrollbar\]\:hidden::-webkit-scrollbar{display:none}.\[\&\:\:-webkit-scrollbar\]\:w-1\.5::-webkit-scrollbar{width:.375rem}.\[\&_\.day-hdr\]\:p-px .day-hdr{padding:1px}.\[\&_\.day-hdr\]\:text-\[9px\] .day-hdr{font-size:9px}.\[\&_\.heatmap-day\]\:min-h-\[22px\] .heatmap-day{min-height:22px}.\[\&_\.heatmap-day\]\:text-\[10px\] .heatmap-day{font-size:10px}.\[\&_\.text-sm\.font-semibold\]\:text-lg .text-sm.font-semibold{font-size:1.125rem;line-height:1.75rem}.\[\&_\.text-sm\.font-semibold\]\:font-semibold .text-sm.font-semibold{font-weight:600}.\[\&_\.text-sm\.font-semibold\]\:leading-normal .text-sm.font-semibold{line-height:1.5}.\[\&_\.text-sm\.font-semibold\]\:text-\[var\(--ink\)\] .text-sm.font-semibold{color:var(--ink)}.admin-page{--admin-accent: var(--spotify-green-dark);--admin-accent-soft: var(--green-bg);--admin-accent-border: var(--border)}.admin-hero{border-color:var(--admin-accent-border);background:var(--bg-surface);color:var(--ink)}[data-theme=dark] .admin-hero{background:var(--bg-surface);border-color:var(--border);--admin-accent-soft: color-mix(in srgb, var(--admin-accent) 16%, var(--bg-interactive));--admin-accent-border: color-mix(in srgb, var(--admin-accent) 30%, var(--border))}[data-theme=dark] .admin-hero-glow{display:none}[data-theme=light] .admin-hero{background:linear-gradient(135deg,color-mix(in srgb,var(--admin-accent) 8%,var(--bg-surface)) 0%,var(--bg-surface) 100%)}.admin-hero h1,.admin-hero h2,.admin-hero p,.admin-hero .text-\[var\(--ink\)\],.admin-hero .text-\[var\(--ink2\)\],.admin-hero .text-\[var\(--ink3\)\]{color:inherit}.admin-hero-glow{background:color-mix(in srgb,var(--admin-accent) 18%,transparent)}.admin-panel-accent{border-top:3px solid var(--admin-accent)}.admin-crud-bar{border-color:var(--admin-accent-border);background:var(--bg-surface);color:var(--ink)}.admin-crud-bar .admin-crud-tag{color:var(--admin-accent);background:var(--admin-accent-soft)}.admin-list-active{background:var(--green-bg)!important;border-left:3px solid var(--admin-accent);color:var(--ink)!important}.admin-list-active .text-\[var\(--ink\)\],.admin-list-active .text-\[var\(--ink2\)\],.admin-list-active .text-\[var\(--ink3\)\],.admin-list-active .text-slate-500,.admin-list-active .text-slate-600,.admin-list-active .text-slate-700{color:var(--ink)!important}.admin-json-live{border-color:var(--admin-accent-border)}.admin-json-live.is-syncing{box-shadow:0 0 0 2px color-mix(in srgb,var(--admin-accent) 25%,transparent)}.admin-json-badge{background:var(--admin-accent-soft);color:var(--admin-accent);border:1px solid var(--admin-accent-border)}.admin-json-badge.pulse{animation:admin-json-pulse 1.2s ease-in-out infinite}@keyframes admin-json-pulse{0%,to{opacity:1}50%{opacity:.55}}.admin-quick-link:hover{border-color:var(--link-accent, var(--admin-accent-border))!important;background:color-mix(in srgb,var(--link-accent, var(--admin-accent)) 8%,var(--bg-surface))!important}.admin-quick-link:hover .admin-quick-icon{color:var(--link-accent, var(--admin-accent));background:color-mix(in srgb,var(--link-accent, var(--admin-accent)) 12%,var(--bg-interactive))}.admin-page .ct-btn-accent,.admin-crud-bar .admin-save-btn{background:var(--admin-accent)!important;border-color:var(--admin-accent)!important;color:#fff!important}.admin-page .ct-btn-accent:hover,.admin-crud-bar .admin-save-btn:hover{filter:brightness(1.08);color:#fff!important}[data-theme=dark] .bg-emerald-50,[data-theme=dark] .hover\:bg-emerald-50:hover{background-color:var(--green-bg)!important}[data-theme=dark] .border-emerald-300{border-color:var(--spotify-green-dark)!important}.admin-page textarea.ct-input{display:block;width:100%;min-height:3.25rem;border-radius:var(--radius-comfortable, 8px);text-align:left;padding:14px 18px;line-height:1.55;white-space:pre-wrap;word-break:break-word;resize:none;overflow:hidden;box-sizing:border-box;field-sizing:content}.admin-page table input.ct-input.w-full{border-radius:var(--radius-comfortable, 8px)}.admin-page .admin-json-live textarea.ct-input{border-radius:0;padding:14px 18px;text-align:left}
