@import "https://fonts.googleapis.com/css2?family=Shadows+Into+Light&display=swap";
*,:before,:after,::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:#3b82f680;--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:0 solid #e5e7eb}:before,:after{--tw-content:""}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--font-sans), system-ui, sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{line-height:inherit;margin:0}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;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family: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:#0000;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-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{margin:0;padding:0;list-style:none}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder{opacity:1;color:#9ca3af}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{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--background:30 40% 97%;--foreground:20 18% 22%;--card:30 30% 99%;--card-foreground:20 18% 22%;--popover:30 30% 99%;--popover-foreground:20 18% 22%;--primary:348 45% 58%;--primary-foreground:0 0% 100%;--secondary:30 20% 93%;--secondary-foreground:20 18% 22%;--muted:30 18% 94%;--muted-foreground:20 10% 50%;--accent:340 28% 93%;--accent-foreground:348 40% 38%;--destructive:0 55% 52%;--destructive-foreground:0 0% 100%;--border:30 15% 87%;--input:30 15% 85%;--ring:348 45% 58%;--radius:12px;--love:348 45% 58%;--love-light:340 35% 95%;--love-dark:348 42% 40%;--chart-1:348 45% 58%;--chart-2:340 35% 65%;--chart-3:30 15% 55%;--chart-4:348 32% 70%;--chart-5:340 40% 80%;--lesson-callout-radius:10px;--lesson-callout-padding:.85rem 1rem;--lesson-callout-border-width:1px;--lesson-callout-love-bg:340 40% 97%;--lesson-callout-love-border:348 35% 78%;--lesson-callout-love-accent:348 42% 50%;--lesson-callout-date-bg:35 45% 96%;--lesson-callout-date-border:28 40% 75%;--lesson-callout-date-accent:24 40% 48%;--lesson-callout-memory-bg:210 35% 96%;--lesson-callout-memory-border:210 30% 75%;--lesson-callout-memory-accent:210 35% 48%;--lesson-callout-promise-bg:155 35% 95%;--lesson-callout-promise-border:155 30% 68%;--lesson-callout-promise-accent:155 35% 42%;--lesson-callout-gratitude-bg:48 42% 95%;--lesson-callout-gratitude-border:45 40% 72%;--lesson-callout-gratitude-accent:38 40% 45%;--lesson-callout-future-bg:255 35% 97%;--lesson-callout-future-border:250 30% 76%;--lesson-callout-future-accent:250 35% 50%;--lesson-callout-pronunciation-bg:210 50% 96%;--lesson-callout-pronunciation-border:210 40% 76%;--lesson-callout-pronunciation-accent:210 45% 45%;--canvas-note-sticky-bg:48 40% 95%;--canvas-note-sticky-border:30 15% 85%;--canvas-note-sticky-header:45 35% 90%;--canvas-note-text-bg:30 28% 99%;--canvas-note-text-border:30 15% 85%;--canvas-note-text-header:210 18% 94%}.dark{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--background:260 18% 14%;--foreground:35 18% 90%;--card:260 16% 18%;--card-foreground:35 18% 90%;--popover:260 16% 18%;--popover-foreground:35 18% 90%;--primary:348 48% 65%;--primary-foreground:0 0% 100%;--secondary:260 14% 22%;--secondary-foreground:35 18% 90%;--muted:260 14% 24%;--muted-foreground:35 12% 60%;--accent:300 18% 24%;--accent-foreground:348 50% 82%;--destructive:0 50% 52%;--destructive-foreground:0 0% 100%;--border:260 12% 32%;--input:260 12% 30%;--ring:348 48% 65%;--love:348 48% 65%;--love-light:300 18% 24%;--love-dark:348 50% 82%;--chart-1:348 48% 65%;--chart-2:340 38% 55%;--chart-3:35 12% 65%;--chart-4:348 32% 58%;--chart-5:340 42% 68%;--lesson-callout-radius:10px;--lesson-callout-padding:.85rem 1rem;--lesson-callout-border-width:1px;--lesson-callout-love-bg:336 22% 22%;--lesson-callout-love-border:348 30% 45%;--lesson-callout-love-accent:336 45% 72%;--lesson-callout-date-bg:28 22% 20%;--lesson-callout-date-border:28 30% 42%;--lesson-callout-date-accent:28 42% 68%;--lesson-callout-memory-bg:210 22% 20%;--lesson-callout-memory-border:210 25% 42%;--lesson-callout-memory-accent:210 38% 68%;--lesson-callout-promise-bg:155 20% 20%;--lesson-callout-promise-border:155 25% 40%;--lesson-callout-promise-accent:155 38% 68%;--lesson-callout-gratitude-bg:45 22% 20%;--lesson-callout-gratitude-border:45 30% 42%;--lesson-callout-gratitude-accent:45 42% 68%;--lesson-callout-future-bg:250 20% 20%;--lesson-callout-future-border:250 25% 42%;--lesson-callout-future-accent:250 38% 68%;--lesson-callout-pronunciation-bg:210 24% 20%;--lesson-callout-pronunciation-border:210 28% 42%;--lesson-callout-pronunciation-accent:210 42% 70%;--canvas-note-sticky-bg:45 22% 20%;--canvas-note-sticky-border:260 12% 32%;--canvas-note-sticky-header:45 18% 26%;--canvas-note-text-bg:260 16% 18%;--canvas-note-text-border:260 12% 32%;--canvas-note-text-header:260 14% 24%}*{border-color:hsl(var(--border))}html{scroll-behavior:smooth;scrollbar-width:none}html::-webkit-scrollbar{display:none}body{background-color:hsl(var(--background));color:hsl(var(--foreground));font-family:var(--font-sans), system-ui, sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}select{background-color:hsl(var(--popover));color:hsl(var(--popover-foreground));border-color:hsl(var(--border));border-radius:var(--radius)}select option{background-color:hsl(var(--popover));color:hsl(var(--popover-foreground))}select option:checked,select option:hover{background-color:hsl(var(--accent));color:hsl(var(--accent-foreground))}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.inset-x-0{left:0;right:0}.inset-y-0{top:0;bottom:0}.-bottom-0\.5{bottom:-.125rem}.-right-0\.5{right:-.125rem}.-right-1{right:-.25rem}.-top-1{top:-.25rem}.bottom-0{bottom:0}.bottom-full{bottom:100%}.left-0{left:0}.left-2{left:.5rem}.left-3{left:.75rem}.right-0{right:0}.top-\[57px\]{top:57px}.top-full{top:100%}.z-20{z-index:20}.z-50{z-index:50}.z-\[10000\]{z-index:10000}.z-\[10001\]{z-index:10001}.-mx-1{margin-left:-.25rem;margin-right:-.25rem}.mx-0\.5{margin-left:.125rem;margin-right:.125rem}.mx-1{margin-left:.25rem;margin-right:.25rem}.mx-auto{margin-left:auto;margin-right:auto}.my-1{margin-top:.25rem;margin-bottom:.25rem}.my-2{margin-top:.5rem;margin-bottom:.5rem}.my-3{margin-top:.75rem;margin-bottom:.75rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-8{margin-bottom:2rem}.ml-2{margin-left:.5rem}.ml-auto{margin-left:auto}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.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}.contents{display:contents}.hidden{display:none}.aspect-\[14\/9\]{aspect-ratio:14/9}.aspect-\[4\/3\]{aspect-ratio:4/3}.aspect-square{aspect-ratio:1}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-12{height:3rem}.h-16{height:4rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-7{height:1.75rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[168px\]{height:168px}.h-full{height:100%}.h-px{height:1px}.h-screen{height:100vh}.max-h-48{max-height:12rem}.max-h-64{max-height:16rem}.max-h-\[calc\(100vh-3rem\)\]{max-height:calc(100vh - 3rem)}.max-h-\[var\(--radix-dropdown-menu-content-available-height\)\]{max-height:var(--radix-dropdown-menu-content-available-height)}.min-h-0{min-height:0}.min-h-\[100px\]{min-height:100px}.min-h-\[108px\]{min-height:108px}.min-h-\[120px\]{min-height:120px}.min-h-\[360px\]{min-height:360px}.min-h-\[420px\]{min-height:420px}.min-h-\[90px\]{min-height:90px}.min-h-screen{min-height:100vh}.w-1\.5{width:.375rem}.w-10{width:2.5rem}.w-11{width:2.75rem}.w-12{width:3rem}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-20{width:5rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-4{width:1rem}.w-48{width:12rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-7{width:1.75rem}.w-72{width:18rem}.w-8{width:2rem}.w-80{width:20rem}.w-9{width:2.25rem}.w-\[168px\]{width:168px}.w-\[min\(20rem\,calc\(100vw-2rem\)\)\]{width:min(20rem,100vw - 2rem)}.w-full{width:100%}.w-px{width:1px}.w-screen{width:100vw}.min-w-0{min-width:0}.min-w-4{min-width:1rem}.min-w-7{min-width:1.75rem}.min-w-\[180px\]{min-width:180px}.min-w-\[260px\]{min-width:260px}.min-w-\[300px\]{min-width:300px}.min-w-\[8rem\]{min-width:8rem}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-6xl{max-width:72rem}.max-w-7xl{max-width:80rem}.max-w-\[9rem\]{max-width:9rem}.max-w-lg{max-width:32rem}.max-w-md{max-width:28rem}.max-w-xl{max-width:36rem}.max-w-xs{max-width:20rem}.flex-1{flex:1}.shrink-0{flex-shrink:0}.grow{flex-grow:1}.basis-full{flex-basis:100%}.origin-\[--radix-dropdown-menu-content-transform-origin\]{transform-origin:var(--radix-dropdown-menu-content-transform-origin)}.rotate-180{--tw-rotate:180deg;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(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)) skewX(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)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:1s linear infinite spin}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.touch-none{touch-action:none}.select-none{-webkit-user-select:none;user-select:none}.resize{resize:both}.list-none{list-style-type:none}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-7{grid-template-columns:repeat(7,minmax(0,1fr))}.grid-cols-\[2\.25rem_1fr_auto\]{grid-template-columns:2.25rem 1fr auto}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-baseline{align-items:baseline}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-10{gap:2.5rem}.gap-12{gap:3rem}.gap-16{gap:4rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.gap-x-3{-moz-column-gap:.75rem;column-gap:.75rem}.gap-x-4{-moz-column-gap:1rem;column-gap:1rem}.gap-y-1\.5{row-gap:.375rem}.gap-y-2{row-gap:.5rem}.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-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-2\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.625rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.625rem * 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))}.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(2rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2rem * var(--tw-space-y-reverse))}.self-start{align-self:flex-start}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.break-words{overflow-wrap:break-word}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-\[3px\]{border-radius:3px}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-amber-500{--tw-border-opacity:1;border-color:rgb(245 158 11/var(--tw-border-opacity,1))}.border-border{border-color:hsl(var(--border))}.border-border\/60{border-color:hsl(var(--border) / .6)}.border-card{border-color:hsl(var(--card))}.border-current{border-color:currentColor}.border-destructive{border-color:hsl(var(--destructive))}.border-destructive\/30{border-color:hsl(var(--destructive) / .3)}.border-destructive\/40{border-color:hsl(var(--destructive) / .4)}.border-emerald-200{--tw-border-opacity:1;border-color:rgb(167 243 208/var(--tw-border-opacity,1))}.border-emerald-500{--tw-border-opacity:1;border-color:rgb(16 185 129/var(--tw-border-opacity,1))}.border-emerald-600{--tw-border-opacity:1;border-color:rgb(5 150 105/var(--tw-border-opacity,1))}.border-foreground{border-color:hsl(var(--foreground))}.border-green-500\/40{border-color:#22c55e66}.border-input{border-color:hsl(var(--input))}.border-muted-foreground{border-color:hsl(var(--muted-foreground))}.border-muted-foreground\/40{border-color:hsl(var(--muted-foreground) / .4)}.border-primary{border-color:hsl(var(--primary))}.border-primary-foreground{border-color:hsl(var(--primary-foreground))}.border-primary-foreground\/30{border-color:hsl(var(--primary-foreground) / .3)}.border-primary\/25{border-color:hsl(var(--primary) / .25)}.border-primary\/30{border-color:hsl(var(--primary) / .3)}.border-red-500\/50{border-color:#ef444480}.border-rose-500{--tw-border-opacity:1;border-color:rgb(244 63 94/var(--tw-border-opacity,1))}.border-sky-500{--tw-border-opacity:1;border-color:rgb(14 165 233/var(--tw-border-opacity,1))}.border-transparent{border-color:#0000}.border-t-transparent{border-top-color:#0000}.\!bg-\[hsl\(var\(--card\)\)\]{background-color:hsl(var(--card))!important}.bg-accent{background-color:hsl(var(--accent))}.bg-accent\/50{background-color:hsl(var(--accent) / .5)}.bg-amber-50{--tw-bg-opacity:1;background-color:rgb(255 251 235/var(--tw-bg-opacity,1))}.bg-background{background-color:hsl(var(--background))}.bg-background\/80{background-color:hsl(var(--background) / .8)}.bg-black\/20{background-color:#0003}.bg-border{background-color:hsl(var(--border))}.bg-card{background-color:hsl(var(--card))}.bg-card\/50{background-color:hsl(var(--card) / .5)}.bg-card\/80{background-color:hsl(var(--card) / .8)}.bg-destructive{background-color:hsl(var(--destructive))}.bg-destructive\/10{background-color:hsl(var(--destructive) / .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-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-700{--tw-bg-opacity:1;background-color:rgb(4 120 87/var(--tw-bg-opacity,1))}.bg-foreground{background-color:hsl(var(--foreground))}.bg-green-500{--tw-bg-opacity:1;background-color:rgb(34 197 94/var(--tw-bg-opacity,1))}.bg-green-500\/10{background-color:#22c55e1a}.bg-love-light{background-color:hsl(var(--love-light))}.bg-muted{background-color:hsl(var(--muted))}.bg-muted-foreground\/50{background-color:hsl(var(--muted-foreground) / .5)}.bg-muted\/20{background-color:hsl(var(--muted) / .2)}.bg-muted\/30{background-color:hsl(var(--muted) / .3)}.bg-muted\/50{background-color:hsl(var(--muted) / .5)}.bg-muted\/60{background-color:hsl(var(--muted) / .6)}.bg-popover{background-color:hsl(var(--popover))}.bg-primary{background-color:hsl(var(--primary))}.bg-primary-foreground{background-color:hsl(var(--primary-foreground))}.bg-primary\/10{background-color:hsl(var(--primary) / .1)}.bg-primary\/5{background-color:hsl(var(--primary) / .05)}.bg-red-50{--tw-bg-opacity:1;background-color:rgb(254 242 242/var(--tw-bg-opacity,1))}.bg-red-500{--tw-bg-opacity:1;background-color:rgb(239 68 68/var(--tw-bg-opacity,1))}.bg-red-500\/15{background-color:#ef444426}.bg-red-500\/20{background-color:#ef444433}.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-transparent{background-color:#0000}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-yellow-500{--tw-bg-opacity:1;background-color:rgb(234 179 8/var(--tw-bg-opacity,1))}.fill-current{fill:currentColor}.fill-primary{fill:hsl(var(--primary))}.object-contain{-o-object-fit:contain;object-fit:contain}.object-cover{-o-object-fit:cover;object-fit:cover}.p-0{padding:0}.p-0\.5{padding:.125rem}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.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}.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-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.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-2{padding-bottom:.5rem}.pb-3{padding-bottom:.75rem}.pb-4{padding-bottom:1rem}.pb-5{padding-bottom:1.25rem}.pb-6{padding-bottom:1.5rem}.pl-8{padding-left:2rem}.pl-9{padding-left:2.25rem}.pr-2{padding-right:.5rem}.pt-2{padding-top:.5rem}.pt-3{padding-top:.75rem}.pt-4{padding-top:1rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.font-sans{font-family:var(--font-sans), system-ui, sans-serif}.font-serif{font-family:var(--font-serif), Georgia, 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-\[0\.65rem\]{font-size:.65rem}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.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}.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}.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-6{line-height:1.5rem}.leading-7{line-height:1.75rem}.leading-\[1\.1\]{line-height:1.1}.leading-none{line-height:1}.leading-relaxed{line-height:1.625}.leading-snug{line-height:1.375}.leading-tight{line-height:1.25}.tracking-tight{letter-spacing:-.025em}.tracking-wide{letter-spacing:.025em}.tracking-widest{letter-spacing:.1em}.\!text-\[hsl\(var\(--foreground\)\)\]{color:hsl(var(--foreground))!important}.text-accent-foreground{color:hsl(var(--accent-foreground))}.text-amber-950{--tw-text-opacity:1;color:rgb(69 26 3/var(--tw-text-opacity,1))}.text-background{color:hsl(var(--background))}.text-card-foreground{color:hsl(var(--card-foreground))}.text-destructive{color:hsl(var(--destructive))}.text-destructive-foreground{color:hsl(var(--destructive-foreground))}.text-emerald-700{--tw-text-opacity:1;color:rgb(4 120 87/var(--tw-text-opacity,1))}.text-emerald-900{--tw-text-opacity:1;color:rgb(6 78 59/var(--tw-text-opacity,1))}.text-emerald-950{--tw-text-opacity:1;color:rgb(2 44 34/var(--tw-text-opacity,1))}.text-foreground{color:hsl(var(--foreground))}.text-green-700{--tw-text-opacity:1;color:rgb(21 128 61/var(--tw-text-opacity,1))}.text-muted-foreground{color:hsl(var(--muted-foreground))}.text-muted-foreground\/40{color:hsl(var(--muted-foreground) / .4)}.text-neutral-950{--tw-text-opacity:1;color:rgb(10 10 10/var(--tw-text-opacity,1))}.text-popover-foreground{color:hsl(var(--popover-foreground))}.text-primary{color:hsl(var(--primary))}.text-primary-foreground{color:hsl(var(--primary-foreground))}.text-primary-foreground\/90{color:hsl(var(--primary-foreground) / .9)}.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-red-700{--tw-text-opacity:1;color:rgb(185 28 28/var(--tw-text-opacity,1))}.text-rose-900{--tw-text-opacity:1;color:rgb(136 19 55/var(--tw-text-opacity,1))}.text-rose-950{--tw-text-opacity:1;color:rgb(76 5 25/var(--tw-text-opacity,1))}.text-sky-950{--tw-text-opacity:1;color:rgb(8 47 73/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.underline{text-decoration-line:underline}.decoration-1{text-decoration-thickness:1px}.decoration-2{text-decoration-thickness:2px}.underline-offset-4{text-underline-offset:4px}.\!opacity-100{opacity:1!important}.opacity-100{opacity:1}.opacity-40{opacity:.4}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-85{opacity:.85}.shadow-2xl{--tw-shadow:0 25px 50px -12px #00000040;--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-glow{--tw-shadow:0 0 20px hsl(var(--primary) / .12);--tw-shadow-colored:0 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-glow-sm{--tw-shadow:0 0 10px hsl(var(--primary) / .08);--tw-shadow-colored:0 0 10px 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-soft{--tw-shadow:0 1px 3px 0 hsl(var(--foreground) / .04), 0 1px 2px -1px hsl(var(--foreground) / .04);--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)}.shadow-soft-lg{--tw-shadow:0 10px 15px -3px hsl(var(--foreground) / .06), 0 4px 6px -4px hsl(var(--foreground) / .04);--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-soft-md{--tw-shadow:0 4px 6px -1px hsl(var(--foreground) / .05), 0 2px 4px -2px hsl(var(--foreground) / .04);--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)}.outline-none{outline-offset:2px;outline:2px solid #0000}.outline{outline-style:solid}.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-border\/70{--tw-ring-color:hsl(var(--border) / .7)}.ring-foreground\/50{--tw-ring-color:hsl(var(--foreground) / .5)}.ring-primary{--tw-ring-color:hsl(var(--primary))}.ring-primary\/40{--tw-ring-color:hsl(var(--primary) / .4)}.ring-offset-1{--tw-ring-offset-width:1px}.ring-offset-background{--tw-ring-offset-color:hsl(var(--background))}.ring-offset-card{--tw-ring-offset-color:hsl(var(--card))}.grayscale{--tw-grayscale:grayscale(100%);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-blur-sm{--tw-backdrop-blur:blur(4px);-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,-webkit-backdrop-filter,backdrop-filter;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-\[width\]{transition-property:width;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-all{transition-property:all;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-opacity{transition-property:opacity;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-transform{transition-property:transform;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-100{transition-duration:.1s}@keyframes enter{0%{opacity:var(--tw-enter-opacity,1);transform:translate3d(var(--tw-enter-translate-x,0), var(--tw-enter-translate-y,0), 0) scale3d(var(--tw-enter-scale,1), var(--tw-enter-scale,1), var(--tw-enter-scale,1)) rotate(var(--tw-enter-rotate,0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity,1);transform:translate3d(var(--tw-exit-translate-x,0), var(--tw-exit-translate-y,0), 0) scale3d(var(--tw-exit-scale,1), var(--tw-exit-scale,1), var(--tw-exit-scale,1)) rotate(var(--tw-exit-rotate,0))}}.duration-100{animation-duration:.1s}.paused{animation-play-state:paused}.neon-auth-surface,.neon-auth-surface *{color:hsl(var(--foreground))}.neon-auth-surface input,.neon-auth-surface select,.neon-auth-surface textarea{background-color:hsl(var(--background));border:1px solid hsl(var(--border));border-radius:var(--radius)}.neon-auth-surface input::-moz-placeholder{color:hsl(var(--muted-foreground))}.neon-auth-surface textarea::-moz-placeholder{color:hsl(var(--muted-foreground))}.neon-auth-surface input::placeholder,.neon-auth-surface textarea::placeholder{color:hsl(var(--muted-foreground))}.neon-auth-surface a{color:hsl(var(--primary))}.ProseMirror h1,.twolearn-lesson-page-body h1{font-family:var(--font-serif), Georgia, serif;letter-spacing:-.01em;margin:1rem 0 .5rem;font-size:1.75rem;font-weight:700;line-height:1.3}.ProseMirror h2,.twolearn-lesson-page-body h2{font-family:var(--font-serif), Georgia, serif;letter-spacing:-.005em;margin:.85rem 0 .5rem;font-size:1.4rem;font-weight:600;line-height:1.35}.ProseMirror h3,.twolearn-lesson-page-body h3{font-family:var(--font-serif), Georgia, serif;margin:.75rem 0 .5rem;font-size:1.15rem;font-weight:600;line-height:1.4}.ProseMirror p,.twolearn-lesson-page-body p{margin:.5rem 0;line-height:1.7}.ProseMirror blockquote,.twolearn-lesson-page-body blockquote{border-left:3px solid hsl(var(--primary) / .4);color:hsl(var(--muted-foreground));margin:.75rem 0;padding-left:1rem;font-style:italic}.ProseMirror pre,.twolearn-lesson-page-body pre{background:hsl(var(--muted));border:1px solid hsl(var(--border));border-radius:8px;padding:.85rem;overflow-x:auto}.ProseMirror code,.twolearn-lesson-page-body code{background:hsl(var(--muted));border:1px solid hsl(var(--border));border-radius:4px;padding:.1rem .3rem;font-size:.9em}.ProseMirror mark,.twolearn-lesson-page-body mark{background:hsl(var(--love-light));border-radius:3px;padding:.05rem .15rem}.ProseMirror ul[data-type=taskList],.twolearn-lesson-page-body ul[data-type=taskList]{padding-left:0;list-style:none}.ProseMirror ul[data-type=taskList] li,.twolearn-lesson-page-body ul[data-type=taskList] li{align-items:flex-start;gap:.5rem;margin:.25rem 0;display:flex}.ProseMirror ul[data-type=taskList] li>label,.twolearn-lesson-page-body ul[data-type=taskList] li>label{margin-top:.2rem}.ProseMirror ul[data-type=taskList] li>div,.twolearn-lesson-page-body ul[data-type=taskList] li>div{flex:1}.ProseMirror table,.twolearn-lesson-page-body table{border-collapse:collapse;table-layout:fixed;width:100%;margin:.75rem 0}.ProseMirror th,.ProseMirror td,.twolearn-lesson-page-body th,.twolearn-lesson-page-body td{border:1px solid hsl(var(--border));vertical-align:top;padding:.45rem .6rem}.ProseMirror th,.twolearn-lesson-page-body th{background:hsl(var(--muted));letter-spacing:.02em;font-size:.8rem;font-weight:600}.ProseMirror .tableWrapper,.twolearn-lesson-page-body .tableWrapper{overflow-x:auto}.ProseMirror img,.twolearn-lesson-page-body img{border-radius:8px;max-width:100%;height:auto}.ProseMirror hr[data-page-break=true]{border:none;border-top:1px solid hsl(var(--border));margin:1.5rem 0}.ProseMirror .lesson-callout,.twolearn-lesson-page-body .lesson-callout{border:var(--lesson-callout-border-width) solid transparent;border-radius:var(--lesson-callout-radius);padding:var(--lesson-callout-padding);margin:.75rem 0;position:relative}.ProseMirror .lesson-callout:before,.twolearn-lesson-page-body .lesson-callout:before{letter-spacing:.04em;color:hsl(var(--muted-foreground));margin-bottom:.4rem;font-size:.72rem;font-weight:600;display:block}.ProseMirror .lesson-callout-love-note,.twolearn-lesson-page-body .lesson-callout-love-note{background:hsl(var(--lesson-callout-love-bg));border-color:hsl(var(--lesson-callout-love-border))}.ProseMirror .lesson-callout-love-note:before,.twolearn-lesson-page-body .lesson-callout-love-note:before{content:"Love note jiji";color:hsl(var(--lesson-callout-love-accent))}.ProseMirror .lesson-callout-date-idea,.twolearn-lesson-page-body .lesson-callout-date-idea{background:hsl(var(--lesson-callout-date-bg));border-color:hsl(var(--lesson-callout-date-border))}.ProseMirror .lesson-callout-date-idea:before,.twolearn-lesson-page-body .lesson-callout-date-idea:before{content:"Date idea";color:hsl(var(--lesson-callout-date-accent))}.ProseMirror .lesson-callout-memory,.twolearn-lesson-page-body .lesson-callout-memory{background:hsl(var(--lesson-callout-memory-bg));border-color:hsl(var(--lesson-callout-memory-border))}.ProseMirror .lesson-callout-memory:before,.twolearn-lesson-page-body .lesson-callout-memory:before{content:"Memory";color:hsl(var(--lesson-callout-memory-accent))}.ProseMirror .lesson-callout-promise,.twolearn-lesson-page-body .lesson-callout-promise{background:hsl(var(--lesson-callout-promise-bg));border-color:hsl(var(--lesson-callout-promise-border))}.ProseMirror .lesson-callout-promise:before,.twolearn-lesson-page-body .lesson-callout-promise:before{content:"Promise";color:hsl(var(--lesson-callout-promise-accent))}.ProseMirror .lesson-callout-gratitude,.twolearn-lesson-page-body .lesson-callout-gratitude{background:hsl(var(--lesson-callout-gratitude-bg));border-color:hsl(var(--lesson-callout-gratitude-border))}.ProseMirror .lesson-callout-gratitude:before,.twolearn-lesson-page-body .lesson-callout-gratitude:before{content:"Gratitude";color:hsl(var(--lesson-callout-gratitude-accent))}.ProseMirror .lesson-callout-future-plan,.twolearn-lesson-page-body .lesson-callout-future-plan{background:hsl(var(--lesson-callout-future-bg));border-color:hsl(var(--lesson-callout-future-border))}.ProseMirror .lesson-callout-future-plan:before,.twolearn-lesson-page-body .lesson-callout-future-plan:before{content:"Future plan";color:hsl(var(--lesson-callout-future-accent))}.ProseMirror .lesson-callout-pronunciation-note,.twolearn-lesson-page-body .lesson-callout-pronunciation-note{background:hsl(var(--lesson-callout-pronunciation-bg));border-color:hsl(var(--lesson-callout-pronunciation-border))}.ProseMirror .lesson-callout-pronunciation-note:before,.twolearn-lesson-page-body .lesson-callout-pronunciation-note:before{content:"Pronunce it like me.";color:hsl(var(--lesson-callout-pronunciation-accent));font-style:italic}.twolearn-lesson-page-wrap{background:hsl(var(--background));border:1px solid hsl(var(--border));border-radius:var(--radius);box-shadow:0 4px 12px hsl(var(--foreground) / .05);max-width:100%;overflow:hidden}@media (max-width:860px){.twolearn-lesson-page-wrap{box-shadow:0 2px 8px hsl(var(--foreground) / .04)}}.twolearn-lesson-page-header{letter-spacing:.03em;color:hsl(var(--muted-foreground));background:hsl(var(--card));border-bottom:1px solid hsl(var(--border));padding:.6rem .85rem;font-size:.72rem;font-weight:500}.twolearn-lesson-page-body{width:210mm;min-height:297mm;padding:16mm;font-size:.875rem;line-height:1.65}@media (max-width:860px){.twolearn-lesson-page-body{width:100%;min-height:auto;padding:1rem}}@media print{.twolearn-lesson-page-wrap{box-shadow:none;border:none;border-radius:0}.twolearn-lesson-page-header{display:none}.twolearn-lesson-page-body{width:auto;min-height:auto;padding:0}}.twolearn-canvas-frame{box-shadow:0 4px 16px hsl(var(--foreground) / .06);border-radius:var(--radius)}.twolearn-canvas-surface{background-image:radial-gradient(circle at var(--canvas-grid-dot) var(--canvas-grid-dot), hsl(var(--muted-foreground) / .15) var(--canvas-grid-dot), transparent 0);background-size:var(--canvas-grid-size) var(--canvas-grid-size)}.dark .twolearn-canvas-surface{background-image:radial-gradient(circle at var(--canvas-grid-dot) var(--canvas-grid-dot), hsl(var(--muted-foreground) / .1) var(--canvas-grid-dot), transparent 0)}.twolearn-canvas-notes-layer,.twolearn-canvas-images-layer{pointer-events:none;position:absolute;inset:0}.twolearn-canvas-note{border:1px solid hsl(var(--border));box-shadow:0 1px 2px hsl(var(--foreground) / .05), 0 5px 16px hsl(var(--foreground) / .07);pointer-events:auto;border-radius:10px;flex-direction:column;display:flex;position:absolute;overflow:hidden}.twolearn-canvas-note-header{letter-spacing:.04em;-webkit-user-select:none;user-select:none;touch-action:none;align-items:center;gap:.35rem;min-width:0;padding:.22rem .35rem;font-size:.6rem;font-weight:600;display:flex}.twolearn-canvas-note-header-tape{border-bottom:1px solid #0000000f;box-shadow:inset 0 -1px #00000014}.dark .twolearn-canvas-note-header-tape{border-bottom:1px solid #ffffff1a;box-shadow:inset 0 -1px #ffffff14}.twolearn-canvas-note-drag-handle{cursor:grab;touch-action:none;border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;min-width:1.25rem;min-height:1.05rem;display:inline-flex}.twolearn-canvas-note-grip{opacity:.42;background-image:radial-gradient(currentColor 1px,#0000 1px);background-size:4px 4px;width:12px;height:10px;display:block}.twolearn-canvas-note-dragging .twolearn-canvas-note-drag-handle{cursor:grabbing}.twolearn-canvas-note-header-tools{flex-wrap:wrap;flex:1;justify-content:flex-end;align-items:center;gap:5px;min-width:0;display:flex}.twolearn-canvas-note-picker-row{flex-wrap:wrap;flex-shrink:0;justify-content:flex-end;align-items:center;gap:6px;display:flex}.twolearn-canvas-note-picker{cursor:pointer;align-items:center;gap:3px;margin:0;display:inline-flex}.twolearn-canvas-note-picker-label{letter-spacing:.07em;text-transform:uppercase;opacity:.82;white-space:nowrap;font-size:.52rem;font-weight:700}.twolearn-canvas-note-color-input{appearance:none;cursor:pointer;box-sizing:border-box;background:0 0;border:1px solid #0003;border-radius:4px;width:1.15rem;height:1.15rem;padding:0}.twolearn-canvas-note-color-input::-webkit-color-swatch-wrapper{padding:2px}.twolearn-canvas-note-color-input::-webkit-color-swatch{border:none;border-radius:2px}.twolearn-canvas-note-color-input::-moz-color-swatch{border:none;border-radius:2px}.twolearn-canvas-note-picker-font{align-items:center}.twolearn-canvas-note-font-select{letter-spacing:.02em;background:hsl(var(--background) / .55);max-width:4.2rem;height:1.15rem;color:inherit;cursor:pointer;box-sizing:border-box;border:1px solid #0003;border-radius:4px;padding:0 .15rem;font-size:.52rem;font-weight:600;line-height:1}.twolearn-canvas-note-font-select:focus{outline:1px solid hsl(var(--ring));outline-offset:1px}.twolearn-canvas-note-textarea{resize:none;color:hsl(var(--foreground));background:0 0;border:none;outline:none;flex:1;padding:.6rem;overflow:hidden}.twolearn-canvas-note[data-kind=sticky] .twolearn-canvas-note-textarea{color:#000;letter-spacing:.03em;text-align:center;font-size:1.6em;font-weight:600;line-height:1.2}.twolearn-canvas-note-delete{box-sizing:border-box;border:1px solid hsl(var(--foreground) / .2);background:hsl(var(--background) / .45);width:15px;height:15px;color:hsl(var(--foreground) / .55);cursor:pointer;box-shadow:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;margin-left:1px;font-size:10px;line-height:1;transition:background-color .15s,color .15s,border-color .15s;display:inline-flex}.twolearn-canvas-note-delete:hover{background:hsl(var(--destructive) / .16);color:hsl(var(--destructive));border-color:hsl(var(--destructive) / .45)}.twolearn-canvas-range{appearance:none;background:hsl(var(--muted));cursor:pointer;border-radius:2px;width:100%;height:4px}.twolearn-canvas-range::-webkit-slider-thumb{appearance:none;background:hsl(var(--primary));cursor:pointer;border:2px solid hsl(var(--background));width:16px;height:16px;box-shadow:0 1px 3px hsl(var(--foreground) / .15);border-radius:50%}.twolearn-canvas-range::-moz-range-thumb{background:hsl(var(--primary));cursor:pointer;border:2px solid hsl(var(--background));width:16px;height:16px;box-shadow:0 1px 3px hsl(var(--foreground) / .15);border-radius:50%}.twolearn-canvas-range:disabled{opacity:.5;cursor:not-allowed}.twolearn-canvas-range:disabled::-webkit-slider-thumb{cursor:not-allowed}.twolearn-canvas-range:disabled::-moz-range-thumb{cursor:not-allowed}.twolearn-canvas-image{pointer-events:auto;box-shadow:0 2px 8px hsl(var(--foreground) / .08);border:2px solid #0000;border-radius:8px;position:absolute;overflow:hidden}.twolearn-canvas-image-active{border-color:hsl(var(--primary));box-shadow:0 0 0 2px hsl(var(--primary) / .25), 0 4px 12px hsl(var(--foreground) / .1)}.twolearn-canvas-image-drag-area{cursor:move;z-index:1;position:absolute;inset:0}.twolearn-canvas-image-resize-handle{background:hsl(var(--primary));border:2px solid hsl(var(--background));z-index:2;pointer-events:auto;width:10px;height:10px;box-shadow:0 1px 3px hsl(var(--foreground) / .15);border-radius:50%;position:absolute}.twolearn-canvas-image-resize-se{cursor:se-resize;bottom:-5px;right:-5px}.twolearn-canvas-image-resize-sw{cursor:sw-resize;bottom:-5px;left:-5px}.twolearn-canvas-image-resize-ne{cursor:ne-resize;top:-5px;right:-5px}.twolearn-canvas-image-resize-nw{cursor:nw-resize;top:-5px;left:-5px}.twolearn-canvas-image-delete{background:hsl(var(--destructive));width:22px;height:22px;color:hsl(var(--destructive-foreground));cursor:pointer;z-index:3;pointer-events:auto;opacity:0;box-shadow:0 2px 4px hsl(var(--foreground) / .15);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:14px;line-height:1;transition:opacity .15s;display:flex;position:absolute;top:6px;right:6px}.twolearn-canvas-image:hover .twolearn-canvas-image-delete{opacity:1}.sr-rooms-page{background:linear-gradient(90deg, hsl(var(--border) / .28) 1px, transparent 1px) 0 0 / 42px 42px, linear-gradient(180deg, hsl(var(--border) / .2) 1px, transparent 1px) 0 0 / 42px 42px, radial-gradient(circle at 18% 4%, hsl(var(--love-light) / .82), transparent 30rem), hsl(var(--background));flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.sr-rooms-header{border-bottom:1px solid hsl(var(--border));background:hsl(var(--card) / .92);z-index:10;min-height:76px;box-shadow:0 12px 30px hsl(var(--foreground) / .04);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);flex-shrink:0;justify-content:space-between;align-items:center;gap:1rem;padding:.85rem clamp(.9rem,2vw,1.6rem);display:flex}.sr-rooms-header-main,.sr-rooms-header-actions{align-items:center;gap:.75rem;min-width:0;display:flex}.sr-rooms-header-actions{flex-shrink:0}.sr-rooms-title-block{flex-direction:column;gap:.12rem;min-width:0;display:flex}.sr-rooms-title{color:hsl(var(--foreground));margin:0;font-size:clamp(1.08rem,1vw + .85rem,1.45rem);font-weight:750;line-height:1.15}.sr-rooms-scroll{overscroll-behavior-y:contain;flex:1;min-height:0;padding:1rem clamp(.8rem,2.4vw,2rem) 2rem;overflow:hidden auto}.sr-rooms-scroll::-webkit-scrollbar{width:5px}.sr-rooms-scroll::-webkit-scrollbar-track{background:0 0}.sr-rooms-scroll::-webkit-scrollbar-thumb{background:hsl(var(--muted-foreground) / .22);border-radius:3px}.sr-rooms-hero,.sr-rooms-list,.sr-rooms-empty{width:min(100%,1040px);margin-left:auto;margin-right:auto}.sr-rooms-hero{border:1px solid hsl(var(--border));background:hsl(var(--card) / .9);box-shadow:0 18px 50px hsl(var(--foreground) / .06);border-radius:18px;justify-content:space-between;align-items:stretch;gap:1rem;margin-bottom:1rem;padding:clamp(1rem,2vw,1.35rem);display:flex}.sr-rooms-hero-copy{max-width:42rem}.sr-rooms-hero-label{color:hsl(var(--primary));letter-spacing:.07em;text-transform:uppercase;margin:0 0 .25rem;font-size:.72rem;font-weight:750}.sr-rooms-hero-title{letter-spacing:0;margin:0;font-size:clamp(1.45rem,2.4vw,2.35rem);font-weight:760;line-height:1.05}.sr-rooms-hero-text{max-width:40rem;color:hsl(var(--muted-foreground));margin:.7rem 0 0;font-size:.95rem;line-height:1.6}.sr-rooms-metrics{grid-template-columns:repeat(3,minmax(0,1fr));gap:.55rem;min-width:min(100%,360px);display:grid}.sr-rooms-metric{border-radius:16px;flex-direction:column;justify-content:flex-end;min-height:96px;padding:.85rem .9rem;display:flex;position:relative;overflow:hidden}.sr-rooms-metric:before{content:"";border:12px solid var(--metric-color);opacity:.13;pointer-events:none;border-radius:50%;width:72px;height:72px;position:absolute;top:-18px;right:-18px}.sr-rooms-metric:first-child{--metric-color:hsl(var(--primary));background:radial-gradient(circle at 10% 0%, hsl(var(--primary) / .18), transparent 65%), hsl(var(--background) / .75);border:1px solid hsl(var(--primary) / .25)}.sr-rooms-metric:nth-child(2){--metric-color:#2fb17b;background:radial-gradient(circle at 10% 0%, #2fb17b2e, transparent 65%), hsl(var(--background) / .75);border:1px solid #2fb17b47}.sr-rooms-metric:nth-child(3){--metric-color:#eaa32a;background:radial-gradient(circle at 10% 0%, #eaa32a2e, transparent 65%), hsl(var(--background) / .75);border:1px solid #eaa32a47}.sr-rooms-metric span{color:var(--metric-color);text-shadow:0 0 28px var(--metric-color);font-size:2rem;font-weight:800;line-height:1}.sr-rooms-metric p{color:hsl(var(--muted-foreground));letter-spacing:.06em;text-transform:uppercase;margin:.38rem 0 0;font-size:.68rem;font-weight:700}.sr-rooms-list{flex-direction:column;gap:.65rem;width:min(100%,1040px);margin:0 auto;padding:0;list-style:none;display:flex}.sr-rooms-item{color:hsl(var(--foreground));border:1px solid color-mix(in srgb, var(--room-color,hsl(var(--border))) 28%, hsl(var(--border)));border-left:3.5px solid var(--room-color,hsl(var(--border)));background:radial-gradient(ellipse at 0% 50%, color-mix(in srgb, var(--room-color,transparent) 10%, transparent), transparent 55%), hsl(var(--card) / .9);box-shadow:0 4px 14px hsl(var(--foreground) / .04);border-radius:16px;align-items:center;gap:1rem;padding:.9rem 1rem;text-decoration:none;transition:transform .18s,border-color .18s,box-shadow .18s,background .18s;display:flex}.sr-rooms-item:hover{background:radial-gradient(ellipse at 0% 50%, color-mix(in srgb, var(--room-color,transparent) 16%, transparent), transparent 60%), hsl(var(--card));box-shadow:0 10px 28px hsl(var(--foreground) / .07), 0 0 0 1px color-mix(in srgb, var(--room-color,transparent) 22%, transparent);transform:translateY(-1px)}.sr-rooms-avatar{color:#fff;letter-spacing:.02em;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1rem;font-weight:750;display:flex;box-shadow:inset 0 0 0 1.5px #ffffff38}.sr-rooms-item-info{flex-direction:column;flex:1;gap:.2rem;min-width:0;display:flex}.sr-rooms-item-top{align-items:center;gap:.6rem;min-width:0;display:flex}.sr-rooms-item-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.975rem;font-weight:700;line-height:1.25;overflow:hidden}.sr-rooms-item-badge{border:1px solid hsl(var(--primary) / .22);background:hsl(var(--love-light));height:22px;color:hsl(var(--primary));white-space:nowrap;border-radius:999px;flex-shrink:0;align-items:center;padding:0 .55rem;font-size:.66rem;font-weight:750;display:inline-flex}.sr-rooms-item-badge-muted{border-color:hsl(var(--border));background:hsl(var(--secondary) / .7);color:hsl(var(--muted-foreground))}.sr-rooms-item-date{font-variant-numeric:tabular-nums;flex-shrink:0}.sr-rooms-item-sub{color:hsl(var(--muted-foreground));text-overflow:ellipsis;white-space:nowrap;font-size:.83rem;line-height:1.4;overflow:hidden}.sr-rooms-item-footer{color:hsl(var(--muted-foreground));gap:.4rem .6rem;margin-top:.08rem;font-size:.72rem;font-weight:600;display:flex}.sr-rooms-item-footer span{align-items:center;display:inline-flex}.sr-rooms-item-footer span+span{display:none}.sr-rooms-item-open{border:1px solid hsl(var(--border));width:32px;height:32px;color:hsl(var(--muted-foreground) / .7);background:hsl(var(--background) / .5);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;transition:color .18s,background .18s,border-color .18s;display:inline-flex}.sr-rooms-item-chevron{opacity:.8}.sr-rooms-item:hover .sr-rooms-item-open{color:var(--room-color,hsl(var(--primary)));background:color-mix(in srgb, var(--room-color,hsl(var(--primary))) 12%, hsl(var(--card)));border-color:color-mix(in srgb, var(--room-color,hsl(var(--border))) 35%, hsl(var(--border)))}.sr-rooms-empty{border:1px dashed hsl(var(--primary) / .28);background:hsl(var(--card) / .78);text-align:center;border-radius:18px;flex-direction:column;justify-content:center;align-items:center;gap:.65rem;margin-top:1rem;padding:3rem 1.5rem;display:flex}.sr-rooms-empty-icon{width:68px;height:68px;color:hsl(var(--primary));background:hsl(var(--love-light));border:1px solid hsl(var(--primary) / .18);border-radius:18px;justify-content:center;align-items:center;margin-bottom:.3rem;display:inline-flex}.sr-rooms-empty-heading{color:hsl(var(--foreground));font-size:1.05rem;font-weight:750}.sr-rooms-empty-sub{color:hsl(var(--muted-foreground));max-width:28rem;font-size:.85rem;line-height:1.6}.sr-rooms-compose-btn{cursor:pointer;background:hsl(var(--primary));min-height:38px;color:hsl(var(--primary-foreground));box-shadow:0 8px 18px hsl(var(--primary) / .22);border:none;border-radius:999px;justify-content:center;align-items:center;gap:.45rem;padding:.45rem .85rem;font-size:.8rem;font-weight:750;transition:transform .15s,box-shadow .15s,opacity .15s;display:flex}.sr-rooms-compose-btn:hover{box-shadow:0 10px 24px hsl(var(--primary) / .28);transform:translateY(-1px)}.sr-rooms-overlay{z-index:50;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#13111894;justify-content:center;align-items:flex-start;padding:calc(69px + 1.25rem) 1rem 1.25rem;display:flex;position:fixed;inset:0;overflow-y:auto}.sr-rooms-dialog{background:radial-gradient(circle at 0% 0%, hsl(var(--love-light) / .75), transparent 18rem), hsl(var(--card));border:1px solid hsl(var(--border));border-radius:18px;width:92%;max-width:480px;animation:.2s ease-out sr-dialog-enter;overflow:hidden;box-shadow:0 24px 70px #13111859}@keyframes sr-dialog-enter{0%{opacity:0;transform:translateY(8px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.sr-rooms-dialog-header{border-bottom:1px solid hsl(var(--border));justify-content:space-between;align-items:center;padding:1.05rem 1.2rem;display:flex}.sr-rooms-dialog-kicker{color:hsl(var(--primary));letter-spacing:.07em;text-transform:uppercase;margin:0 0 .12rem;font-size:.68rem;font-weight:750}.sr-rooms-dialog-title{color:hsl(var(--foreground));margin:0;font-size:1.12rem;font-weight:750}.sr-rooms-dialog-close{border:1px solid hsl(var(--border));background:hsl(var(--background) / .72);width:40px;height:40px;color:hsl(var(--muted-foreground));cursor:pointer;border-radius:12px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.sr-rooms-dialog-close:hover{background:hsl(var(--love-light));color:hsl(var(--primary))}.sr-rooms-dialog-form{flex-direction:column;gap:1.05rem;padding:1.2rem;display:flex}.sr-rooms-dialog-field{flex-direction:column;gap:.4rem;display:flex}.sr-rooms-dialog-label{color:hsl(var(--foreground));letter-spacing:.01em;font-size:.76rem;font-weight:750}.sr-rooms-dialog-input,.sr-rooms-dialog-select{border:1px solid hsl(var(--border));background:hsl(var(--background) / .84);min-height:46px;color:hsl(var(--foreground));border-radius:14px;outline:none;padding:.68rem .85rem;font-size:.88rem;transition:border-color .2s,box-shadow .2s}.sr-rooms-dialog-input:focus,.sr-rooms-dialog-select:focus{border-color:hsl(var(--primary));box-shadow:0 0 0 3px hsl(var(--primary) / .1)}.sr-rooms-dialog-input::placeholder{color:hsl(var(--muted-foreground))}.sr-rooms-dialog-submit{background:hsl(var(--primary));min-height:46px;color:hsl(var(--primary-foreground));cursor:pointer;box-shadow:0 2px 6px hsl(var(--primary) / .25);border:none;border-radius:14px;margin-top:.25rem;padding:.68rem 1.25rem;font-size:.88rem;font-weight:750;transition:background .15s,box-shadow .15s}.sr-rooms-dialog-submit:hover{box-shadow:0 4px 12px hsl(var(--primary) / .3)}@media (max-width:760px){.sr-rooms-header{min-height:70px}.sr-rooms-header .sr-chat-room-mark{display:none}.sr-rooms-title{font-size:1rem}.sr-rooms-header .sr-chat-kicker{display:none}.sr-rooms-scroll{padding:.8rem .8rem 1.4rem}.sr-rooms-hero{border-radius:16px;flex-direction:column}.sr-rooms-metrics{min-width:0}.sr-rooms-metric{min-height:80px;padding:.7rem .75rem}.sr-rooms-metric span{font-size:1.55rem}.sr-rooms-list{grid-template-columns:1fr}.sr-rooms-item{border-radius:16px;min-height:142px}.sr-rooms-item-top{flex-direction:column;align-items:flex-start;gap:.35rem}.sr-rooms-item-open,.sr-rooms-compose-btn span{display:none}.sr-rooms-compose-btn{border-radius:12px;width:38px;padding:0}}.sr-shadowing-page{background:linear-gradient(90deg, hsl(var(--border) / .28) 1px, transparent 1px) 0 0 / 42px 42px, linear-gradient(180deg, hsl(var(--border) / .2) 1px, transparent 1px) 0 0 / 42px 42px, radial-gradient(circle at 82% 5%, hsl(var(--love-light) / .8), transparent 28rem), hsl(var(--background));flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.sr-shadowing-create{border:1px solid hsl(var(--border));background:hsl(var(--card) / .9);width:min(100%,1040px);box-shadow:0 10px 28px hsl(var(--foreground) / .045);border-radius:18px;margin-bottom:1rem;margin-left:auto;margin-right:auto;padding:clamp(.9rem,2vw,1.2rem) clamp(1rem,2vw,1.35rem)}.sr-shadowing-create-label{color:hsl(var(--primary));letter-spacing:.07em;text-transform:uppercase;margin:0 0 .65rem;font-size:.72rem;font-weight:750}.sr-shadowing-create-input{border:1px solid hsl(var(--border));background:hsl(var(--background) / .84);min-height:46px;color:hsl(var(--foreground));border-radius:14px;outline:none;flex:1;padding:.68rem .9rem;font-size:.88rem;transition:border-color .2s,box-shadow .2s}.sr-shadowing-create-input:focus{border-color:hsl(var(--primary));box-shadow:0 0 0 3px hsl(var(--primary) / .1)}.sr-shadowing-create-input::placeholder{color:hsl(var(--muted-foreground))}.sr-shadowing-create-btn{background:hsl(var(--primary));min-height:46px;color:hsl(var(--primary-foreground));cursor:pointer;box-shadow:0 2px 8px hsl(var(--primary) / .28);white-space:nowrap;border:none;border-radius:14px;flex-shrink:0;padding:.68rem 1.25rem;font-size:.88rem;font-weight:750;transition:box-shadow .15s,opacity .15s}.sr-shadowing-create-btn:hover:not(:disabled){box-shadow:0 4px 14px hsl(var(--primary) / .36)}.sr-shadowing-create-btn:disabled{opacity:.55;cursor:not-allowed}.sr-shadowing-list{flex-direction:column;gap:.65rem;width:min(100%,1040px);margin:0 auto;padding:0;list-style:none;display:flex}.sr-shadowing-item{border:1px solid color-mix(in srgb, var(--session-color,hsl(var(--border))) 28%, hsl(var(--border)));border-left:3.5px solid var(--session-color,hsl(var(--border)));background:radial-gradient(ellipse at 0% 50%, color-mix(in srgb, var(--session-color,transparent) 10%, transparent), transparent 55%), hsl(var(--card) / .9);min-height:76px;box-shadow:0 4px 14px hsl(var(--foreground) / .04);border-radius:16px;align-items:stretch;transition:transform .18s,border-color .18s,box-shadow .18s,background .18s;display:flex;overflow:hidden}.sr-shadowing-item:hover{background:radial-gradient(ellipse at 0% 50%, color-mix(in srgb, var(--session-color,transparent) 16%, transparent), transparent 60%), hsl(var(--card));box-shadow:0 10px 28px hsl(var(--foreground) / .07), 0 0 0 1px color-mix(in srgb, var(--session-color,transparent) 22%, transparent);transform:translateY(-1px)}.sr-shadowing-item-link{color:inherit;flex:1;align-items:center;gap:.85rem;min-width:0;padding:.85rem 1rem;text-decoration:none;display:flex}.sr-shadowing-avatar{color:#fff;letter-spacing:.02em;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1rem;font-weight:750;display:flex;box-shadow:inset 0 0 0 1.5px #ffffff38}.sr-shadowing-item-info{flex-direction:column;flex:1;gap:.18rem;min-width:0;display:flex}.sr-shadowing-item-top{align-items:center;gap:.5rem;min-width:0;display:flex}.sr-shadowing-item-name{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:.975rem;font-weight:700;line-height:1.25;overflow:hidden}.sr-shadowing-unread{background:hsl(var(--primary));min-width:20px;height:20px;color:hsl(var(--primary-foreground));border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;padding:0 .35rem;font-size:.65rem;font-weight:800;line-height:1;display:inline-flex}.sr-shadowing-item-preview{color:hsl(var(--muted-foreground));text-overflow:ellipsis;white-space:nowrap;font-size:.83rem;line-height:1.4;overflow:hidden}.sr-shadowing-item-date{color:hsl(var(--muted-foreground));margin-top:.06rem;font-size:.72rem;font-weight:600}.sr-shadowing-item-chevron{border:1px solid hsl(var(--border));width:32px;height:32px;color:hsl(var(--muted-foreground) / .7);background:hsl(var(--background) / .5);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;margin-right:.85rem;transition:color .18s,background .18s,border-color .18s;display:inline-flex}.sr-shadowing-item:hover .sr-shadowing-item-chevron{color:var(--session-color,hsl(var(--primary)));background:color-mix(in srgb, var(--session-color,hsl(var(--primary))) 12%, hsl(var(--card)));border-color:color-mix(in srgb, var(--session-color,hsl(var(--border))) 35%, hsl(var(--border)))}.sr-shadowing-item>form{align-self:stretch;display:flex}.sr-shadowing-item-delete{border:none;border-left:1px solid hsl(var(--border));width:48px;color:hsl(var(--muted-foreground) / .55);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:color .15s,background .15s;display:flex}.sr-shadowing-item-delete:hover{color:hsl(var(--destructive));background:hsl(var(--destructive) / .07)}.sr-shadowing-empty{border:1.5px dashed hsl(var(--primary) / .24);background:hsl(var(--card) / .6);text-align:center;border-radius:18px;flex-direction:column;align-items:center;gap:.6rem;width:min(100%,1040px);margin-left:auto;margin-right:auto;padding:3.5rem 2rem;display:flex}.sr-shadowing-empty-icon{border:1px solid hsl(var(--primary) / .18);background:hsl(var(--love-light));width:68px;height:68px;color:hsl(var(--primary));border-radius:18px;justify-content:center;align-items:center;margin-bottom:.3rem;display:flex}.sr-shadowing-empty-heading{color:hsl(var(--foreground));margin:0;font-size:1.05rem;font-weight:750}.sr-shadowing-empty-sub{color:hsl(var(--muted-foreground));max-width:28rem;margin:0;font-size:.85rem;line-height:1.6}@media (max-width:760px){.sr-shadowing-create{border-radius:14px}.sr-shadowing-list{gap:.5rem}.sr-shadowing-item{border-radius:14px}.sr-shadowing-item-link{gap:.7rem;padding:.75rem .85rem}.sr-shadowing-avatar{width:38px;height:38px;font-size:.875rem}.sr-shadowing-item-chevron{display:none}.sr-shadowing-empty{border-radius:14px;padding:2.5rem 1.5rem}}.sr-chat-page{background:hsl(var(--background));flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.sr-chat-header{border-bottom:1px solid hsl(var(--border));background:hsl(var(--card));z-index:10;flex-shrink:0;justify-content:space-between;align-items:center;gap:1rem;padding:.65rem 1.25rem;display:flex}.sr-chat-back-btn{width:44px;height:44px;color:hsl(var(--foreground));background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;transition:background .15s;display:flex}.sr-chat-back-btn:hover{background:hsl(var(--muted))}.sr-chat-header-link{color:hsl(var(--muted-foreground));border-radius:var(--radius);border:none;padding:.35rem .7rem;font-size:.78rem;font-weight:500;transition:color .15s,background .15s}.sr-chat-header-link:hover{background:hsl(var(--muted));color:hsl(var(--foreground))}.sr-chat-body{flex-direction:column;flex:1;min-height:0;display:flex;position:relative}.sr-scroll-to-end-btn{z-index:20;border:1px solid hsl(var(--border));background:hsl(var(--card));width:44px;height:44px;color:hsl(var(--foreground));box-shadow:0 4px 12px hsl(var(--foreground) / .1);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:background .15s,box-shadow .15s;display:flex;position:absolute;bottom:5rem;left:50%;transform:translate(-50%)}.sr-scroll-to-end-btn:hover{background:hsl(var(--accent));box-shadow:0 6px 16px hsl(var(--foreground) / .12)}.sr-chat-scroll{overscroll-behavior-y:contain;flex:1;min-height:0;overflow:hidden auto}.sr-chat-scroll::-webkit-scrollbar{width:5px}.sr-chat-scroll::-webkit-scrollbar-track{background:0 0}.sr-chat-scroll::-webkit-scrollbar-thumb{background:hsl(var(--muted-foreground) / .2);border-radius:3px}.sr-chat-scroll::-webkit-scrollbar-thumb:hover{background:hsl(var(--muted-foreground) / .35)}.sr-chat-feed{flex-direction:column;gap:.25rem;width:100%;padding:1.5rem 1.25rem 2rem;display:flex}@media (max-width:640px){.sr-chat-feed{padding:.75rem .75rem 1.5rem}.sr-chat-header{min-height:56px;padding:.4rem .75rem}.sr-chat-header-link{align-items:center;min-height:44px;padding:.6rem .75rem;display:inline-flex}.sr-input-bar{padding:.5rem .75rem}.sr-bubble{max-width:88%}.sr-bubble-system{max-width:80%}.sr-rooms-header{padding:.6rem .85rem}.sr-rooms-item{min-height:60px;padding:.7rem .85rem}}.sr-chat-empty{color:hsl(var(--muted-foreground));text-align:center;opacity:.6;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;padding:6rem 1.5rem;display:flex}.sr-bubble-row{width:100%;padding:.1rem 0;display:flex}.sr-bubble-row-own{justify-content:flex-end}.sr-bubble-row-other{justify-content:flex-start}.sr-bubble-row-center{justify-content:center}.sr-bubble{word-break:break-word;border-radius:16px;max-width:75%;padding:.7rem .95rem;font-size:.88rem;line-height:1.6;position:relative}.sr-bubble-other{background:hsl(var(--card));border:1px solid hsl(var(--border));border-bottom-left-radius:4px}.sr-bubble-system{background:hsl(var(--muted));opacity:.75;border-radius:12px;max-width:60%;font-size:.8rem}.sr-bubble-sender{color:hsl(var(--primary));margin-bottom:.15rem;font-size:.7rem;font-weight:600}.sr-bubble-time{color:hsl(var(--muted-foreground));text-align:right;opacity:.5;font-variant-numeric:tabular-nums;margin-top:.3rem;font-size:.62rem}.sr-bubble-sending{opacity:.45;font-style:italic}.sr-typing-indicator{color:hsl(var(--muted-foreground));opacity:.85;font-size:.75rem}.sr-typing-dots{animation:1.4s ease-in-out infinite sr-typing-bounce;display:inline-block}@keyframes sr-typing-bounce{0%,60%,to{opacity:.3}30%{opacity:1}}.sr-bubble-label{color:hsl(var(--muted-foreground));margin-bottom:.3rem;font-size:.68rem;font-weight:500}.sr-vocab-word{cursor:pointer;border-bottom:1.5px solid hsl(var(--primary) / .5);border-radius:2px;padding:0 2px;transition:background .15s,color .15s;display:inline}.sr-vocab-word:hover{background:hsl(var(--love-light));color:hsl(var(--primary))}.sr-bubble-image-wrap{margin:.15rem 0}.sr-bubble-image{-o-object-fit:cover;object-fit:cover;border-radius:10px;width:auto;max-width:100%;max-height:320px;display:block}.sr-bubble-image:hover{box-shadow:0 4px 12px hsl(var(--foreground) / .08)}.sr-audio-card{background:hsl(var(--card));border:1px solid hsl(var(--border));width:272px;max-width:min(272px,100%);box-shadow:0 1px 3px hsl(var(--foreground) / .06), 0 4px 16px hsl(var(--foreground) / .07);border-radius:18px;overflow:hidden}.sr-audio-card-translated{border-color:hsl(var(--primary) / .6);box-shadow:0 1px 3px hsl(var(--foreground) / .06), 0 4px 20px hsl(var(--primary) / .22), 0 0 0 3px hsl(var(--primary) / .1);transition:border-color .3s,box-shadow .3s}.sr-audio-card-translated .sr-audio-card-header{background:hsl(var(--primary) / .1);border-bottom-color:hsl(var(--primary) / .2)}.sr-audio-card-translated .sr-audio-card-header-icon{color:hsl(var(--primary));opacity:1}.sr-audio-card-banner{background:linear-gradient(90deg, hsl(var(--primary) / .12), hsl(var(--primary) / .06));border-bottom:1px solid hsl(var(--primary) / .2);color:hsl(var(--primary));align-items:center;gap:7px;padding:8px 14px;font-size:.72rem;font-weight:600;display:flex;overflow:hidden}.sr-audio-card-banner-icon{flex-shrink:0}.sr-audio-card-banner-dot{background:hsl(var(--primary));border-radius:50%;flex-shrink:0;width:7px;height:7px;margin-left:auto;animation:1.8s ease-in-out infinite sr-banner-dot-pulse}@keyframes sr-banner-dot-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.sr-audio-card-header{border-bottom:1px solid hsl(var(--border) / .6);background:hsl(var(--muted) / .45);align-items:center;gap:6px;padding:9px 14px 7px;display:flex}.sr-audio-card-header-icon{color:hsl(var(--primary));flex-shrink:0}.sr-audio-card-header-label{text-transform:uppercase;letter-spacing:.08em;color:hsl(var(--muted-foreground));flex:1;font-size:.65rem;font-weight:700}.sr-audio-card-header-sender{color:hsl(var(--primary));text-overflow:ellipsis;white-space:nowrap;max-width:90px;font-size:.65rem;font-weight:600;overflow:hidden}.sr-audio-card-player{padding:12px 14px 8px}.sr-audio-card-divider{background:hsl(var(--border) / .55);height:1px;margin:0 14px}.sr-audio-card-rating{padding:8px 14px 10px}.sr-audio-card-section-label{text-transform:uppercase;letter-spacing:.08em;color:hsl(var(--muted-foreground));margin-bottom:5px;font-size:.62rem;font-weight:700}.sr-audio-card-footer{padding:8px 14px 10px}.sr-audio-translate-btn{cursor:pointer;border:1.5px solid hsl(var(--primary) / .28);background:hsl(var(--primary) / .07);width:100%;color:hsl(var(--primary));border-radius:10px;justify-content:center;align-items:center;gap:6px;padding:7px 12px;font-size:.76rem;font-weight:500;transition:background .15s,border-color .15s;display:flex}.sr-audio-translate-btn:hover:not(:disabled){background:hsl(var(--primary) / .13);border-color:hsl(var(--primary) / .45)}.sr-audio-translate-btn:disabled{opacity:.6;cursor:default}.sr-audio-translate-btn-sent{border-color:hsl(var(--border));background:hsl(var(--muted) / .5);color:hsl(var(--muted-foreground))}.sr-audio-card-time{color:hsl(var(--muted-foreground));text-align:right;padding:0 14px 8px;font-size:.65rem}.sr-audio-player{align-items:center;gap:8px;width:100%;padding:2px 0;display:flex}.sr-audio-play-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#9e58e4,#4982f3);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;padding-left:2px;transition:transform .12s,filter .12s;display:flex;box-shadow:0 2px 10px #6952e04d}.sr-audio-play-btn:hover{filter:brightness(1.1);transform:scale(1.1)}.sr-audio-play-btn:active{transform:scale(.92)}.sr-audio-waveform{cursor:pointer;flex:1;align-items:center;gap:2px;height:32px;padding:2px 0;display:flex}.sr-audio-bar{transform-origin:50%;border-radius:3px;flex:0 0 3px}@keyframes sr-bar-pulse{0%,to{transform:scaleY(1)}50%{transform:scaleY(1.55)}}.sr-audio-bar-playing{animation:ease-in-out infinite sr-bar-pulse}.sr-audio-bar-played{background:linear-gradient(#5a8cf2,#9447e1)}.sr-audio-bar-unplayed{background:hsl(var(--muted-foreground) / .28)}.sr-audio-time{font-variant-numeric:tabular-nums;color:hsl(var(--muted-foreground));text-align:right;flex-shrink:0;min-width:30px;font-size:.68rem}.sr-bubble-link{color:hsl(var(--primary));text-underline-offset:3px;word-break:break-all;text-decoration:underline;text-decoration-thickness:1px;transition:color .15s}.sr-bubble-link:hover{color:hsl(var(--love-dark))}.sr-bubble-lesson{border:1px solid hsl(var(--border));border-radius:var(--radius);background:hsl(var(--background));box-shadow:0 2px 6px hsl(var(--foreground) / .05);overflow:hidden}.sr-bubble-lesson-header{background:hsl(var(--muted));border-bottom:1px solid hsl(var(--border));align-items:center;gap:.45rem;padding:.55rem .85rem;display:flex}.sr-bubble-lesson-title{color:hsl(var(--foreground));font-size:.83rem;font-weight:600;text-decoration:none;transition:color .15s}.sr-bubble-lesson-title:hover{color:hsl(var(--primary));text-decoration:underline}.sr-bubble-lesson-body{max-height:320px;padding:.65rem .85rem;font-size:.82rem;overflow-y:auto}.sr-bubble-lesson-body .prose-editor{min-height:unset!important;border:none!important;padding:0!important}.sr-input-bar{border-top:1px solid hsl(var(--border));background:hsl(var(--card));z-index:10;flex-shrink:0;padding:.65rem 1.25rem}.sr-input-error{color:hsl(var(--destructive));background:hsl(var(--destructive) / .06);border:1px solid hsl(var(--destructive) / .2);border-radius:var(--radius);margin-bottom:.35rem;padding:.3rem .65rem;font-size:.76rem;overflow:hidden}.sr-input-text-row{align-items:flex-end;gap:.4rem;display:flex}.sr-input-textarea{border:1px solid hsl(var(--border));background:hsl(var(--background));min-height:42px;max-height:140px;color:hsl(var(--foreground));resize:none;field-sizing:content;border-radius:20px;outline:none;flex:1;padding:.6rem .9rem;font-size:.88rem;transition:border-color .2s,box-shadow .2s}.sr-input-textarea:focus{border-color:hsl(var(--primary) / .5);box-shadow:0 0 0 3px hsl(var(--primary) / .08)}.sr-input-textarea::placeholder{color:hsl(var(--muted-foreground));opacity:.6}.sr-input-icon-btn{width:44px;height:44px;color:hsl(var(--muted-foreground));cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.sr-input-icon-btn:hover:not(:disabled){background:hsl(var(--muted));color:hsl(var(--foreground))}.sr-input-icon-btn:disabled{opacity:.35;cursor:not-allowed}.sr-input-send-btn{background:hsl(var(--primary));width:44px;height:44px;color:hsl(var(--primary-foreground));cursor:pointer;box-shadow:0 2px 6px hsl(var(--primary) / .25);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:transform .15s,box-shadow .15s;display:flex}.sr-input-send-btn:hover:not(:disabled){box-shadow:0 4px 12px hsl(var(--primary) / .3);transform:scale(1.05)}.sr-input-send-btn:disabled{opacity:.3;cursor:not-allowed}.sr-actions-dropdown{background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:var(--radius);box-shadow:0 8px 24px hsl(var(--foreground) / .1);z-index:20;min-width:180px;max-width:min(220px,100vw - 1rem);padding:.3rem;position:absolute;bottom:calc(100% + .5rem);left:0;right:auto}.sr-actions-item{width:100%;color:hsl(var(--foreground));border-radius:calc(var(--radius) - 4px);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.55rem;padding:.5rem .75rem;font-size:.82rem;font-weight:500;transition:background .15s;display:flex}.sr-actions-item:hover{background:hsl(var(--accent) / .5)}.sr-actions-item:disabled{opacity:.4;cursor:not-allowed}.sr-input-recording{justify-content:space-between;align-items:center;gap:.75rem;padding:.35rem 0;display:flex}.sr-recording-indicator{align-items:center;gap:.5rem;display:flex}.sr-recording-dot{background:hsl(var(--destructive));border-radius:50%;flex-shrink:0;width:10px;height:10px;animation:1.2s ease-in-out infinite sr-pulse}@keyframes sr-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}.sr-recording-time{font-variant-numeric:tabular-nums;min-width:3ch;font-size:.95rem;font-weight:600}.sr-input-btn{border-radius:var(--radius);cursor:pointer;border:none;padding:.45rem 1rem;font-size:.82rem;font-weight:600;transition:background .15s,box-shadow .15s}.sr-input-btn:hover:not(:disabled){box-shadow:0 2px 6px hsl(var(--foreground) / .08)}.sr-input-btn:disabled{opacity:.4;cursor:not-allowed}.sr-input-btn-cancel{color:hsl(var(--muted-foreground));background:0 0}.sr-input-btn-cancel:hover:not(:disabled){background:hsl(var(--muted));color:hsl(var(--foreground))}.sr-input-btn-stop{background:hsl(var(--destructive));color:hsl(var(--destructive-foreground))}.sr-input-btn-send{background:hsl(var(--primary));color:hsl(var(--primary-foreground))}.sr-chat-page{background:linear-gradient(90deg, hsl(var(--border) / .32) 1px, transparent 1px) 0 0 / 42px 42px, linear-gradient(180deg, hsl(var(--border) / .22) 1px, transparent 1px) 0 0 / 42px 42px, radial-gradient(circle at 15% 0%, hsl(var(--love-light) / .8), transparent 32rem), hsl(var(--background));height:calc(100dvh - 69px);max-height:calc(100dvh - 69px)}.sr-chat-header{background:hsl(var(--card) / .92);border-bottom-color:hsl(var(--border) / .8);min-height:76px;box-shadow:0 12px 30px hsl(var(--foreground) / .04);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);padding:.85rem clamp(.9rem,2vw,1.6rem)}.sr-chat-header-main,.sr-chat-header-actions{align-items:center;gap:.75rem;min-width:0;display:flex}.sr-chat-header-actions{flex-shrink:0}.sr-chat-room-mark,.sr-study-stage-icon,.sr-input-lesson-icon,.sr-bubble-lesson-mark{color:hsl(var(--primary));background:hsl(var(--love-light));border:1px solid hsl(var(--primary) / .18);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.sr-chat-room-mark{border-radius:14px;width:46px;height:46px}.sr-chat-title-block{flex-direction:column;gap:.12rem;min-width:0;display:flex}.sr-chat-kicker{letter-spacing:.08em;text-transform:uppercase;color:hsl(var(--primary));margin:0;font-size:.68rem;font-weight:700}.sr-chat-title{text-overflow:ellipsis;white-space:nowrap;max-width:min(46vw,38rem);margin:0;font-size:clamp(1.05rem,1vw + .85rem,1.45rem);font-weight:750;line-height:1.15;overflow:hidden}.sr-chat-lesson-link{text-overflow:ellipsis;white-space:nowrap;width:fit-content;max-width:min(46vw,34rem);color:hsl(var(--muted-foreground));align-items:center;gap:.35rem;font-size:.8rem;font-weight:600;display:inline-flex;overflow:hidden}.sr-chat-lesson-link:hover{color:hsl(var(--primary))}.sr-chat-header-link{border:1px solid hsl(var(--border));background:hsl(var(--background) / .72);min-height:38px;color:hsl(var(--foreground));align-items:center;padding:.45rem .85rem;font-weight:650;display:inline-flex}.sr-chat-header-link:hover{background:hsl(var(--love-light));color:hsl(var(--primary));border-color:hsl(var(--primary) / .24)}.sr-chat-back-btn{border:1px solid hsl(var(--border));background:hsl(var(--background) / .72);border-radius:12px;width:42px;height:42px}.sr-chat-back-btn:hover{background:hsl(var(--love-light));color:hsl(var(--primary));border-color:hsl(var(--primary) / .24)}.sr-chat-scroll{padding:0 clamp(.8rem,2.4vw,2rem)}.sr-study-stage,.sr-chat-feed{width:min(100%,1040px);margin:0 auto}.sr-study-stage{border:1px solid hsl(var(--border));background:hsl(var(--card) / .9);width:min(100% - clamp(1.6rem,4.8vw,4rem),1040px);box-shadow:0 18px 50px hsl(var(--foreground) / .06);border-radius:18px;justify-content:space-between;align-items:center;gap:1rem;margin:1rem auto 0;padding:1rem;display:flex}.sr-study-stage-copy{align-items:center;gap:.9rem;min-width:0;display:flex}.sr-study-stage-icon{border-radius:14px;width:48px;height:48px}.sr-study-stage-label{letter-spacing:.07em;text-transform:uppercase;color:hsl(var(--primary));margin:0 0 .12rem;font-size:.72rem;font-weight:750}.sr-study-stage-title{margin:0;font-size:clamp(1rem,.75vw + .9rem,1.28rem);font-weight:750;line-height:1.2}.sr-study-stage-text{max-width:42rem;color:hsl(var(--muted-foreground));margin:.22rem 0 0;font-size:.86rem;line-height:1.45}.sr-study-stage-steps{flex-shrink:0;align-items:center;gap:.35rem;display:flex}.sr-study-stage-steps span{border:1px solid hsl(var(--border));background:hsl(var(--background) / .72);min-height:30px;color:hsl(var(--muted-foreground));border-radius:999px;align-items:center;padding:.3rem .62rem;font-size:.72rem;font-weight:700;display:inline-flex}.sr-chat-feed{gap:.55rem;padding:1rem 0 1.5rem}.sr-chat-empty{border:1px dashed hsl(var(--primary) / .3);background:hsl(var(--card) / .74);opacity:1;border-radius:18px;width:min(100%,620px);margin:2.5rem auto;padding:2.2rem 1.5rem}.sr-chat-empty-icon{width:64px;height:64px;color:hsl(var(--primary));background:hsl(var(--love-light));border:1px solid hsl(var(--primary) / .18);border-radius:18px;justify-content:center;align-items:center;display:inline-flex}.sr-chat-empty-heading,.sr-chat-empty-copy{margin:0}.sr-chat-empty-heading{max-width:28rem;color:hsl(var(--foreground));font-size:1rem;font-weight:750}.sr-chat-empty-copy{max-width:34rem;color:hsl(var(--muted-foreground));font-size:.9rem;line-height:1.55}.sr-bubble-row{padding:.2rem 0}.sr-bubble{max-width:min(74%,680px);box-shadow:0 8px 24px hsl(var(--foreground) / .045);border-radius:16px;padding:.78rem .95rem}.sr-bubble-own{background:hsl(var(--primary));color:hsl(var(--primary-foreground));border-bottom-right-radius:5px}.sr-bubble-own .sr-bubble-time,.sr-bubble-own .sr-bubble-label{color:hsl(var(--primary-foreground) / .74)}.sr-bubble-own .sr-vocab-word{border-bottom-color:hsl(var(--primary-foreground) / .55)}.sr-bubble-own .sr-vocab-word:hover{background:hsl(var(--primary-foreground) / .14);color:hsl(var(--primary-foreground))}.sr-bubble-other{background:hsl(var(--card));border:1px solid hsl(var(--border))}.sr-bubble-system{background:hsl(var(--secondary) / .82);border:1px solid hsl(var(--border));opacity:1;max-width:min(78%,760px);padding:.62rem .9rem}.sr-bubble-sender{color:hsl(var(--primary));letter-spacing:.01em}.sr-bubble-lesson{background:hsl(var(--card));width:100%;box-shadow:0 16px 42px hsl(var(--foreground) / .07);border-radius:18px}.sr-bubble-lesson-shell{width:min(100%,760px);max-width:min(100%,760px);box-shadow:none;background:0 0;border:none;padding:0}.sr-bubble-lesson-shell .sr-bubble-time{text-align:right;padding:.35rem .25rem 0}.sr-bubble-lesson-header{background:linear-gradient(135deg, hsl(var(--love-light)), hsl(var(--card)));align-items:center;gap:.7rem;padding:.8rem}.sr-bubble-lesson-mark{background:hsl(var(--card) / .88);border-radius:12px;width:40px;height:40px}.sr-bubble-lesson-heading{flex:1;min-width:0}.sr-bubble-lesson-heading p{letter-spacing:.07em;text-transform:uppercase;color:hsl(var(--primary));margin:0 0 .08rem;font-size:.7rem;font-weight:750}.sr-bubble-lesson-title{text-overflow:ellipsis;white-space:nowrap;font-size:1rem;font-weight:750;display:block;overflow:hidden}.sr-bubble-lesson-open{border:1px solid hsl(var(--primary) / .24);background:hsl(var(--card) / .85);min-height:34px;color:hsl(var(--primary));border-radius:999px;align-items:center;padding:.35rem .75rem;font-size:.78rem;font-weight:750;text-decoration:none;display:inline-flex}.sr-bubble-lesson-open:hover{background:hsl(var(--primary));color:hsl(var(--primary-foreground))}.sr-bubble-lesson-body{background:hsl(var(--background) / .48);max-height:300px;padding:1rem}.sr-input-bar{background:hsl(var(--card) / .94);border-top-color:hsl(var(--border) / .78);box-shadow:0 -14px 36px hsl(var(--foreground) / .045);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);padding:.7rem clamp(.8rem,2.4vw,2rem) .85rem}.sr-input-bar>*{width:min(100%,1040px);margin-left:auto;margin-right:auto}.sr-input-lesson-strip{border:1px solid hsl(var(--primary) / .18);background:hsl(var(--love-light) / .66);border-radius:14px;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.65rem;padding:.55rem .65rem;display:flex}.sr-input-lesson-copy{align-items:center;gap:.55rem;min-width:0;display:flex}.sr-input-lesson-icon{background:hsl(var(--card) / .82);border-radius:10px;width:34px;height:34px}.sr-input-lesson-text{text-overflow:ellipsis;white-space:nowrap;min-width:0;color:hsl(var(--muted-foreground));font-size:.82rem;font-weight:600;overflow:hidden}.sr-input-lesson-text strong{color:hsl(var(--foreground));font-weight:750}.sr-input-present-btn{background:hsl(var(--primary));min-height:34px;color:hsl(var(--primary-foreground));cursor:pointer;box-shadow:0 8px 18px hsl(var(--primary) / .22);border:none;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;padding:.35rem .8rem;font-size:.78rem;font-weight:750;transition:transform .15s,box-shadow .15s,opacity .15s;display:inline-flex}.sr-input-present-btn:hover:not(:disabled){box-shadow:0 10px 24px hsl(var(--primary) / .26);transform:translateY(-1px)}.sr-input-present-btn:disabled{opacity:.45;cursor:not-allowed}.sr-input-text-row{align-items:flex-end;gap:.5rem}.sr-input-textarea{background:hsl(var(--background) / .84);border-radius:16px;min-height:46px;padding:.72rem 1rem;font-size:.92rem}.sr-input-icon-btn,.sr-input-send-btn{border-radius:14px;width:46px;height:46px}.sr-input-icon-btn{border:1px solid hsl(var(--border));background:hsl(var(--background) / .72)}.sr-input-icon-btn:hover:not(:disabled){background:hsl(var(--love-light));color:hsl(var(--primary));border-color:hsl(var(--primary) / .24)}.sr-actions-dropdown{box-shadow:0 16px 42px hsl(var(--foreground) / .12);border-radius:14px}@media (max-width:760px){.sr-chat-header{min-height:64px}.sr-chat-room-mark{display:none}.sr-chat-title{max-width:48vw;font-size:1rem}.sr-chat-kicker,.sr-chat-lesson-link{display:none}.sr-chat-header-link{min-height:36px;padding:.42rem .65rem;font-size:.74rem}.sr-study-stage{border-radius:16px;flex-direction:column;align-items:flex-start;width:min(100% - 1.6rem,1040px);padding:.85rem}.sr-study-stage-copy{align-items:flex-start}.sr-study-stage-icon{width:42px;height:42px}.sr-study-stage-steps{width:100%;padding-bottom:.1rem;overflow-x:auto}.sr-chat-feed{padding-top:.75rem}.sr-bubble,.sr-bubble-system{max-width:92%}.sr-bubble-lesson{width:min(92vw,100%)}.sr-input-lesson-strip{flex-direction:column;align-items:stretch}.sr-input-present-btn{width:100%}.sr-input-text-row{gap:.35rem}.sr-input-icon-btn,.sr-input-send-btn{width:42px;height:42px}}.ob-page{background:hsl(var(--background));justify-content:center;align-items:center;min-height:100dvh;padding:2rem 1.5rem;display:flex}.ob-container{flex-direction:column;gap:1.75rem;width:100%;max-width:520px;display:flex}.ob-header{text-align:center}.ob-step-badge{letter-spacing:.03em;color:hsl(var(--primary));background:hsl(var(--love-light));border:1px solid hsl(var(--primary) / .2);border-radius:999px;align-items:center;gap:.35rem;margin-bottom:1rem;padding:.35rem .9rem;font-size:.72rem;font-weight:500;display:inline-flex}.ob-title{font-family:var(--font-serif), Georgia, serif;letter-spacing:-.02em;color:hsl(var(--foreground));font-size:2rem;font-weight:700;line-height:1.15}.ob-subtitle{color:hsl(var(--muted-foreground));margin-top:.65rem;max-width:38rem;margin-inline:auto;font-size:.92rem;line-height:1.65}.ob-form{flex-direction:column;gap:.85rem;display:flex}.ob-panel{border:1px solid hsl(var(--border));border-radius:var(--radius);background:hsl(var(--card));box-shadow:0 4px 16px hsl(var(--foreground) / .04);gap:.9rem;padding:1rem;display:flex}.ob-panel-muted{background:hsl(var(--muted) / .35)}.ob-panel-icon{background:hsl(var(--love-light));width:2.5rem;height:2.5rem;color:hsl(var(--primary));border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.ob-panel-content{flex:1;min-width:0}.ob-fields{gap:.75rem;margin-top:.85rem;display:grid}.ob-field{gap:.35rem;display:grid}.ob-field-label{color:hsl(var(--muted-foreground));font-size:.76rem;font-weight:600}.ob-select{border:1px solid hsl(var(--border));border-radius:var(--radius);background:hsl(var(--background));width:100%;min-width:0;min-height:2.75rem;color:hsl(var(--foreground));outline:none;padding:0 .8rem;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.ob-select:focus{border-color:hsl(var(--primary));box-shadow:0 0 0 3px hsl(var(--primary) / .12)}.ob-input{border:1px solid hsl(var(--border));border-radius:var(--radius);background:hsl(var(--background));width:100%;min-width:0;min-height:2.75rem;color:hsl(var(--foreground));outline:none;padding:0 .8rem;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.ob-input:focus{border-color:hsl(var(--primary));box-shadow:0 0 0 3px hsl(var(--primary) / .12)}.ob-field-invite-email{margin-top:.85rem}.ob-field-hint{color:hsl(var(--muted-foreground));margin:0;font-size:.72rem;line-height:1.35}.ob-submit{border-radius:var(--radius);background:hsl(var(--primary));min-height:2.9rem;color:hsl(var(--primary-foreground));justify-content:center;align-items:center;gap:.45rem;font-size:.92rem;font-weight:700;transition:opacity .2s;display:inline-flex}.ob-submit:disabled{cursor:not-allowed;opacity:.55}.ob-card{border:1px solid hsl(var(--border));border-radius:var(--radius);background:hsl(var(--card));text-align:left;cursor:pointer;align-items:stretch;transition:border-color .2s,box-shadow .2s;display:flex;overflow:hidden}.ob-card:hover{border-color:hsl(var(--primary) / .4);box-shadow:0 4px 16px hsl(var(--primary) / .08)}.ob-card-spanish:hover,.ob-card-romanian:hover{border-color:hsl(var(--primary) / .5)}.ob-card-flag{flex-direction:column;flex-shrink:0;width:5px;display:flex}.ob-flag-band{flex:1}.ob-flag-es-red{background:#df2020}.ob-flag-es-yellow{background:#f9bf10}.ob-flag-ro-blue{background:#2b60ca}.ob-flag-ro-yellow{background:#f9d210}.ob-flag-ro-red{background:#df2020}.ob-card-body{flex:1;min-width:0;padding:1rem 1.15rem}.ob-card-title{font-family:var(--font-serif), Georgia, serif;color:hsl(var(--foreground));font-size:1.05rem;font-weight:600;line-height:1.3}.ob-card-desc{color:hsl(var(--muted-foreground));margin-top:.35rem;font-size:.84rem;line-height:1.6}.ob-card-tags{flex-wrap:wrap;gap:.35rem;margin-top:.65rem;display:flex}.ob-tag{background:hsl(var(--muted));color:hsl(var(--muted-foreground));border:none;border-radius:999px;padding:.2rem .6rem;font-size:.68rem;font-weight:500;display:inline-block}.ob-tag-bridge{background:hsl(var(--love-light));color:hsl(var(--primary))}.ob-card-arrow{color:hsl(var(--primary));opacity:0;flex-shrink:0;align-items:center;padding:0 .85rem;transition:opacity .2s,transform .2s;display:flex;transform:translate(-4px)}.ob-card:hover .ob-card-arrow{opacity:1;transform:translate(0)}@media (max-width:420px){.ob-panel{flex-direction:column}}.ob-footer-note{text-align:center;color:hsl(var(--muted-foreground));opacity:.6;max-width:36rem;margin-inline:auto;font-size:.78rem;line-height:1.65}.ob-signin-prompt{border:1px solid hsl(var(--border));border-radius:calc(var(--radius) + 4px);background:hsl(var(--card));text-align:center;box-shadow:0 4px 16px hsl(var(--foreground) / .06);flex-direction:column;align-items:center;gap:.85rem;padding:2.5rem 2rem;display:flex}.ob-signin-icon{background:hsl(var(--love-light));width:52px;height:52px;color:hsl(var(--primary));border:none;border-radius:50%;justify-content:center;align-items:center;margin-bottom:.25rem;display:flex}.ob-signin-text{color:hsl(var(--muted-foreground));font-size:.92rem}.ob-signin-link{background:hsl(var(--primary));color:hsl(var(--primary-foreground));border-radius:var(--radius);box-shadow:0 2px 6px hsl(var(--primary) / .25);border:none;align-items:center;gap:.35rem;padding:.55rem 1.35rem;font-size:.85rem;font-weight:600;text-decoration:none;transition:box-shadow .15s;display:inline-flex}.ob-signin-link:hover{box-shadow:0 4px 16px hsl(var(--primary) / .3)}.ob-skeleton-heading{background:hsl(var(--muted));border-radius:8px;width:55%;height:1.85rem;margin-inline:auto;animation:1.5s ease-in-out infinite ob-shimmer}.ob-skeleton-sub{background:hsl(var(--muted));border-radius:6px;width:80%;height:.9rem;margin:.75rem auto 0;animation:1.5s ease-in-out .1s infinite ob-shimmer}.ob-skeleton-card{background:hsl(var(--muted));border:1px solid hsl(var(--border));border-radius:var(--radius);height:100px;animation:1.5s ease-in-out .2s infinite ob-shimmer}.ob-skeleton-card+.ob-skeleton-card{animation-delay:.3s}@keyframes ob-shimmer{0%,to{opacity:.45}50%{opacity:.75}}.ss-page{background:hsl(var(--background));justify-content:center;align-items:flex-start;min-height:100dvh;padding:3rem 1.5rem 4rem;display:flex}.ss-container{flex-direction:column;gap:1.5rem;width:100%;max-width:580px;display:flex}.ss-header{text-align:center}.ss-badge{letter-spacing:.03em;color:hsl(var(--primary));background:hsl(var(--love-light));border:1px solid hsl(var(--primary) / .2);border-radius:999px;align-items:center;gap:.35rem;margin-bottom:1rem;padding:.35rem .9rem;font-size:.72rem;font-weight:500;display:inline-flex}.ss-title{font-family:var(--font-serif), Georgia, serif;letter-spacing:-.02em;color:hsl(var(--foreground));font-size:2rem;font-weight:700;line-height:1.15}.ss-subtitle{color:hsl(var(--muted-foreground));margin-top:.65rem;max-width:38rem;margin-inline:auto;font-size:.92rem;line-height:1.65}.ss-status-card{border:1px solid hsl(var(--border));border-radius:var(--radius);background:hsl(var(--card));box-shadow:0 2px 8px hsl(var(--foreground) / .04);flex-direction:column;gap:1rem;padding:1.25rem;display:flex}.ss-status-connected{border-color:#5eba94}.ss-status-waiting{border-color:hsl(var(--primary) / .5)}.ss-status-row{align-items:center;gap:.85rem;display:flex}.ss-status-indicator-wrap{background:hsl(var(--muted));border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.ss-status-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.ss-dot-connected{background:#3db885}.ss-dot-waiting{background:hsl(var(--primary));animation:2s ease-in-out infinite ss-pulse}@keyframes ss-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}.ss-status-info{flex-direction:column;gap:.1rem;display:flex}.ss-status-label{color:hsl(var(--foreground));font-size:.92rem;font-weight:600}.ss-status-detail{color:hsl(var(--muted-foreground));font-size:.8rem}.ss-members{border-top:1px solid hsl(var(--border));gap:.75rem;padding-top:.75rem;display:flex}@media (max-width:480px){.ss-members{flex-direction:column}}.ss-member{background:hsl(var(--muted) / .5);border-radius:var(--radius);flex:1;align-items:center;gap:.65rem;min-width:0;padding:.65rem .75rem;display:flex}.ss-member-empty{opacity:.55}.ss-member-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.85rem;font-weight:600;display:flex}.ss-member-avatar-owner{background:hsl(var(--primary))}.ss-member-avatar-partner{background:#3b9b73}.ss-member-avatar-empty{background:hsl(var(--muted-foreground) / .3);color:hsl(var(--muted-foreground))}.ss-member-info{flex-direction:column;gap:.05rem;min-width:0;display:flex}.ss-member-name{color:hsl(var(--foreground));white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:600;overflow:hidden}.ss-member-name-empty{color:hsl(var(--muted-foreground));font-weight:400}.ss-member-role{color:hsl(var(--muted-foreground));font-size:.68rem;font-weight:500}.ss-invite-card{border:1px solid hsl(var(--border));border-radius:var(--radius);background:hsl(var(--card));box-shadow:0 2px 8px hsl(var(--foreground) / .04);flex-direction:column;gap:.65rem;padding:1.15rem 1.25rem;display:flex}.ss-invite-header{color:hsl(var(--primary));align-items:center;gap:.5rem;display:flex}.ss-invite-title{font-family:var(--font-serif), Georgia, serif;color:hsl(var(--foreground));font-size:.92rem;font-weight:600}.ss-invite-desc{color:hsl(var(--muted-foreground));font-size:.82rem;line-height:1.55}.ss-invite-row{align-items:center;gap:.5rem;display:flex}.ss-invite-code{border:1px solid hsl(var(--border));border-radius:var(--radius);background:hsl(var(--muted));color:hsl(var(--foreground));white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;padding:.55rem .85rem;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace;font-size:.8rem;overflow:hidden}.ss-invite-copy-btn{border:1px solid hsl(var(--border));border-radius:var(--radius);background:hsl(var(--background));color:hsl(var(--foreground));cursor:pointer;flex-shrink:0;align-items:center;gap:.35rem;padding:.55rem 1rem;font-size:.82rem;font-weight:500;transition:background .15s,border-color .15s;display:inline-flex}.ss-invite-copy-btn:hover{background:hsl(var(--muted));border-color:hsl(var(--foreground) / .2)}.ss-invite-copy-btn-done{color:#36a174;background:#f1f9f5;border-color:#70c2a0}.dark .ss-invite-copy-btn-done{color:#6ecfa6;background:#1b2d25;border-color:#428a6c}.ss-nav-grid{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}@media (max-width:540px){.ss-nav-grid{grid-template-columns:1fr}}.ss-nav-card{border:1px solid hsl(var(--border));border-radius:var(--radius);background:hsl(var(--card));color:hsl(var(--foreground));align-items:center;gap:.75rem;padding:1rem 1.1rem;text-decoration:none;transition:border-color .2s,box-shadow .2s;display:flex}.ss-nav-card:hover{border-color:hsl(var(--primary) / .4);box-shadow:0 4px 16px hsl(var(--primary) / .08)}.ss-nav-icon{background:hsl(var(--love-light));width:42px;height:42px;color:hsl(var(--primary));border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.ss-nav-card-body{flex-direction:column;flex:1;gap:.1rem;min-width:0;display:flex}.ss-nav-card-label{color:hsl(var(--foreground));font-size:.88rem;font-weight:600}.ss-nav-card-desc{color:hsl(var(--muted-foreground));font-size:.72rem;line-height:1.45}.ss-nav-card-chevron{color:hsl(var(--muted-foreground));opacity:0;flex-shrink:0;transition:opacity .2s,transform .2s;transform:translate(-4px)}.ss-nav-card:hover .ss-nav-card-chevron{opacity:.6;transform:translate(0)}.ss-footer-note{text-align:center;color:hsl(var(--muted-foreground));opacity:.6;max-width:36rem;margin-inline:auto;padding:.5rem 0;font-size:.82rem;line-height:1.65}.tl-scrollbar-track{z-index:9999;opacity:0;cursor:pointer;border-radius:3px;width:6px;position:fixed;top:4px;bottom:4px;right:4px}.tl-scrollbar-track:before{content:"";background:hsl(var(--muted-foreground) / .06);border-radius:3px;position:absolute;inset:0}.tl-scrollbar-thumb{background:hsl(var(--primary) / .35);will-change:transform;border-radius:3px;width:100%;transition:background .2s;position:absolute;top:0;left:0}.tl-scrollbar-thumb:hover,.tl-scrollbar-thumb[data-active=true]{background:hsl(var(--primary) / .6)}.tl-scrollbar-thumb[data-active=true]{box-shadow:0 0 0 1px hsl(var(--primary) / .3)}.placeholder\:text-muted-foreground::placeholder{color:hsl(var(--muted-foreground))}.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)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:scale-125:hover{--tw-scale-x:1.25;--tw-scale-y:1.25;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:scale-\[1\.02\]:hover{--tw-scale-x:1.02;--tw-scale-y:1.02;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:border-border:hover{border-color:hsl(var(--border))}.hover\:border-primary\/20:hover{border-color:hsl(var(--primary) / .2)}.hover\:bg-accent:hover{background-color:hsl(var(--accent))}.hover\:bg-destructive\/10:hover{background-color:hsl(var(--destructive) / .1)}.hover\:bg-muted:hover{background-color:hsl(var(--muted))}.hover\:bg-primary-foreground\/10:hover{background-color:hsl(var(--primary-foreground) / .1)}.hover\:text-accent-foreground:hover{color:hsl(var(--accent-foreground))}.hover\:text-destructive:hover{color:hsl(var(--destructive))}.hover\:text-foreground:hover{color:hsl(var(--foreground))}.hover\:text-primary:hover{color:hsl(var(--primary))}.hover\:text-red-400:hover{--tw-text-opacity:1;color:rgb(248 113 113/var(--tw-text-opacity,1))}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-90:hover{opacity:.9}.hover\:shadow-glow:hover{--tw-shadow:0 0 20px hsl(var(--primary) / .12);--tw-shadow-colored:0 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)}.hover\:shadow-soft:hover{--tw-shadow:0 1px 3px 0 hsl(var(--foreground) / .04), 0 1px 2px -1px hsl(var(--foreground) / .04);--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-soft-md:hover{--tw-shadow:0 4px 6px -1px hsl(var(--foreground) / .05), 0 2px 4px -2px hsl(var(--foreground) / .04);--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\:ring-1: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(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)}.hover\:ring-foreground\/20:hover{--tw-ring-color:hsl(var(--foreground) / .2)}.hover\:brightness-110:hover{--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)}.focus\:border-border:focus{border-color:hsl(var(--border))}.focus\:border-destructive:focus{border-color:hsl(var(--destructive))}.focus\:border-primary:focus{border-color:hsl(var(--primary))}.focus\:bg-accent:focus{background-color:hsl(var(--accent))}.focus\:text-accent-foreground:focus{color:hsl(var(--accent-foreground))}.focus\:outline-none:focus{outline-offset:2px;outline:2px solid #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-ring:focus{--tw-ring-color:hsl(var(--ring))}.focus-visible\:border-primary:focus-visible{border-color:hsl(var(--primary))}.focus-visible\:outline-none:focus-visible{outline-offset:2px;outline:2px solid #0000}.focus-visible\:ring-2:focus-visible{--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-visible\:ring-primary:focus-visible{--tw-ring-color:hsl(var(--primary))}.focus-visible\:ring-primary-foreground:focus-visible{--tw-ring-color:hsl(var(--primary-foreground))}.focus-visible\:ring-ring:focus-visible{--tw-ring-color:hsl(var(--ring))}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px}.focus-visible\:ring-offset-background:focus-visible{--tw-ring-offset-color:hsl(var(--background))}.focus-visible\:ring-offset-primary:focus-visible{--tw-ring-offset-color:hsl(var(--primary))}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:opacity-60:disabled{opacity:.6}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[state\=open\]\:bg-accent[data-state=open]{background-color:hsl(var(--accent))}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[state\=open\]\:animate-in[data-state=open]{--tw-enter-opacity:initial;--tw-enter-scale:initial;--tw-enter-rotate:initial;--tw-enter-translate-x:initial;--tw-enter-translate-y:initial;animation-name:enter;animation-duration:.15s}.data-\[state\=closed\]\:animate-out[data-state=closed]{--tw-exit-opacity:initial;--tw-exit-scale:initial;--tw-exit-rotate:initial;--tw-exit-translate-x:initial;--tw-exit-translate-y:initial;animation-name:exit;animation-duration:.15s}.data-\[state\=closed\]\:fade-out-0[data-state=closed]{--tw-exit-opacity:0}.data-\[state\=open\]\:fade-in-0[data-state=open]{--tw-enter-opacity:0}.data-\[state\=closed\]\:zoom-out-95[data-state=closed]{--tw-exit-scale:.95}.data-\[state\=open\]\:zoom-in-95[data-state=open]{--tw-enter-scale:.95}.data-\[side\=bottom\]\:slide-in-from-top-2[data-side=bottom]{--tw-enter-translate-y:-.5rem}.data-\[side\=left\]\:slide-in-from-right-2[data-side=left]{--tw-enter-translate-x:.5rem}.data-\[side\=right\]\:slide-in-from-left-2[data-side=right]{--tw-enter-translate-x:-.5rem}.data-\[side\=top\]\:slide-in-from-bottom-2[data-side=top]{--tw-enter-translate-y:.5rem}.dark\:border-emerald-500\/30:is(.dark *){border-color:#10b9814d}.dark\:bg-emerald-300:is(.dark *){--tw-bg-opacity:1;background-color:rgb(110 231 183/var(--tw-bg-opacity,1))}.dark\:bg-emerald-400\/10:is(.dark *){background-color:#34d3991a}.dark\:bg-emerald-500:is(.dark *){--tw-bg-opacity:1;background-color:rgb(16 185 129/var(--tw-bg-opacity,1))}.dark\:bg-emerald-600:is(.dark *){--tw-bg-opacity:1;background-color:rgb(5 150 105/var(--tw-bg-opacity,1))}.dark\:bg-emerald-800:is(.dark *){--tw-bg-opacity:1;background-color:rgb(6 95 70/var(--tw-bg-opacity,1))}.dark\:bg-emerald-900\/70:is(.dark *){background-color:#064e3bb3}.dark\:bg-red-950:is(.dark *){--tw-bg-opacity:1;background-color:rgb(69 10 10/var(--tw-bg-opacity,1))}.dark\:text-emerald-100:is(.dark *){--tw-text-opacity:1;color:rgb(209 250 229/var(--tw-text-opacity,1))}.dark\:text-emerald-200:is(.dark *){--tw-text-opacity:1;color:rgb(167 243 208/var(--tw-text-opacity,1))}.dark\:text-emerald-950:is(.dark *){--tw-text-opacity:1;color:rgb(2 44 34/var(--tw-text-opacity,1))}.dark\:text-green-300:is(.dark *){--tw-text-opacity:1;color:rgb(134 239 172/var(--tw-text-opacity,1))}.dark\:text-red-300:is(.dark *){--tw-text-opacity:1;color:rgb(252 165 165/var(--tw-text-opacity,1))}@media (min-width:640px){.sm\:ml-auto{margin-left:auto}.sm\:block{display:block}.sm\:flex{display:flex}.sm\:w-auto{width:auto}.sm\:min-w-\[300px\]{min-width:300px}.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-\[0\.9fr_1\.1fr\]{grid-template-columns:.9fr 1.1fr}.sm\:grid-cols-\[220px_1fr\]{grid-template-columns:220px 1fr}.sm\:flex-row{flex-direction:row}.sm\:items-start{align-items:flex-start}.sm\:items-center{align-items:center}.sm\:justify-between{justify-content:space-between}.sm\:gap-3{gap:.75rem}.sm\:p-3{padding:.75rem}.sm\:p-5{padding:1.25rem}.sm\:p-6{padding:1.5rem}.sm\:px-5{padding-left:1.25rem;padding-right:1.25rem}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}.sm\:py-14{padding-top:3.5rem;padding-bottom:3.5rem}.sm\:py-8{padding-top:2rem;padding-bottom:2rem}.sm\:text-2xl{font-size:1.5rem;line-height:2rem}.sm\:text-4xl{font-size:2.25rem;line-height:2.5rem}.sm\:text-base{font-size:1rem;line-height:1.5rem}}@media (min-width:768px){.md\:block{display:block}.md\:hidden{display:none}.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-5{grid-template-columns:repeat(5,minmax(0,1fr))}.md\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.md\:grid-cols-\[1\.3fr_minmax\(0\,1fr\)\]{grid-template-columns:1.3fr minmax(0,1fr)}.md\:grid-cols-\[minmax\(0\,1\.6fr\)_minmax\(0\,1\.2fr\)\]{grid-template-columns:minmax(0,1.6fr) minmax(0,1.2fr)}.md\:flex-row{flex-direction:row}.md\:items-end{align-items:flex-end}.md\:items-center{align-items:center}.md\:justify-between{justify-content:space-between}.md\:p-6{padding:1.5rem}.md\:px-8{padding-left:2rem;padding-right:2rem}.md\:py-10{padding-top:2.5rem;padding-bottom:2.5rem}.md\:text-2xl{font-size:1.5rem;line-height:2rem}.md\:text-3xl{font-size:1.875rem;line-height:2.25rem}.md\:text-5xl{font-size:3rem;line-height:1}}@media (min-width:1024px){.lg\:sticky{position:sticky}.lg\:top-6{top:1.5rem}.lg\:min-w-\[360px\]{min-width:360px}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:grid-cols-\[minmax\(0\,1\.5fr\)_minmax\(280px\,0\.9fr\)\]{grid-template-columns:minmax(0,1.5fr) minmax(280px,.9fr)}.lg\:grid-cols-\[minmax\(280px\,420px\)_1fr\]{grid-template-columns:minmax(280px,420px) 1fr}.lg\:flex-row{flex-direction:row}.lg\:items-start{align-items:flex-start}.lg\:items-end{align-items:flex-end}.lg\:justify-between{justify-content:space-between}.lg\:px-16{padding-left:4rem;padding-right:4rem}.lg\:px-8{padding-left:2rem;padding-right:2rem}.lg\:text-\[3\.5rem\]{font-size:3.5rem}}@media (min-width:1280px){.xl\:sticky{position:sticky}.xl\:top-6{top:1.5rem}.xl\:block{display:block}.xl\:flex{display:flex}.xl\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.xl\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.xl\:grid-cols-\[minmax\(0\,1\.55fr\)_320px\]{grid-template-columns:minmax(0,1.55fr) 320px}.xl\:grid-cols-\[minmax\(0\,1\.7fr\)_340px\]{grid-template-columns:minmax(0,1.7fr) 340px}.xl\:grid-cols-\[minmax\(0\,1fr\)_280px\]{grid-template-columns:minmax(0,1fr) 280px}.xl\:grid-cols-\[minmax\(0\,1fr\)_320px\]{grid-template-columns:minmax(0,1fr) 320px}.xl\:grid-cols-\[minmax\(0\,1fr\)_minmax\(0\,1fr\)_280px\]{grid-template-columns:minmax(0,1fr) minmax(0,1fr) 280px}.xl\:self-start{align-self:flex-start}}.\[\&\:\:-webkit-details-marker\]\:hidden::-webkit-details-marker{display:none}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{width:1rem;height:1rem}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}