/*! tailwindcss v4.2.0 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-ease:initial;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1}}}@layer theme{:root,:host{--font-sans:"DM Sans", sans-serif;--font-mono:"DM Mono", monospace;--color-red-50:oklch(97.1% .013 17.38);--color-red-200:oklch(88.5% .062 18.334);--color-red-300:oklch(80.8% .114 19.571);--color-red-400:oklch(70.4% .191 22.216);--color-red-500:oklch(63.7% .237 25.331);--color-red-700:oklch(50.5% .213 27.518);--color-red-800:oklch(44.4% .177 26.899);--color-red-900:oklch(39.6% .141 25.723);--color-orange-300:oklch(83.7% .128 66.29);--color-orange-700:oklch(55.3% .195 38.402);--color-orange-900:oklch(40.8% .123 38.172);--color-amber-300:oklch(87.9% .169 91.605);--color-amber-400:oklch(82.8% .189 84.429);--color-amber-700:oklch(55.5% .163 48.998);--color-amber-900:oklch(41.4% .112 45.904);--color-green-50:oklch(98.2% .018 155.826);--color-green-200:oklch(92.5% .084 155.995);--color-green-300:oklch(87.1% .15 154.449);--color-green-400:oklch(79.2% .209 151.711);--color-green-500:oklch(72.3% .219 149.579);--color-green-700:oklch(52.7% .154 150.069);--color-green-800:oklch(44.8% .119 151.328);--color-green-900:oklch(39.3% .095 152.535);--color-indigo-300:oklch(78.5% .115 274.713);--color-indigo-400:oklch(67.3% .182 276.935);--color-indigo-500:oklch(58.5% .233 277.117);--color-indigo-900:oklch(35.9% .144 278.697);--color-purple-400:oklch(71.4% .203 305.504);--color-purple-500:oklch(62.7% .265 303.9);--color-gray-300:oklch(87.2% .01 258.338);--color-gray-400:oklch(70.7% .022 261.325);--color-gray-500:oklch(55.1% .027 264.364);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-800:oklch(27.8% .033 256.848);--color-white:#fff;--spacing:.25rem;--container-xs:20rem;--container-md:28rem;--container-2xl:42rem;--container-3xl:48rem;--container-4xl:56rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height:calc(1.5 / 1);--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--text-3xl:1.875rem;--text-3xl--line-height:calc(2.25 / 1.875);--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--font-weight-extrabold:800;--tracking-wider:.05em;--leading-snug:1.375;--leading-relaxed:1.625;--radius-sm:.25rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--ease-out:cubic-bezier(0, 0, .2, 1);--ease-in-out:cubic-bezier(.4, 0, .2, 1);--animate-spin:spin 1s linear infinite;--animate-ping:ping 1s cubic-bezier(0, 0, .2, 1) infinite;--animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-bg:#f5f1eb;--color-card:#fefdfb;--color-txt:#1c1812;--color-sub:#6d665b;--color-muted:#887f72;--color-faint:#b5ad9f;--color-accent:#2c261e;--color-accent-text:#f5f1eb;--color-dark:#1c1912;--color-dark-text:#e8e4dc;--color-dark-sub:#908880;--color-dark-muted:#605848;--color-link:#8b6d28;--radius-btn:11px;--radius-card:14px;--radius-section:20px;--animate-enter:enter .55s ease both}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);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}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}html{scroll-behavior:smooth}::selection{background:#7864461a}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}@layer components{.border-lr{border-color:#1c18120f}.border-lr-hover{border-color:#1c181221}.border-lr-dark{border-color:#fffaf00f}.card-hover{transition:all .2s}.card-hover:hover{border-color:#1c181221;transform:translateY(-2px);box-shadow:0 8px 30px #1c181214,0 2px 8px #1c18120a}.hover-lift{transition:all .2s}.hover-lift:hover{transform:translateY(-1px);box-shadow:0 4px 12px #1c18121a,0 1px 3px #1c18120f}.btn-shadow{box-shadow:0 1px 3px #1c18121f,0 1px 2px #1c18120f}.btn-shadow:hover{box-shadow:0 4px 12px #1c181226,0 2px 4px #1c181214}.nav-scrolled{-webkit-backdrop-filter:blur(16px)saturate(1.4);background:#f5f1ebe0;border-bottom-color:#1c18120f}.section-dark{background:linear-gradient(#1c1912 0%,#191610 100%)}.delay-100{animation-delay:.1s}.delay-200{animation-delay:.2s}.delay-300{animation-delay:.3s}.delay-400{animation-delay:.4s}.delay-500{animation-delay:.5s}.label-mono{letter-spacing:2px;text-transform:uppercase;font-family:DM Mono,monospace;font-size:.56rem}.auth-card{-webkit-backdrop-filter:blur(50px)saturate(1.4);background:#ffffff80;border:1px solid #1c181212;border-radius:20px;box-shadow:0 8px 32px #1c18120d,0 1px 3px #1c181208}.auth-input{color:#1c1812;background:#fff;border:1px solid #1c18121a;border-radius:10px;outline:none;width:100%;padding:.68rem .85rem;font-family:DM Sans,sans-serif;font-size:.86rem;transition:border-color .2s,box-shadow .2s}.auth-input::placeholder{color:#a09889}.auth-input:focus{border-color:#1c181238;box-shadow:0 0 0 3px #1c18120a}.auth-label{color:#6d665b;margin-bottom:.35rem;font-family:DM Sans,sans-serif;font-size:.72rem;font-weight:500;display:block}.auth-btn{color:#f5f1eb;cursor:pointer;background:#2c261e;border:none;border-radius:11px;width:100%;padding:.72rem 1rem;font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:600;transition:all .2s;box-shadow:0 1px 3px #1c18121f,0 1px 2px #1c18120f}.auth-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #1c181226,0 2px 4px #1c181214}.auth-btn:active{transform:translateY(0)}.auth-google-btn{color:#1c1812;cursor:pointer;background:#fff;border:1px solid #1c18121a;border-radius:11px;justify-content:center;align-items:center;gap:.6rem;width:100%;padding:.65rem 1rem;font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:500;transition:all .2s;display:flex}.auth-google-btn:hover{border-color:#1c181233;box-shadow:0 2px 8px #1c18120f}.auth-enter{animation:.45s both authEnter}@keyframes authEnter{0%{opacity:0;transform:translateY(16px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.auth-errors{background:#b0605014;border:1px solid #b0605026;border-radius:10px;margin-bottom:1rem;padding:.7rem .85rem}.auth-errors p{color:#b06050;margin:0;font-family:DM Sans,sans-serif;font-size:.72rem;font-weight:500}.auth-errors ul{margin:.3rem 0 0;padding-left:1rem}.auth-errors li{color:#b06050;font-family:DM Sans,sans-serif;font-size:.68rem;line-height:1.4}.auth-flash{border-radius:10px;max-width:370px;margin:0 auto 1rem;padding:.6rem .85rem;font-family:DM Sans,sans-serif;font-size:.72rem;font-weight:500;animation:.35s both authEnter}.auth-flash-notice{color:#3d7a5a;background:#5ba8801a;border:1px solid #5ba8802e}.auth-flash-alert{color:#b06050;background:#b0605014;border:1px solid #b0605026}.highlight .k,.highlight .kd,.highlight .kn,.highlight .kp,.highlight .kr,.highlight .kt{color:#ff7b72}.highlight .s,.highlight .s1,.highlight .s2,.highlight .sb,.highlight .sc,.highlight .sd,.highlight .sh,.highlight .sx{color:#a5d6ff}.highlight .nf,.highlight .nb{color:#d2a8ff}.highlight .c,.highlight .c1,.highlight .cm,.highlight .cs{color:#8b949e;font-style:italic}.highlight .mi,.highlight .mf,.highlight .mh,.highlight .mo{color:#79c0ff}.highlight .no,.highlight .nc{color:#ffa657}.highlight .o,.highlight .ow{color:#ff7b72}.highlight .p,.highlight .n,.highlight .na,.highlight .ni,.highlight .ne,.highlight .nv,.highlight .vi,.highlight .vg{color:#c9d1d9}.highlight .nn{color:#ffa657}.highlight .nt{color:#7ee787}.highlight .gh{color:#d2a8ff;font-weight:700}.highlight .gd{color:#ffa198;background-color:#f851491a}.highlight .gi{color:#7ee787;background-color:#3fb9501a}.code-block{margin-block:calc(var(--spacing) * 4);border-radius:var(--radius-xl);border:1px solid var(--color-border-subtle);background-color:#0d1117;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,Liberation Mono,monospace;overflow:hidden}.lesson-content{font-size:.9375rem;line-height:1.7}.lesson-content h1{margin-top:calc(var(--spacing) * 8);margin-bottom:calc(var(--spacing) * 4);font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height));--tw-font-weight:var(--font-weight-extrabold);font-weight:var(--font-weight-extrabold);color:var(--color-txt);letter-spacing:-.3px}.lesson-content h2{margin-top:calc(var(--spacing) * 8);margin-bottom:calc(var(--spacing) * 3);font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height));--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold);color:var(--color-txt);letter-spacing:-.2px}.lesson-content h3{margin-top:calc(var(--spacing) * 6);margin-bottom:calc(var(--spacing) * 2);font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height));--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold);color:var(--color-txt)}.lesson-content h4{margin-top:calc(var(--spacing) * 4);margin-bottom:calc(var(--spacing) * 2);font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height));--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold);color:var(--color-sub)}.lesson-content p{margin-bottom:calc(var(--spacing) * 4);--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed);color:var(--color-sub);font-size:inherit}.lesson-content strong{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold);color:var(--color-txt)}.lesson-content em{color:var(--color-sub);font-style:italic}.lesson-content ul{margin-bottom:calc(var(--spacing) * 4);margin-left:calc(var(--spacing) * 2);list-style-type:disc;list-style-position:inside}:where(.lesson-content ul>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)))}.lesson-content ul{color:var(--color-sub)}.lesson-content ol{margin-bottom:calc(var(--spacing) * 4);margin-left:calc(var(--spacing) * 2);list-style-type:decimal;list-style-position:inside}:where(.lesson-content ol>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)))}.lesson-content ol{color:var(--color-sub)}.lesson-content li{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed);font-size:inherit}.lesson-content blockquote{margin-block:calc(var(--spacing) * 5);padding-block:calc(var(--spacing) * 2);padding-left:calc(var(--spacing) * 5);color:var(--color-muted);background:linear-gradient(135deg,#6366f10a,#0000);border-left:3px solid #6366f1;border-radius:0 12px 12px 0;padding-right:1.25rem;font-style:italic}.lesson-content a{text-underline-offset:2px;transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration));color:var(--color-link);text-decoration-line:underline}.lesson-content code:not(pre code){padding-inline:calc(var(--spacing) * 1.5);padding-block:calc(var(--spacing) * .5);font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));background:var(--color-tint-strong);border:1px solid var(--color-border-subtle);color:var(--color-badge-review-text);border-radius:.25rem;font-family:ui-monospace,SFMono-Regular,monospace}.lesson-content table{margin-bottom:calc(var(--spacing) * 5);border-collapse:collapse;border:1px solid var(--color-border-subtle);border-radius:12px;width:100%;overflow:hidden}.lesson-content th{padding-inline:calc(var(--spacing) * 4);padding-block:calc(var(--spacing) * 3);text-align:left;font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold);background:var(--color-tint-strong);color:var(--color-txt);border-bottom:1px solid var(--color-border-subtle);font-family:DM Sans,sans-serif}.lesson-content td{padding-inline:calc(var(--spacing) * 4);padding-block:calc(var(--spacing) * 3);font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));color:var(--color-sub);border-bottom:1px solid var(--color-border-subtle)}.lesson-content tr:last-child td{border-bottom:none}.lesson-content tr:hover td{background:var(--color-tint)}.lesson-content hr{margin-block:calc(var(--spacing) * 8);border-color:var(--color-border-subtle);opacity:.5;border-style:solid}.lesson-content img{margin-block:calc(var(--spacing) * 5);border-radius:14px;max-width:100%;box-shadow:0 2px 8px #0000000a,0 8px 24px #00000005}.mermaid-container{margin-block:calc(var(--spacing) * 6);border:1px solid var(--color-border-subtle);background:var(--color-card);border-radius:14px;overflow:hidden;box-shadow:0 1px 3px #00000005,0 4px 12px #00000003}.mermaid-label{letter-spacing:.12em;text-transform:uppercase;color:var(--color-muted);padding:.625rem 1.25rem 0;font-family:DM Mono,monospace;font-size:.5625rem;font-weight:600;display:block}.mermaid-container .mermaid{-webkit-overflow-scrolling:touch;text-align:center;padding:1.25rem;overflow-x:auto}.mermaid-container .mermaid svg{max-width:100%;height:auto}.mermaid-caption{color:var(--color-muted);text-align:center;padding:0 1.25rem .75rem;font-size:.8125rem;font-style:italic}.mermaid--rendered{min-height:60px}.mermaid-fallback{padding:1rem 1.25rem}.mermaid-fallback__header{color:var(--color-muted);align-items:center;gap:.5rem;margin-bottom:.75rem;font-family:DM Mono,monospace;font-size:.75rem;font-weight:500;display:flex}.mermaid-fallback__code{background:var(--color-tint);white-space:pre-wrap;color:var(--color-sub);border-radius:8px;margin:0;padding:.75rem 1rem;font-size:.75rem;line-height:1.5;overflow-x:auto}@media (max-width:640px){.mermaid-container .mermaid{padding:.75rem}}@media print{.mermaid-container{break-inside:avoid;border:1px solid #ccc}.mermaid--rendered svg{max-width:100%!important}}.lesson-block{margin-block:calc(var(--spacing) * 6);border-radius:var(--radius-2xl);border:1px solid var(--color-border-subtle);background:var(--color-card);overflow:hidden;box-shadow:0 1px 3px #00000005,0 4px 12px #00000003}.lesson-block__header{align-items:center;gap:calc(var(--spacing) * 2.5);padding-inline:calc(var(--spacing) * 5);padding-block:calc(var(--spacing) * 3.5);font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold);border-bottom:1px solid var(--color-border-subtle);color:var(--color-txt);display:flex}.lesson-block__icon{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.lesson-block__title{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold);color:var(--color-txt)}.lesson-block__body{padding-inline:calc(var(--spacing) * 5);padding-block:calc(var(--spacing) * 4)}.lesson-block__body p{margin-bottom:calc(var(--spacing) * 3);font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed);color:var(--color-sub)}.lesson-block__body p:last-child,.lesson-block__body ul{margin-bottom:calc(var(--spacing) * 0)}.lesson-block--concept{background:linear-gradient(135deg, #f5f4fa, var(--color-card));border-left:4px solid #6366f1}@supports (color:color-mix(in lab, red, red)){.lesson-block--concept{background:linear-gradient(135deg, color-mix(in srgb, #6366f1 6%, var(--color-card)), var(--color-card))}}.lesson-block--concept{box-shadow:0 1px 3px #6366f10a,0 4px 16px #6366f105}.lesson-block--tip{background:linear-gradient(135deg, #fef8ef, var(--color-card));border-left:4px solid #f59e0b}@supports (color:color-mix(in lab, red, red)){.lesson-block--tip{background:linear-gradient(135deg, color-mix(in srgb, #f59e0b 5%, var(--color-card)), var(--color-card))}}.lesson-block--tip{box-shadow:0 1px 3px #f59e0b0a,0 4px 16px #f59e0b05}.lesson-block--example{background:linear-gradient(135deg, #f2faf5, var(--color-card));border-left:4px solid #10b981}@supports (color:color-mix(in lab, red, red)){.lesson-block--example{background:linear-gradient(135deg, color-mix(in srgb, #10b981 5%, var(--color-card)), var(--color-card))}}.lesson-block--example{box-shadow:0 1px 3px #10b9810a,0 4px 16px #10b98105}.lesson-block--summary{border-left:4px solid var(--color-txt);background:linear-gradient(135deg, #f5f4f2, var(--color-card))}@supports (color:color-mix(in lab, red, red)){.lesson-block--summary{background:linear-gradient(135deg, color-mix(in srgb, var(--color-txt) 4%, var(--color-card)), var(--color-card))}}.lesson-block--check{background:linear-gradient(135deg, #f8f5fb, var(--color-card));border-left:4px solid #8b5cf6}@supports (color:color-mix(in lab, red, red)){.lesson-block--check{background:linear-gradient(135deg, color-mix(in srgb, #8b5cf6 5%, var(--color-card)), var(--color-card))}}.lesson-block--check{box-shadow:0 1px 3px #8b5cf60a,0 4px 16px #8b5cf605}.lesson-check__question{margin-bottom:calc(var(--spacing) * 3);font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium);color:var(--color-txt)}.lesson-check__options{gap:calc(var(--spacing) * 2.5);flex-direction:column;display:flex}.lesson-check__option{cursor:pointer;align-items:center;gap:calc(var(--spacing) * 3.5);border-radius:var(--radius-xl);padding-inline:calc(var(--spacing) * 5);padding-block:calc(var(--spacing) * 3.5);text-align:left;font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration));border:1.5px solid var(--color-border-subtle);background:var(--color-card);color:var(--color-sub);display:flex;box-shadow:0 1px 3px #00000005}.lesson-check__option:hover{background:#f7f3fb;border-color:#8b5cf659}@supports (color:color-mix(in lab, red, red)){.lesson-check__option:hover{background:color-mix(in srgb, #8b5cf6 6%, var(--color-card))}}.lesson-check__option:hover{transform:translateY(-1px);box-shadow:0 2px 8px #8b5cf614}.lesson-check__letter{height:calc(var(--spacing) * 7);width:calc(var(--spacing) * 7);border-radius:var(--radius-lg);font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height));--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold);background:var(--color-tint-strong);color:var(--color-sub);flex-shrink:0;justify-content:center;align-items:center;transition:all .2s;display:flex}.lesson-check__option:hover .lesson-check__letter{color:#8b5cf6;background:#8b5cf61f}.lesson-check__option--correct{background:#e1f5ec!important;border-color:#10b981!important}@supports (color:color-mix(in lab, red, red)){.lesson-check__option--correct{background:color-mix(in srgb, #10b981 12%, var(--color-card))!important}}.lesson-check__option--correct{color:var(--color-txt)!important;opacity:1!important}.lesson-check__option--correct .lesson-check__letter{color:#fff;background:#10b981}.lesson-check__option--wrong{background:#fdebe9!important;border-color:#ef4444!important}@supports (color:color-mix(in lab, red, red)){.lesson-check__option--wrong{background:color-mix(in srgb, #ef4444 10%, var(--color-card))!important}}.lesson-check__option--wrong{opacity:1!important}.lesson-check__option--wrong .lesson-check__letter{color:#fff;background:#ef4444}.lesson-check__feedback{margin-top:calc(var(--spacing) * 3);border-radius:var(--radius-lg);padding-inline:calc(var(--spacing) * 4);padding-block:calc(var(--spacing) * 2);font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.lesson-check__feedback--correct{background:#10b981}@supports (color:color-mix(in lab, red, red)){.lesson-check__feedback--correct{background:color-mix(in srgb, #10b981 15%, var(--color-tint))}}.lesson-check__feedback--correct{color:#10b981}.lesson-check__feedback--wrong{background:#ef4444}@supports (color:color-mix(in lab, red, red)){.lesson-check__feedback--wrong{background:color-mix(in srgb, #ef4444 10%, var(--color-tint))}}.lesson-check__feedback--wrong{color:#ef4444}}@layer utilities{.collapse{visibility:collapse}.collapse\!{visibility:collapse!important}.invisible{visibility:hidden}.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.inset-0{inset:calc(var(--spacing) * 0)}.inset-y-0{inset-block:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.start\!{inset-inline-start:var(--spacing)!important}.end{inset-inline-end:var(--spacing)}.end\!{inset-inline-end:var(--spacing)!important}.top-0{top:calc(var(--spacing) * 0)}.top-20{top:calc(var(--spacing) * 20)}.right-0{right:calc(var(--spacing) * 0)}.left-0{left:calc(var(--spacing) * 0)}.isolate{isolation:isolate}.z-\[100\]{z-index:100}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mx-auto{margin-inline:auto}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-1\.5{margin-top:calc(var(--spacing) * 1.5)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-5{margin-top:calc(var(--spacing) * 5)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mt-8{margin-top:calc(var(--spacing) * 8)}.mt-10{margin-top:calc(var(--spacing) * 10)}.mt-12{margin-top:calc(var(--spacing) * 12)}.mt-28{margin-top:calc(var(--spacing) * 28)}.mt-\[1\.4rem\]{margin-top:1.4rem}.mt-\[3rem\]{margin-top:3rem}.-mr-2{margin-right:calc(var(--spacing) * -2)}.mr-2{margin-right:calc(var(--spacing) * 2)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-1\.5{margin-bottom:calc(var(--spacing) * 1.5)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-5{margin-bottom:calc(var(--spacing) * 5)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.mb-8{margin-bottom:calc(var(--spacing) * 8)}.mb-10{margin-bottom:calc(var(--spacing) * 10)}.mb-12{margin-bottom:calc(var(--spacing) * 12)}.mb-16{margin-bottom:calc(var(--spacing) * 16)}.mb-20{margin-bottom:calc(var(--spacing) * 20)}.mb-\[0\.5rem\]{margin-bottom:.5rem}.mb-\[0\.6rem\]{margin-bottom:.6rem}.mb-\[0\.35rem\]{margin-bottom:.35rem}.mb-\[1\.5rem\]{margin-bottom:1.5rem}.mb-\[1\.8rem\]{margin-bottom:1.8rem}.ml-0\.5{margin-left:calc(var(--spacing) * .5)}.ml-1{margin-left:calc(var(--spacing) * 1)}.block{display:block}.block\!{display:block!important}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.table\!{display:table!important}.h-2{height:calc(var(--spacing) * 2)}.h-3{height:calc(var(--spacing) * 3)}.h-3\.5{height:calc(var(--spacing) * 3.5)}.h-4{height:calc(var(--spacing) * 4)}.h-5{height:calc(var(--spacing) * 5)}.h-6{height:calc(var(--spacing) * 6)}.h-7{height:calc(var(--spacing) * 7)}.h-8{height:calc(var(--spacing) * 8)}.h-10{height:calc(var(--spacing) * 10)}.h-11{height:calc(var(--spacing) * 11)}.h-12{height:calc(var(--spacing) * 12)}.h-14{height:calc(var(--spacing) * 14)}.h-16{height:calc(var(--spacing) * 16)}.h-20{height:calc(var(--spacing) * 20)}.h-24{height:calc(var(--spacing) * 24)}.h-\[6px\]{height:6px}.h-\[58px\]{height:58px}.h-full{height:100%}.h-px{height:1px}.min-h-\[85vh\]{min-height:85vh}.min-h-\[200px\]{min-height:200px}.min-h-\[300px\]{min-height:300px}.w-1{width:calc(var(--spacing) * 1)}.w-1\.5{width:calc(var(--spacing) * 1.5)}.w-2{width:calc(var(--spacing) * 2)}.w-3{width:calc(var(--spacing) * 3)}.w-3\.5{width:calc(var(--spacing) * 3.5)}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.w-6{width:calc(var(--spacing) * 6)}.w-7{width:calc(var(--spacing) * 7)}.w-8{width:calc(var(--spacing) * 8)}.w-10{width:calc(var(--spacing) * 10)}.w-11{width:calc(var(--spacing) * 11)}.w-12{width:calc(var(--spacing) * 12)}.w-14{width:calc(var(--spacing) * 14)}.w-16{width:calc(var(--spacing) * 16)}.w-20{width:calc(var(--spacing) * 20)}.w-24{width:calc(var(--spacing) * 24)}.w-48{width:calc(var(--spacing) * 48)}.w-\[6px\]{width:6px}.w-full{width:100%}.max-w-2xl{max-width:var(--container-2xl)}.max-w-3xl{max-width:var(--container-3xl)}.max-w-4xl{max-width:var(--container-4xl)}.max-w-\[280px\]{max-width:280px}.max-w-\[440px\]{max-width:440px}.max-w-\[720px\]{max-width:720px}.max-w-\[840px\]{max-width:840px}.max-w-\[1100px\]{max-width:1100px}.max-w-\[1200px\]{max-width:1200px}.max-w-md{max-width:var(--container-md)}.max-w-none{max-width:none}.max-w-xs{max-width:var(--container-xs)}.min-w-0{min-width:calc(var(--spacing) * 0)}.flex-1{flex:1}.flex-shrink{flex-shrink:1}.flex-shrink-0,.shrink-0{flex-shrink:0}.border-collapse{border-collapse:collapse}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.transform\!{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)!important}.animate-enter{animation:var(--animate-enter)}.animate-ping{animation:var(--animate-ping)}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.resize{resize:both}.resize-none{resize:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}.gap-10{gap:calc(var(--spacing) * 10)}.gap-\[0\.3rem\]{gap:.3rem}.gap-\[0\.5rem\]{gap:.5rem}.gap-\[0\.6rem\]{gap:.6rem}.gap-\[0\.8rem\]{gap:.8rem}.gap-\[0\.42rem\]{gap:.42rem}.gap-\[0\.55rem\]{gap:.55rem}.gap-\[1\.4rem\]{gap:1.4rem}.gap-\[clamp\(1rem\,3vw\,2\.5rem\)\]{gap:clamp(1rem,3vw,2.5rem)}:where(.space-y-1>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 1) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-1\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 1.5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 1.5) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 5) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)))}.gap-x-10{column-gap:calc(var(--spacing) * 10)}.gap-y-8{row-gap:calc(var(--spacing) * 8)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-\[9px\]{border-radius:9px}.rounded-\[11px\]{border-radius:11px}.rounded-\[12px\]{border-radius:12px}.rounded-\[13px\]{border-radius:13px}.rounded-\[14px\]{border-radius:14px}.rounded-\[18px\]{border-radius:18px}.rounded-\[22px\]{border-radius:22px}.rounded-btn{border-radius:var(--radius-btn)}.rounded-card{border-radius:var(--radius-card)}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-section{border-radius:var(--radius-section)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-0{border-style:var(--tw-border-style);border-width:0}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-amber-700\/30{border-color:#b750004d}@supports (color:color-mix(in lab, red, red)){.border-amber-700\/30{border-color:color-mix(in oklab, var(--color-amber-700) 30%, transparent)}}.border-green-200{border-color:var(--color-green-200)}.border-green-500\/50{border-color:#00c75880}@supports (color:color-mix(in lab, red, red)){.border-green-500\/50{border-color:color-mix(in oklab, var(--color-green-500) 50%, transparent)}}.border-green-700\/30{border-color:#0081384d}@supports (color:color-mix(in lab, red, red)){.border-green-700\/30{border-color:color-mix(in oklab, var(--color-green-700) 30%, transparent)}}.border-indigo-500\/20{border-color:#625fff33}@supports (color:color-mix(in lab, red, red)){.border-indigo-500\/20{border-color:color-mix(in oklab, var(--color-indigo-500) 20%, transparent)}}.border-orange-700\/30{border-color:#c53c004d}@supports (color:color-mix(in lab, red, red)){.border-orange-700\/30{border-color:color-mix(in oklab, var(--color-orange-700) 30%, transparent)}}.border-red-200{border-color:var(--color-red-200)}.border-red-500\/50{border-color:#fb2c3680}@supports (color:color-mix(in lab, red, red)){.border-red-500\/50{border-color:color-mix(in oklab, var(--color-red-500) 50%, transparent)}}.border-red-700\/30{border-color:#bf000f4d}@supports (color:color-mix(in lab, red, red)){.border-red-700\/30{border-color:color-mix(in oklab, var(--color-red-700) 30%, transparent)}}.border-transparent{border-color:#0000}.border-white\/\[0\.04\]{border-color:#ffffff0a}@supports (color:color-mix(in lab, red, red)){.border-white\/\[0\.04\]{border-color:color-mix(in oklab, var(--color-white) 4%, transparent)}}.bg-accent{background-color:var(--color-accent)}.bg-amber-900\/20{background-color:#7b330633}@supports (color:color-mix(in lab, red, red)){.bg-amber-900\/20{background-color:color-mix(in oklab, var(--color-amber-900) 20%, transparent)}}.bg-bg{background-color:var(--color-bg)}.bg-card{background-color:var(--color-card)}.bg-dark-text{background-color:var(--color-dark-text)}.bg-gray-800{background-color:var(--color-gray-800)}.bg-gray-800\/50{background-color:#1e293980}@supports (color:color-mix(in lab, red, red)){.bg-gray-800\/50{background-color:color-mix(in oklab, var(--color-gray-800) 50%, transparent)}}.bg-green-50{background-color:var(--color-green-50)}.bg-green-500{background-color:var(--color-green-500)}.bg-green-900\/20{background-color:#0d542b33}@supports (color:color-mix(in lab, red, red)){.bg-green-900\/20{background-color:color-mix(in oklab, var(--color-green-900) 20%, transparent)}}.bg-green-900\/30{background-color:#0d542b4d}@supports (color:color-mix(in lab, red, red)){.bg-green-900\/30{background-color:color-mix(in oklab, var(--color-green-900) 30%, transparent)}}.bg-green-900\/50{background-color:#0d542b80}@supports (color:color-mix(in lab, red, red)){.bg-green-900\/50{background-color:color-mix(in oklab, var(--color-green-900) 50%, transparent)}}.bg-indigo-500\/10{background-color:#625fff1a}@supports (color:color-mix(in lab, red, red)){.bg-indigo-500\/10{background-color:color-mix(in oklab, var(--color-indigo-500) 10%, transparent)}}.bg-indigo-900\/50{background-color:#312c8580}@supports (color:color-mix(in lab, red, red)){.bg-indigo-900\/50{background-color:color-mix(in oklab, var(--color-indigo-900) 50%, transparent)}}.bg-orange-900\/20{background-color:#7e2a0c33}@supports (color:color-mix(in lab, red, red)){.bg-orange-900\/20{background-color:color-mix(in oklab, var(--color-orange-900) 20%, transparent)}}.bg-red-50{background-color:var(--color-red-50)}.bg-red-500{background-color:var(--color-red-500)}.bg-red-900\/20{background-color:#82181a33}@supports (color:color-mix(in lab, red, red)){.bg-red-900\/20{background-color:color-mix(in oklab, var(--color-red-900) 20%, transparent)}}.bg-red-900\/30{background-color:#82181a4d}@supports (color:color-mix(in lab, red, red)){.bg-red-900\/30{background-color:color-mix(in oklab, var(--color-red-900) 30%, transparent)}}.bg-red-900\/50{background-color:#82181a80}@supports (color:color-mix(in lab, red, red)){.bg-red-900\/50{background-color:color-mix(in oklab, var(--color-red-900) 50%, transparent)}}.bg-gradient-to-r{--tw-gradient-position:to right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.from-indigo-500{--tw-gradient-from:var(--color-indigo-500);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-purple-500{--tw-gradient-to:var(--color-purple-500);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.p-1{padding:calc(var(--spacing) * 1)}.p-2{padding:calc(var(--spacing) * 2)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-5{padding:calc(var(--spacing) * 5)}.p-6{padding:calc(var(--spacing) * 6)}.p-8{padding:calc(var(--spacing) * 8)}.p-\[0\.7rem\]{padding:.7rem}.p-\[1\.4rem\]{padding:1.4rem}.p-\[2rem\]{padding:2rem}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.px-6{padding-inline:calc(var(--spacing) * 6)}.px-8{padding-inline:calc(var(--spacing) * 8)}.px-\[0\.65rem\]{padding-inline:.65rem}.px-\[1\.4rem\]{padding-inline:1.4rem}.px-\[1\.15rem\]{padding-inline:1.15rem}.px-\[1rem\]{padding-inline:1rem}.px-\[2\.2rem\]{padding-inline:2.2rem}.px-\[2rem\]{padding-inline:2rem}.px-\[clamp\(1\.5rem\,5vw\,4rem\)\]{padding-inline:clamp(1.5rem,5vw,4rem)}.px-\[clamp\(2rem\,5vw\,4rem\)\]{padding-inline:clamp(2rem,5vw,4rem)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-2\.5{padding-block:calc(var(--spacing) * 2.5)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-5{padding-block:calc(var(--spacing) * 5)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-8{padding-block:calc(var(--spacing) * 8)}.py-10{padding-block:calc(var(--spacing) * 10)}.py-12{padding-block:calc(var(--spacing) * 12)}.py-16{padding-block:calc(var(--spacing) * 16)}.py-20{padding-block:calc(var(--spacing) * 20)}.py-\[0\.4rem\]{padding-block:.4rem}.py-\[0\.35rem\]{padding-block:.35rem}.py-\[0\.48rem\]{padding-block:.48rem}.py-\[0\.85rem\]{padding-block:.85rem}.py-\[1\.05rem\]{padding-block:1.05rem}.py-\[2\.8rem\]{padding-block:2.8rem}.pt-2{padding-top:calc(var(--spacing) * 2)}.pt-4{padding-top:calc(var(--spacing) * 4)}.pt-6{padding-top:calc(var(--spacing) * 6)}.pt-28{padding-top:calc(var(--spacing) * 28)}.pt-40{padding-top:calc(var(--spacing) * 40)}.pt-\[0\.5rem\]{padding-top:.5rem}.pt-\[3\.5rem\]{padding-top:3.5rem}.pb-3{padding-bottom:calc(var(--spacing) * 3)}.pb-4{padding-bottom:calc(var(--spacing) * 4)}.pb-5{padding-bottom:calc(var(--spacing) * 5)}.pb-6{padding-bottom:calc(var(--spacing) * 6)}.pb-12{padding-bottom:calc(var(--spacing) * 12)}.pb-14{padding-bottom:calc(var(--spacing) * 14)}.pb-20{padding-bottom:calc(var(--spacing) * 20)}.pl-5{padding-left:calc(var(--spacing) * 5)}.text-center{text-align:center}.text-left{text-align:left}.font-mono{font-family:var(--font-mono)}.font-sans{font-family:var(--font-sans)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[0\.6rem\]{font-size:.6rem}.text-\[0\.8rem\]{font-size:.8rem}.text-\[0\.54rem\]{font-size:.54rem}.text-\[0\.58rem\]{font-size:.58rem}.text-\[0\.66rem\]{font-size:.66rem}.text-\[0\.68rem\]{font-size:.68rem}.text-\[0\.72rem\]{font-size:.72rem}.text-\[0\.78rem\]{font-size:.78rem}.text-\[0\.82rem\]{font-size:.82rem}.text-\[0\.85rem\]{font-size:.85rem}.text-\[0\.88rem\]{font-size:.88rem}.text-\[0\.92rem\]{font-size:.92rem}.text-\[0\.95rem\]{font-size:.95rem}.text-\[1\.1rem\]{font-size:1.1rem}.text-\[1\.05rem\]{font-size:1.05rem}.text-\[1\.08rem\]{font-size:1.08rem}.text-\[1\.15rem\]{font-size:1.15rem}.text-\[2\.2rem\]{font-size:2.2rem}.text-\[clamp\(1\.4rem\,3vw\,1\.9rem\)\]{font-size:clamp(1.4rem,3vw,1.9rem)}.text-\[clamp\(1\.6rem\,3\.2vw\,2\.2rem\)\]{font-size:clamp(1.6rem,3.2vw,2.2rem)}.text-\[clamp\(1\.8rem\,3\.5vw\,2\.6rem\)\]{font-size:clamp(1.8rem,3.5vw,2.6rem)}.text-\[clamp\(3rem\,6\.5vw\,4\.6rem\)\]{font-size:clamp(3rem,6.5vw,4.6rem)}.leading-\[1\.02\]{--tw-leading:1.02;line-height:1.02}.leading-\[1\.7\]{--tw-leading:1.7;line-height:1.7}.leading-\[1\.9\]{--tw-leading:1.9;line-height:1.9}.leading-\[1\.15\]{--tw-leading:1.15;line-height:1.15}.leading-\[1\.75\]{--tw-leading:1.75;line-height:1.75}.leading-\[1\.85\]{--tw-leading:1.85;line-height:1.85}.leading-none{--tw-leading:1;line-height:1}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.leading-snug{--tw-leading:var(--leading-snug);line-height:var(--leading-snug)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-normal{--tw-font-weight:var(--font-weight-normal);font-weight:var(--font-weight-normal)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-\[-0\.2px\]{--tw-tracking:-.2px;letter-spacing:-.2px}.tracking-\[-0\.3px\]{--tw-tracking:-.3px;letter-spacing:-.3px}.tracking-\[-0\.5px\]{--tw-tracking:-.5px;letter-spacing:-.5px}.tracking-\[-0\.8px\]{--tw-tracking:-.8px;letter-spacing:-.8px}.tracking-\[-1\.2px\]{--tw-tracking:-1.2px;letter-spacing:-1.2px}.tracking-\[-1\.5px\]{--tw-tracking:-1.5px;letter-spacing:-1.5px}.tracking-\[-1px\]{--tw-tracking:-1px;letter-spacing:-1px}.tracking-\[-3px\]{--tw-tracking:-3px;letter-spacing:-3px}.tracking-\[0\.08em\]{--tw-tracking:.08em;letter-spacing:.08em}.tracking-\[1\.2px\]{--tw-tracking:1.2px;letter-spacing:1.2px}.tracking-\[1\.5px\]{--tw-tracking:1.5px;letter-spacing:1.5px}.tracking-\[1px\]{--tw-tracking:1px;letter-spacing:1px}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.text-accent{color:var(--color-accent)}.text-accent-text{color:var(--color-accent-text)}.text-amber-300{color:var(--color-amber-300)}.text-amber-400{color:var(--color-amber-400)}.text-dark{color:var(--color-dark)}.text-dark-muted{color:var(--color-dark-muted)}.text-dark-sub{color:var(--color-dark-sub)}.text-dark-text{color:var(--color-dark-text)}.text-faint{color:var(--color-faint)}.text-gray-300{color:var(--color-gray-300)}.text-gray-400{color:var(--color-gray-400)}.text-gray-500{color:var(--color-gray-500)}.text-green-300{color:var(--color-green-300)}.text-green-400{color:var(--color-green-400)}.text-green-800{color:var(--color-green-800)}.text-indigo-300{color:var(--color-indigo-300)}.text-indigo-400{color:var(--color-indigo-400)}.text-indigo-500{color:var(--color-indigo-500)}.text-muted{color:var(--color-muted)}.text-orange-300{color:var(--color-orange-300)}.text-red-300{color:var(--color-red-300)}.text-red-300\/70{color:#ffa3a3b3}@supports (color:color-mix(in lab, red, red)){.text-red-300\/70{color:color-mix(in oklab, var(--color-red-300) 70%, transparent)}}.text-red-400{color:var(--color-red-400)}.text-red-700{color:var(--color-red-700)}.text-red-800{color:var(--color-red-800)}.text-sub{color:var(--color-sub)}.text-txt{color:var(--color-txt)}.text-white{color:var(--color-white)}.capitalize{text-transform:capitalize}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.italic{font-style:italic}.line-through{text-decoration-line:line-through}.no-underline{text-decoration-line:none}.underline{text-decoration-line:underline}.placeholder-gray-600::placeholder{color:var(--color-gray-600)}.accent-indigo-500{accent-color:var(--color-indigo-500)}.opacity-0{opacity:0}.opacity-75{opacity:.75}.opacity-80{opacity:.8}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring-2{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring-indigo-500{--tw-ring-color:var(--color-indigo-500)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.invert{--tw-invert:invert(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-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.delay-100{transition-delay:.1s}.delay-200{transition-delay:.2s}.delay-300{transition-delay:.3s}.delay-400{transition-delay:.4s}.duration-100{--tw-duration:.1s;transition-duration:.1s}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.\[chat\:ChatName\]{chat:ChatName}.\[message\:MessageName\]{message:MessageName}.\[rdoc-ref\:lib\/racc\/rdoc\/grammar\.en\.rdoc\]{rdoc-ref:lib/racc/rdoc/grammar.en.rdoc}@media (hover:hover){.group-hover\:opacity-100:is(:where(.group):hover *){opacity:1}.hover\:scale-105:hover{--tw-scale-x:105%;--tw-scale-y:105%;--tw-scale-z:105%;scale:var(--tw-scale-x) var(--tw-scale-y)}.hover\:from-indigo-400:hover{--tw-gradient-from:var(--color-indigo-400);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.hover\:to-purple-400:hover{--tw-gradient-to:var(--color-purple-400);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.hover\:text-txt:hover{color:var(--color-txt)}.hover\:text-white:hover{color:var(--color-white)}}.focus\:not-sr-only:focus{clip-path:none;white-space:normal;width:auto;height:auto;margin:0;padding:0;position:static;overflow:visible}.focus\:absolute:focus{position:absolute}.focus\:top-2:focus{top:calc(var(--spacing) * 2)}.focus\:top-4:focus{top:calc(var(--spacing) * 4)}.focus\:left-4:focus{left:calc(var(--spacing) * 4)}.focus\:z-\[200\]:focus{z-index:200}.focus\:rounded-btn:focus{border-radius:var(--radius-btn)}.focus\:rounded-lg:focus{border-radius:var(--radius-lg)}.focus\:border-indigo-500\/30:focus{border-color:#625fff4d}@supports (color:color-mix(in lab, red, red)){.focus\:border-indigo-500\/30:focus{border-color:color-mix(in oklab, var(--color-indigo-500) 30%, transparent)}}.focus\:bg-accent:focus{background-color:var(--color-accent)}.focus\:bg-indigo-500:focus{background-color:var(--color-indigo-500)}.focus\:px-4:focus{padding-inline:calc(var(--spacing) * 4)}.focus\:py-2:focus{padding-block:calc(var(--spacing) * 2)}.focus\:text-sm:focus{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.focus\:font-semibold:focus{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.focus\:text-accent-text:focus{color:var(--color-accent-text)}.focus\:text-white:focus{color:var(--color-white)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.focus-visible\:text-txt:focus-visible{color:var(--color-txt)}.focus-visible\:underline:focus-visible{text-decoration-line:underline}.focus-visible\:outline-none:focus-visible{--tw-outline-style:none;outline-style:none}@media (min-width:40rem){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:px-6{padding-inline:calc(var(--spacing) * 6)}.sm\:px-8{padding-inline:calc(var(--spacing) * 8)}.sm\:pt-36{padding-top:calc(var(--spacing) * 36)}.sm\:text-right{text-align:right}}@media (min-width:48rem){.md\:block{display:block}.md\:flex{display:flex}.md\:hidden{display:none}.md\:inline-flex{display:inline-flex}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:py-32{padding-block:calc(var(--spacing) * 32)}.md\:pt-48{padding-top:calc(var(--spacing) * 48)}}@media (min-width:64rem){.lg\:block{display:block}.lg\:px-8{padding-inline:calc(var(--spacing) * 8)}}@media (min-width:80rem){.xl\:block{display:block}}}:root{--color-card-glass:#fff9;--color-border-subtle:#1c18120f;--color-tint:#1c18120a;--color-tint-strong:#1c181214;--color-flash-notice-bg:#5ba8801a;--color-flash-notice-border:#5ba8802e;--color-flash-notice-text:#3d7a5a;--color-flash-alert-bg:#b0605014;--color-flash-alert-border:#b0605026;--color-flash-alert-text:#b06050;--color-status-active-bg:#5ba8801a;--color-status-active-text:#3d7a5a;--color-status-completed-bg:#6e9bc81a;--color-status-completed-text:#4a7a9e;--color-status-paused-bg:#b098481a;--color-status-paused-text:#8b6d28;--color-progress-bar:#5ba880;--color-faint-text:#b5ad9f;--color-badge-lesson-bg:#3b82f61a;--color-badge-lesson-text:#2563eb;--color-badge-exercise-bg:#10b9811a;--color-badge-exercise-text:#059669;--color-badge-assessment-bg:#f973161a;--color-badge-assessment-text:#d97706;--color-badge-review-bg:#8b5cf61a;--color-badge-review-text:#7c3aed;--color-progress-track:#1c18120f;--journey-contrast-rgb:28, 24, 18;--journey-alpha-mult:5;--journey-opacity-mult:2.5;--color-tint-hover:#1c181224;--color-step-completed-bg:#22c55e1a;--color-step-completed-icon:#16a34a;--color-step-progress-bg:#6366f11a;--color-step-progress-icon:#4f46e5;--color-step-available-bg:#1c18120f;--color-step-locked-bg:#1c181208;--color-step-locked-icon:#b5ad9f;--color-due-bg:#d977060f;--color-due-border:#d9770626;--color-due-heading:#92400e;--color-due-text:#b45309;--color-due-link:#d97706;--color-positive:#16a34a;--color-positive-bg:#16a34a14;--color-positive-border:#16a34a2e;--color-warning:#ca8a04;--color-warning-bg:#ca8a0414;--color-warning-border:#ca8a042e;--color-negative:#dc2626;--color-negative-bg:#dc262614;--color-negative-border:#dc26262e;--color-info:#2563eb;--color-info-bg:#2563eb14;--color-info-border:#2563eb2e}html[data-theme=dark]{--color-bg:#1a1710;--color-card:#221f18;--color-txt:#e8e4dc;--color-sub:#a09889;--color-muted:#8a8070;--color-faint:#3d3730;--color-accent:#e8e4dc;--color-accent-text:#1a1710;--color-link:#d4a84b;--color-card-glass:#221f18bf;--color-border-subtle:#ffffff0f;--color-tint:#ffffff0f;--color-tint-strong:#ffffff1a;--color-flash-notice-bg:#5ba8801f;--color-flash-notice-border:#5ba88040;--color-flash-notice-text:#7bc8a0;--color-flash-alert-bg:#b060501f;--color-flash-alert-border:#b0605040;--color-flash-alert-text:#d4887a;--color-status-active-bg:#5ba88026;--color-status-active-text:#7bc8a0;--color-status-completed-bg:#6e9bc826;--color-status-completed-text:#8ab8d8;--color-status-paused-bg:#b0984826;--color-status-paused-text:#d4b85c;--color-progress-bar:#5ba880;--color-faint-text:#6a6050;--color-badge-lesson-bg:#3b82f626;--color-badge-lesson-text:#93c5fd;--color-badge-exercise-bg:#10b98126;--color-badge-exercise-text:#6ee7b7;--color-badge-assessment-bg:#f9731626;--color-badge-assessment-text:#fdba74;--color-badge-review-bg:#8b5cf626;--color-badge-review-text:#c4b5fd;--color-progress-track:#ffffff0f;--journey-contrast-rgb:255, 255, 255;--journey-alpha-mult:1;--journey-opacity-mult:1;--color-tint-hover:#ffffff29;--color-step-completed-bg:#22c55e26;--color-step-completed-icon:#4ade80;--color-step-progress-bg:#6366f126;--color-step-progress-icon:#818cf8;--color-step-available-bg:#ffffff0f;--color-step-locked-bg:#ffffff08;--color-step-locked-icon:#3d3730;--color-due-bg:#d977061a;--color-due-border:#d9770633;--color-due-heading:#fcd34d;--color-due-text:#fbbf24;--color-due-link:#f59e0b;--color-positive:#4ade80;--color-positive-bg:#4ade801f;--color-positive-border:#4ade8038;--color-warning:#facc15;--color-warning-bg:#facc151f;--color-warning-border:#facc1538;--color-negative:#f87171;--color-negative-bg:#f871711f;--color-negative-border:#f8717138;--color-info:#60a5fa;--color-info-bg:#60a5fa1f;--color-info-border:#60a5fa38}html[data-theme=dark] ::selection{background:#c8b48c33}html[data-theme=dark] .nav-scrolled{background:#1a1710eb;border-bottom-color:#ffffff0f}html[data-theme=dark] .section-dark{background:linear-gradient(#242018 0%,#1f1c14 100%);border:1px solid #ffffff0a}html[data-theme=dark] .card-hover:hover{border-color:#ffffff1a;box-shadow:0 8px 30px #0000004d,0 2px 8px #0003}html[data-theme=dark] .auth-card{background:#221f18d9;border-color:#ffffff14;box-shadow:0 8px 32px #0006}html[data-theme=dark] .auth-input{color:#e8e4dc;background:#2a2620;border-color:#ffffff1a}html[data-theme=dark] .auth-input::placeholder{color:#706858}html[data-theme=dark] .auth-input:focus{border-color:#fff3;box-shadow:0 0 0 3px #ffffff0a}html[data-theme=dark] .auth-btn{color:#1a1710;background:#e8e4dc}html[data-theme=dark] .auth-google-btn{color:#e8e4dc;background:#2a2620;border-color:#ffffff1a}html[data-theme=dark] .auth-errors{color:#e8a090;background:#dc78641a;border-color:#dc786433}html[data-theme=dark] .auth-errors li{color:#e8a090}html[data-theme=dark] .auth-flash-notice{color:#7fd4a5;background:#5ba8801f;border-color:#5ba88033}html[data-theme=dark] .auth-flash-alert{color:#e8a090;background:#dc78641a;border-color:#dc786433}html[data-theme=dark] .nav-link:hover,html[data-theme=dark] .footer-link:hover,html[data-theme=dark] .social-link:hover{color:#e8e4dc!important}html[data-theme=dark] .theme-bg-texture{opacity:.4}html[data-theme=dark] .border-lr{border-color:#ffffff0f}html[data-theme=dark] .border-lr-hover{border-color:#ffffff1f}.app-navbar{background:#f5f1ebe0;border-bottom:1px solid #1c18120a}html[data-theme=dark] .app-navbar{background:#1a1710eb;border-bottom-color:#ffffff0f}.learning-nav{-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border-subtle);background:#f5f1ebe0}html[data-theme=dark] .learning-nav{background:#1a1710d9}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@media screen and (max-width:767px){input[type=text],input[type=email],input[type=password],input[type=number],input[type=tel],input[type=url],select,textarea{font-size:16px!important}}.footer-link{transition:color .2s}.footer-link:hover{color:#1c1812!important}.social-link{transition:color .2s}.social-link:hover{color:#1c1812!important}.nav-link{transition:color .2s}.nav-link:hover{color:#1c1812!important}.avatar-hover{transition:transform .15s}.avatar-hover:hover{transform:scale(1.08)}.overlay-close-btn{transition:background .2s,color .2s}.overlay-close-btn:hover{color:#ffffffb3!important;background:#ffffff1a!important}.create-route-card{transition:all .25s cubic-bezier(.22,1,.36,1)}.create-route-card:hover{background:#5ba88004!important;border-color:#5ba880!important}.create-route-card:hover [data-icon]{background:#5ba8801f!important}.btn-lift{transition:transform .2s,box-shadow .2s}.btn-lift:hover,.btn-lift:focus-visible{transform:translateY(-1px);box-shadow:0 4px 16px #1c18121f}.btn-lift:active{transform:translateY(0)}:focus-visible{outline:2px solid var(--color-progress-bar,#5ba880);outline-offset:2px}.hover-border-faint:hover{border-color:var(--color-faint)!important}.focus-border-faint:focus{border-color:var(--color-faint)!important;box-shadow:0 0 0 3px var(--color-tint)!important}.blur-border-subtle:not(:focus){border-color:var(--color-border-subtle)!important;box-shadow:none!important}.hover-bg-red:hover{background:#f87171!important}.hover-bg-indigo:hover{background:#818cf8!important}.hover-bg-tint:hover{background:var(--color-tint-hover)!important}.hover-bg-indigo-light:hover{background:#6366f133!important}.hover-text-txt:hover{color:var(--color-txt)!important}.hover-text-muted:hover{color:var(--color-muted)!important}.hover-text-indigo:hover{color:#a5b4fc!important}.hover-tint-txt:hover{background:var(--color-tint-hover)!important;color:var(--color-txt)!important}.hover-shadow-card:hover{box-shadow:0 2px 8px #1c18120a!important}.hover-shadow-card-sm:hover{box-shadow:0 2px 6px #1c18120a!important}.hover-lift-dark:hover{transform:translateY(-1px)!important;box-shadow:0 4px 16px #1c18122e!important}.hover-lift-green:hover{transform:translateY(-1px)!important;box-shadow:0 4px 16px #5ba88040!important}.hover-back-btn:hover{border-color:var(--color-faint)!important;color:var(--color-txt)!important}@keyframes wizardCardEnter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes wizardScaleIn{0%{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}@media (max-width:600px){[data-route-wizard-target=topicGrid]{grid-template-columns:repeat(2,1fr)!important}}@media (max-width:400px){[data-route-wizard-target=topicGrid]{grid-template-columns:1fr!important}}.like-pulse{animation:.3s likePulse}@keyframes likePulse{0%{transform:scale(1)}50%{transform:scale(1.3)}to{transform:scale(1)}}.liked{color:#ef4444}@keyframes journeyPulse{0%,to{r:54;opacity:.1}50%{r:62;opacity:.02}}@keyframes celebration-gold-flash{0%{opacity:1}to{opacity:0}}@keyframes celebration-check-in{0%{opacity:0;transform:scale(0)}60%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}@keyframes celebration-pulse-ring{0%{opacity:.6;transform:scale(.8)}to{opacity:0;transform:scale(2.2)}}.celebration-pulse{animation:.4s cubic-bezier(.34,1.56,.64,1) both celebration-check-in}.celebration-ring{border-radius:inherit;pointer-events:none;border:2px solid #5ba880;animation:.8s ease-out both celebration-pulse-ring;position:absolute;inset:0}@keyframes lessonFadeIn{0%{opacity:0}to{opacity:1}}@keyframes lessonSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes lessonShake{0%,to{transform:translate(0)}10%,50%,90%{transform:translate(-4px)}30%,70%{transform:translate(4px)}}@keyframes lessonBounce{0%{transform:scale(0)}60%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes lessonPulseGlow{0%,to{box-shadow:0 0 #5ba88066}50%{box-shadow:0 0 0 8px #5ba88000}}@keyframes waveformPulse{0%,to{transform:scaleY(.3)}50%{transform:scaleY(1)}}.animate-fade-in{animation:.4s both lessonFadeIn}.animate-bounce-once{animation:.4s both lessonBounce}.lesson-nav-progress{z-index:30;background:var(--color-bg);align-items:center;gap:.75rem;max-width:48rem;margin:0 auto;padding:.75rem 1rem;display:flex;position:sticky;top:0}.lesson-progress-segment{background:var(--color-border-subtle);border-radius:2px;flex:1;height:4px;transition:background .3s}.lesson-progress--active{background:var(--color-accent,#2c261e)}.lesson-progress--visited{background:var(--color-progress-bar,#5ba880)}.lesson-progress-counter{color:var(--color-muted);white-space:nowrap;font-family:DM Mono,monospace;font-size:.6875rem;font-weight:500}.lesson-sections-container{min-height:12rem;padding-bottom:5rem;position:relative}.lesson-section{transition:transform .4s cubic-bezier(.22,1,.36,1),opacity .4s cubic-bezier(.22,1,.36,1)}.lesson-section--exit-left,.lesson-section--exit-right,.lesson-section--enter-left,.lesson-section--enter-right{will-change:transform, opacity}.lesson-section--exit-left{opacity:0;pointer-events:none;transform:translate(-30px)}.lesson-section--exit-right{opacity:0;pointer-events:none;transform:translate(30px)}.lesson-section--enter-left{opacity:0;transform:translate(30px)}.lesson-section--enter-right{opacity:0;transform:translate(-30px)}.lesson-section-badge{letter-spacing:.08em;text-transform:uppercase;-webkit-backdrop-filter:blur(8px);border-radius:9999px;align-items:center;gap:.375rem;padding:.25rem .75rem;font-family:DM Mono,monospace;font-size:.6875rem;font-weight:600;display:inline-flex;box-shadow:0 1px 4px #0000000a}.lesson-section-badge--concept{color:#6366f1;background:linear-gradient(135deg,#6366f11f,#6366f10f);border:1px solid #6366f126}.lesson-section-badge--example{color:#059669;background:linear-gradient(135deg,#10b9811f,#10b9810f);border:1px solid #10b98126}.lesson-section-badge--check,.lesson-section-badge--challenge{color:#8b5cf6;background:linear-gradient(135deg,#8b5cf61f,#8b5cf60f);border:1px solid #8b5cf626}.lesson-section-badge--visual{color:#d97706;background:linear-gradient(135deg,#f59e0b1f,#f59e0b0f);border:1px solid #f59e0b26}.lesson-section-badge--summary{background:linear-gradient(135deg, var(--color-tint-strong), var(--color-tint));color:var(--color-txt);border:1px solid var(--color-border-subtle)}.lesson-section-badge--audio{color:#6366f1;background:linear-gradient(135deg,#6366f11f,#6366f10f);border:1px solid #6366f126}.lesson-section-badge--tip{color:#d97706;background:linear-gradient(135deg,#f59e0b1f,#f59e0b0f);border:1px solid #f59e0b26}html[data-theme=dark] .lesson-section-badge--concept{color:#a5b4fc;background:linear-gradient(135deg,#6366f133,#6366f11a);border-color:#6366f140}html[data-theme=dark] .lesson-section-badge--example{color:#6ee7b7;background:linear-gradient(135deg,#10b98133,#10b9811a);border-color:#10b98140}html[data-theme=dark] .lesson-section-badge--check,html[data-theme=dark] .lesson-section-badge--challenge{color:#c4b5fd;background:linear-gradient(135deg,#8b5cf633,#8b5cf61a);border-color:#8b5cf640}html[data-theme=dark] .lesson-section-badge--visual{color:#fbbf24;background:linear-gradient(135deg,#f59e0b33,#f59e0b1a);border-color:#f59e0b40}html[data-theme=dark] .lesson-section-badge--audio{color:#a5b4fc;background:linear-gradient(135deg,#6366f133,#6366f11a);border-color:#6366f140}html[data-theme=dark] .lesson-section-badge--summary{color:#e5e5e5;background:linear-gradient(135deg,#ffffff14,#ffffff0a);border-color:#ffffff1f}html[data-theme=dark] .lesson-section-badge--tip{color:#fbbf24;background:linear-gradient(135deg,#f59e0b33,#f59e0b1a);border-color:#f59e0b40}.lesson-nav-footer{z-index:30;background:linear-gradient(to top, var(--color-bg) 80%, transparent);-webkit-backdrop-filter:blur(12px);border-top:1px solid #1c18120a;padding:.75rem 1rem;position:fixed;bottom:0;left:0;right:0}html[data-theme=dark] .lesson-nav-footer{background:linear-gradient(to top, var(--color-bg) 80%, transparent)}.lesson-btn--primary{color:#f5f1eb;cursor:pointer;background:linear-gradient(135deg,#2c261e 0%,#3d352b 100%);border:none;border-radius:14px;justify-content:center;align-items:center;padding:.9375rem 1.75rem;font-family:DM Sans,sans-serif;font-size:.9375rem;font-weight:600;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .3s;display:flex;box-shadow:0 2px 8px #1c18121a,inset 0 1px #ffffff0a}.lesson-btn--primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #1c181229,inset 0 1px #ffffff0f}.lesson-btn--primary:active{transform:translateY(0);box-shadow:0 1px 4px #1c181214}.lesson-btn--muted{background:var(--color-tint-strong);color:var(--color-muted);cursor:not-allowed;border:none;border-radius:11px;justify-content:center;align-items:center;padding:.875rem 1.5rem;font-family:DM Sans,sans-serif;font-size:.9375rem;font-weight:600;display:flex}.lesson-btn--back{border:1px solid var(--color-border-subtle);width:3rem;height:auto;color:var(--color-sub);cursor:pointer;background:0 0;border-radius:11px;justify-content:center;align-items:center;transition:border-color .2s,color .2s;display:flex}.lesson-btn--back:hover{border-color:var(--color-faint);color:var(--color-txt)}.lesson-btn--shake{animation:.5s lessonShake}.lesson-nav-check-option{padding:1rem 1.125rem!important;font-size:.9375rem!important}.lesson-waveform-bar{background:var(--color-accent,#2c261e);opacity:.25;border-radius:2px;width:3px;height:100%;animation:1.2s ease-in-out infinite waveformPulse;transform:scaleY(.3)}.section-audio-waveform-bar{will-change:background, opacity}@keyframes sectionAudioSpin{to{transform:rotate(360deg)}}@keyframes flashSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.section-audio-spinner{border:2px solid var(--color-border-subtle);border-top-color:#6366f1;border-radius:50%;width:1.25rem;height:1.25rem;animation:.6s linear infinite sectionAudioSpin}:root{--color-section-audio-active:#6366f1}html[data-theme=dark]{--color-section-audio-active:#818cf8}.skeleton-shimmer{background:linear-gradient(90deg, var(--color-tint) 25%, var(--color-tint-strong) 50%, var(--color-tint) 75%);background-size:200% 100%;animation:1.8s ease-in-out infinite skeletonShimmer}@keyframes skeletonShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-spinner{border:2px solid var(--color-tint-strong);border-top-color:#6366f1;border-radius:50%;width:1.125rem;height:1.125rem;animation:.7s linear infinite sectionAudioSpin}.lesson-summary-point{animation:.4s both lessonFadeIn}@keyframes lessonCheckBounce{0%{opacity:0;transform:scale(0)}50%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}@keyframes lessonXpGlow{0%{box-shadow:0 0 #b0984866}50%{box-shadow:0 0 20px 4px #b0984833}to{box-shadow:0 0 #b0984800}}@keyframes lessonLevelPulse{0%{opacity:0;transform:scale(0)}60%{transform:scale(1.15)}to{opacity:1;transform:scale(1)}}.lesson-completion-screen{justify-content:center;align-items:center;min-height:20rem;padding:3rem 1rem;animation:.5s both lessonFadeIn;display:flex}.lesson-completion-inner{text-align:center;max-width:24rem}.lesson-completion-check{background:var(--color-progress-bar,#5ba880);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:5rem;height:5rem;margin-bottom:1.5rem;animation:.5s cubic-bezier(.34,1.56,.64,1) both lessonCheckBounce;display:inline-flex}.lesson-completion-heading{color:var(--color-txt);margin:0 0 .5rem;font-family:DM Sans,sans-serif;font-size:1.5rem;font-weight:700;animation:.4s .2s both lessonFadeIn}.lesson-completion-sub{color:var(--color-sub);margin:0 0 1.25rem;font-size:.9375rem;animation:.4s .35s both lessonFadeIn}.lesson-completion-xp{margin-bottom:1rem;animation:.4s .4s both lessonFadeIn}.lesson-completion-xp-badge{color:#b09848;background:#b0984814;border:1px solid #b0984833;border-radius:12px;padding:.5rem 1.25rem;font-family:DM Mono,monospace;font-size:1.125rem;font-weight:700;animation:1.5s .6s lessonXpGlow;display:inline-block}.lesson-completion-level{margin-bottom:1rem;animation:.6s cubic-bezier(.34,1.56,.64,1) .5s both lessonLevelPulse}.lesson-completion-level-label{color:#b09848;letter-spacing:2px;text-transform:uppercase;margin-bottom:.25rem;font-family:DM Mono,monospace;font-size:.625rem;font-weight:600;display:block}.lesson-completion-level-number{color:var(--color-txt);text-shadow:0 0 40px #b098484d;font-family:DM Mono,monospace;font-size:3rem;font-weight:700;line-height:1;display:block}.lesson-completion-streak{align-items:center;gap:.375rem;margin-bottom:1.25rem;animation:.4s .55s both lessonFadeIn;display:inline-flex}.lesson-completion-streak-flame{font-size:1.25rem}.lesson-completion-streak-count{color:var(--color-sub);font-family:DM Mono,monospace;font-size:.875rem;font-weight:600}.lesson-completion-actions{flex-direction:column;align-items:center;gap:.625rem;margin-top:.5rem;animation:.4s .6s both lessonFadeIn;display:flex}.lesson-completion-btn{border-radius:11px;justify-content:center;align-items:center;gap:.375rem;width:100%;max-width:20rem;padding:.875rem 2rem;font-family:DM Sans,sans-serif;font-size:.9375rem;font-weight:600;text-decoration:none;transition:transform .2s,box-shadow .2s;display:inline-flex}.lesson-completion-btn--primary{background:var(--color-accent,#2c261e);color:var(--color-accent-text,#f5f1eb)}.lesson-completion-btn--secondary{background:var(--color-tint-strong,#1c18120a);color:var(--color-sub);border:1px solid var(--color-border-subtle);padding:.625rem 1.5rem;font-size:.8125rem}.lesson-completion-btn:hover{transform:translateY(-1px);box-shadow:0 4px 16px #1c18121f}@media (prefers-reduced-motion:reduce){.lesson-section{will-change:auto!important;transition:none!important}.lesson-section--exit-left,.lesson-section--exit-right,.lesson-section--enter-left,.lesson-section--enter-right{opacity:1!important;transform:none!important}.lesson-waveform-bar{animation:none!important;transform:scaleY(.5)!important}.lesson-btn--shake{animation:none!important}.animate-fade-in,.animate-bounce-once,.lesson-summary-point,.lesson-completion-screen,.lesson-completion-check,.lesson-completion-heading,.lesson-completion-sub,.lesson-completion-btn,.lesson-completion-xp,.lesson-completion-xp-badge,.lesson-completion-level,.lesson-completion-streak,.lesson-completion-actions{opacity:1!important;animation:none!important}}.lesson-hud{z-index:30;background:linear-gradient(to bottom, var(--color-bg) 90%, transparent);-webkit-backdrop-filter:blur(12px);max-width:48rem;margin:0 auto;padding:.625rem 1rem .5rem;position:sticky;top:0}.lesson-hud-progress{align-items:center;gap:3px;height:10px;margin-bottom:.375rem;display:flex}.lesson-hud-progress .lesson-progress-segment{border-radius:5px;height:10px;box-shadow:inset 0 1px 2px #0000000a}.lesson-hud-stats{align-items:center;gap:.625rem;display:flex}.lesson-hud-hearts{color:#ef4444;background:#ef444414;border-radius:20px;align-items:center;gap:3px;padding:.25rem .625rem;font-size:.8125rem;font-weight:700;display:flex}.lesson-hud-hearts.shake,.lesson-hud-hearts.lesson-hearts--shake{animation:.4s lessonShake}.lesson-hud-hearts.lesson-hearts--critical{animation:1s infinite timer-pulse}.lesson-hud-streak{color:#d97706;background:linear-gradient(135deg,#fff6e0cc,#ffe8c0cc);border-radius:20px;align-items:center;gap:3px;padding:.25rem .625rem;font-size:.8125rem;font-weight:700;display:flex}.lesson-hud-streak-fire{animation:1s infinite lesson-wiggle;display:inline-block}@keyframes lesson-wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-8deg)}75%{transform:rotate(8deg)}}.lesson-hud-xp{background:var(--color-tint-strong);border:1px solid var(--color-border-subtle);border-radius:20px;align-items:center;gap:.375rem;padding:.25rem .375rem .25rem .625rem;display:flex}.lesson-hud-xp-track{background:var(--color-border-subtle);border-radius:5px;width:4.5rem;height:10px;position:relative;overflow:hidden}.lesson-hud-xp-fill{background:linear-gradient(90deg,#f59e0b,#ef4444);border-radius:5px;height:100%;transition:width .8s cubic-bezier(.4,0,.2,1);position:relative}.lesson-hud-xp-fill:after{content:"";background:linear-gradient(#ffffff59,#0000);border-radius:5px;position:absolute;inset:0}.lesson-hud-xp-fill.pulse,.lesson-xp--pulse .lesson-hud-xp-fill{animation:.6s xp-bar-pulse}@keyframes xp-bar-pulse{0%,to{filter:brightness()}50%{filter:brightness(1.5)}}.lesson-hud-xp-level{color:#fff;background:linear-gradient(135deg,#f59e0b,#ef4444);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:1.625rem;height:1.625rem;font-size:.6875rem;font-weight:800;display:flex}.quiz-timer{color:#be185d;background:linear-gradient(135deg,#fdf2f8cc,#fef3c7cc);border-radius:20px;flex-shrink:0;align-items:center;gap:.375rem;padding:.375rem .75rem;font-size:.875rem;font-weight:700;transition:all .3s;display:flex}.quiz-timer svg{color:#be185d}.quiz-timer.urgent{color:#dc2626;background:linear-gradient(135deg,#fee2e2cc,#fecacacc);animation:1s infinite timer-pulse}.quiz-timer.urgent svg{color:#dc2626}@keyframes timer-pulse{0%,to{opacity:1}50%{opacity:.5}}.quiz-bonus-tag{color:#b45309;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:8px;align-items:center;gap:.25rem;padding:.25rem .625rem;font-family:DM Mono,monospace;font-size:.6875rem;font-weight:700;animation:2s infinite bonus-glow;display:inline-flex}@keyframes bonus-glow{0%,to{box-shadow:0 0 #f59e0b4d}50%{box-shadow:0 0 0 6px #f59e0b00}}.quiz-bonus-tag.earned{color:#065f46;background:linear-gradient(135deg,#d1fae5,#a7f3d0);animation:none}.quiz-bonus-tag.missed{opacity:.4;text-decoration:line-through;animation:none}.lesson-section-badge--challenge{color:#db2777;background:linear-gradient(135deg,#fdf2f8cc,#faf5ffcc)}html[data-theme=dark] .lesson-section-badge--challenge{color:#f9a8d4;background:#db277726}.quiz-modal-backdrop{z-index:9990;opacity:0;background:#0009;justify-content:center;align-items:center;padding:1rem;transition:opacity .3s;display:flex;position:fixed;inset:0}.quiz-modal-backdrop.quiz-modal--visible{opacity:1}.quiz-modal-card{background:var(--color-card,#fff);opacity:0;border-left:4px solid #8b5cf6;border-radius:20px;width:100%;max-width:32rem;max-height:90vh;padding:1.75rem;transition:transform .4s cubic-bezier(.22,1,.36,1),opacity .4s;overflow-y:auto;transform:translateY(2rem)scale(.96);box-shadow:0 25px 50px #00000040,0 0 0 1px #8b5cf61a}.quiz-modal--visible .quiz-modal-card{opacity:1;transform:translateY(0)scale(1)}.quiz-modal--exit .quiz-modal-card{opacity:0;transform:translateY(2rem)scale(.96)}.quiz-modal-continue{color:#fff;cursor:pointer;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:12px;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.875rem 1.5rem;font-family:DM Sans,sans-serif;font-size:.9375rem;font-weight:700;transition:all .2s;display:flex;box-shadow:0 2px 8px #8b5cf64d}.quiz-modal-continue:hover{transform:translateY(-1px);box-shadow:0 4px 16px #8b5cf666}.lesson-progress-segment--quiz{position:relative}.lesson-progress-segment--quiz:after{content:"⚡";pointer-events:none;font-size:.5rem;line-height:1;position:absolute;top:-14px;left:50%;transform:translate(-50%)}.lesson-progress-segment--quiz.lesson-progress--visited{background:#8b5cf6}.lesson-progress-segment--visual{position:relative}.lesson-progress-segment--visual:after{content:"🖼";pointer-events:none;font-size:.45rem;line-height:1;position:absolute;top:-14px;left:50%;transform:translate(-50%)}.lesson-progress-segment--visual.lesson-progress--visited{background:#6e9bc8}.lesson-progress-segment--tip{position:relative}.lesson-progress-segment--tip:after{content:"⭐";pointer-events:none;font-size:.45rem;line-height:1;position:absolute;top:-14px;left:50%;transform:translate(-50%)}.lesson-progress-segment--tip.lesson-progress--visited{background:#f59e0b}.lesson-progress-segment--summary{position:relative}.lesson-progress-segment--summary:after{content:"📋";pointer-events:none;font-size:.45rem;line-height:1;position:absolute;top:-14px;left:50%;transform:translate(-50%)}.lesson-progress-segment--summary.lesson-progress--visited{background:#6b7280}@media (max-width:640px){.quiz-modal-card{max-height:85vh;margin:.5rem;padding:1.25rem}}.lesson-particles{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.lesson-particle{opacity:0;border-radius:50%;animation:linear infinite lesson-float-particle;position:absolute}@keyframes lesson-float-particle{0%{opacity:0;transform:translateY(100vh)scale(0)}10%{opacity:.3}90%{opacity:.3}to{opacity:0;transform:translateY(-10vh)scale(1)}}.lesson-companion{z-index:25;cursor:pointer;filter:drop-shadow(0 4px 12px #00000014);transition:transform .3s cubic-bezier(.34,1.56,.64,1);position:fixed;bottom:5.5rem;right:1.25rem}.lesson-companion:hover{transform:scale(1.1)rotate(-5deg)}.lesson-companion-body{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border:2px solid #fff9;border-radius:50%;justify-content:center;align-items:center;width:3.5rem;height:3.5rem;font-size:1.75rem;line-height:1;animation:3s infinite companion-bob;display:flex}html[data-theme=dark] .lesson-companion-body{background:linear-gradient(135deg,#312e81,#4338ca)}@keyframes companion-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.lesson-companion-bubble{background:var(--color-card,white);color:var(--color-txt);white-space:nowrap;opacity:0;pointer-events:none;border-radius:14px;padding:.625rem .875rem;font-size:.75rem;font-weight:600;transition:all .3s cubic-bezier(.34,1.56,.64,1);position:absolute;bottom:calc(100% + .5rem);right:0;transform:translateY(8px)scale(.9);box-shadow:0 4px 20px #0000001a}.lesson-companion-bubble:after{content:"";background:var(--color-card,white);border-radius:2px;width:12px;height:12px;position:absolute;bottom:-6px;right:1.25rem;transform:rotate(45deg)}.lesson-companion-bubble.show,.lesson-companion-bubble.lesson-companion-bubble--visible{opacity:1;transform:translateY(0)scale(1)}.lesson-lvlup-overlay{z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;background:#00000080;flex-direction:column;justify-content:center;align-items:center;animation:.3s lessonFadeIn;display:flex;position:fixed;inset:0}.lesson-lvlup-ring{background:linear-gradient(135deg,#f59e0b,#ef4444,#ec4899);border-radius:50%;justify-content:center;align-items:center;width:9rem;height:9rem;animation:.6s cubic-bezier(.34,1.56,.64,1) both lessonBounce,3s linear infinite lvl-hue-spin;display:flex;box-shadow:0 0 60px #f59e0b66}@keyframes lvl-hue-spin{0%{filter:hue-rotate()}to{filter:hue-rotate(360deg)}}.lesson-lvlup-inner{background:var(--color-bg);border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:7.5rem;height:7.5rem;display:flex}.lesson-lvlup-num{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#f59e0b,#ef4444);-webkit-background-clip:text;font-size:2.5rem;font-weight:800;line-height:1}.lesson-lvlup-label{text-transform:uppercase;letter-spacing:1px;color:var(--color-muted);font-size:.625rem}.lesson-lvlup-title{color:#fff;text-shadow:0 2px 10px #0000004d;margin-top:1.25rem;font-size:1.5rem;font-weight:800}.lesson-lvlup-sub{color:#ffffffb3;margin-top:.25rem;font-size:.9375rem}.lesson-lvlup--active{animation:.3s lessonFadeIn}.lesson-toast{z-index:90;opacity:0;white-space:nowrap;pointer-events:none;color:#065f46;background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-radius:14px;padding:.75rem 1.5rem;font-size:.875rem;font-weight:600;transition:all .4s cubic-bezier(.34,1.56,.64,1);position:fixed;top:5.5rem;left:50%;transform:translate(-50%)translateY(-1.25rem);box-shadow:0 4px 20px #10b98133}.lesson-toast.show,.lesson-toast.lesson-toast--visible{opacity:1;transform:translate(-50%)translateY(0)}.lesson-content pre{border-radius:14px;margin:1.25rem 0;position:relative;overflow:hidden;box-shadow:0 2px 8px #0000000f,0 8px 24px #0000000a}.code-block-header{background:#181825;border-bottom:1px solid #313244;border-radius:14px 14px 0 0;justify-content:space-between;align-items:center;padding:.625rem 1rem;display:flex}.code-block-dots{gap:.375rem;display:flex}.code-block-dots span{border-radius:50%;width:10px;height:10px}.code-block-dots span:first-child{background:#f38ba8}.code-block-dots span:nth-child(2){background:#fab387}.code-block-dots span:nth-child(3){background:#a6e3a1}.code-block-lang{color:#6c7086;text-transform:uppercase;font-family:DM Mono,monospace;font-size:.6875rem}.code-block-run{color:#1e1e2e;cursor:pointer;background:#a6e3a1;border:none;border-radius:8px;align-items:center;gap:.25rem;padding:.25rem .75rem;font-family:DM Mono,monospace;font-size:.6875rem;font-weight:700;transition:all .2s;display:flex}.code-block-run:hover{background:#94e2b5;transform:scale(1.05)}.code-block-run:active{transform:scale(.95)}.code-block-run svg{width:12px;height:12px}.code-block-output{color:#a6e3a1;white-space:pre;background:#11111b;border-top:1px solid #313244;border-radius:0 0 11px 11px;padding:.75rem 1.125rem;font-family:DM Mono,monospace;font-size:.8125rem;display:none}.code-block-output.show{animation:.3s code-output-in;display:block;overflow:hidden}@keyframes code-output-in{0%{opacity:0;max-height:0}to{opacity:1;max-height:200px}}.lesson-completion-stats{grid-template-columns:repeat(auto-fit,minmax(6rem,1fr));gap:.75rem;width:100%;max-width:28rem;margin:1.5rem auto;display:grid}.lesson-completion-stat-icon{border-radius:50%;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;margin:0 auto .5rem;font-size:1.125rem;display:flex}.lesson-completion-stat{background:var(--color-tint-strong);text-align:center;border:1px solid var(--color-border-subtle);min-width:6rem;animation:.4s both stat-pop;animation-delay:var(--delay,.2s);border-radius:14px;padding:1.125rem 1.5rem;transition:transform .3s}.lesson-completion-stat:hover{transform:translateY(-3px)}@keyframes stat-pop{0%{opacity:0;transform:scale(.8)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.lesson-completion-stat-value{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#10b981,#3b82f6);-webkit-background-clip:text;font-size:1.75rem;font-weight:800;line-height:1}.lesson-completion-stat-label{color:var(--color-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:.25rem;font-family:DM Mono,monospace;font-size:.625rem}@media (prefers-reduced-motion:reduce){.lesson-particle,.lesson-companion-body,.lesson-hud-streak-fire,.quiz-bonus-tag,.lesson-lvlup-ring,.lesson-completion-stat,.lesson-hud-hearts.lesson-hearts--shake,.lesson-hud-hearts.lesson-hearts--critical{animation:none!important}.lesson-companion-bubble,.lesson-toast,.lesson-hud-xp-fill,.quiz-timer{transition:none!important}}@media (max-width:640px){.lesson-hud-xp-track{width:3rem}.lesson-companion{bottom:5rem;right:.75rem}.lesson-companion-body{width:2.75rem;height:2.75rem;font-size:1.375rem}}@media (max-width:1280px){.step-page-layout{flex-direction:column!important}.step-page-layout>aside{width:100%!important;display:block!important}}@keyframes step-in-progress-pulse{0%,to{border-color:#6366f14d}50%{border-color:#6366f126}}html[data-theme=dark] .lesson-content img,[data-layout=learning] .lesson-content img{border:1px solid var(--color-border-subtle)}@media (max-width:640px){.lesson-sections-container .lesson-section>div{padding-left:.75rem!important;padding-right:.75rem!important}}@supports (padding-bottom:env(safe-area-inset-bottom)){.lesson-nav-footer{padding-bottom:calc(.75rem + env(safe-area-inset-bottom))}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"<length-percentage>";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"<length-percentage>";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"<length-percentage>";inherits:false;initial-value:100%}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@keyframes spin{to{transform:rotate(360deg)}}@keyframes ping{75%,to{opacity:0;transform:scale(2)}}@keyframes pulse{50%{opacity:.5}}@keyframes enter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}