.lf-embed-root{font-family:var(--lf-font);color:var(--lf-text);background:var(--lf-bg);border-radius:var(--lf-radius);box-sizing:border-box;--lf-surface:color-mix(in srgb, var(--lf-bg) 92%, var(--lf-text));--lf-border:color-mix(in srgb, var(--lf-bg) 80%, var(--lf-text));padding:1rem;line-height:1.5}.lf-embed-root *,.lf-embed-root :before,.lf-embed-root :after{box-sizing:border-box}.lf-embed-root .lf-h2{color:var(--lf-text);margin:0 0 .5rem;font-size:1.4rem;font-weight:700}.lf-embed-root .lf-h3{color:var(--lf-text);margin:0 0 .5rem;font-size:1.05rem;font-weight:600}.lf-embed-root .lf-prose{margin:0 0 .5rem}.lf-embed-root .lf-muted{opacity:.7}.lf-embed-root .lf-small{font-size:.85rem}.lf-embed-root .lf-mt{margin-top:1rem}.lf-embed-root .lf-error{color:#b91c1c}.lf-embed-root .lf-error-detail{white-space:pre-wrap;opacity:.8;margin:.5rem 0 0;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.75rem}.lf-embed-root .lf-questions,.lf-embed-root .lf-question{flex-direction:column;gap:.75rem;display:flex}.lf-embed-root .lf-questions{gap:1.25rem}.lf-embed-root .lf-question{background:var(--lf-surface);border:1px solid var(--lf-border);border-radius:var(--lf-radius);padding:1rem}.lf-embed-root .lf-lesson{background:var(--lf-surface);border:1px solid var(--lf-border);border-radius:var(--lf-radius);margin-top:.75rem;padding:1rem}.lf-embed-root .lf-options{flex-direction:column;gap:.4rem;display:flex}.lf-embed-root .lf-option-label{cursor:pointer;align-items:center;gap:.5rem;display:flex}.lf-embed-root .lf-text-input{border:1px solid var(--lf-border);border-radius:var(--lf-radius);background:var(--lf-bg);width:100%;color:var(--lf-text);font:inherit;padding:.5rem .75rem}.lf-embed-root .lf-audio{width:100%;margin:.75rem 0}.lf-embed-root .lf-button-row{flex-wrap:wrap;gap:.5rem;margin-top:.5rem;display:flex}.lf-embed-root .lf-btn{font:inherit;border-radius:var(--lf-radius);border:1px solid var(--lf-border);background:var(--lf-surface);color:var(--lf-text);cursor:pointer;padding:.5rem 1rem}.lf-embed-root .lf-btn:disabled{opacity:.5;cursor:not-allowed}.lf-embed-root .lf-btn-primary{background:var(--lf-accent);color:var(--lf-bg);border-color:var(--lf-accent)}.lf-embed-root .lf-btn-secondary{background:var(--lf-surface)}.lf-embed-root .lf-btn-active{background:var(--lf-accent);color:var(--lf-bg);border-color:var(--lf-accent)}.lf-embed-root .lf-stepper{justify-content:space-between;gap:.5rem;margin-top:1rem;display:flex}.lf-embed-root .lf-result-card{flex-direction:column;gap:.75rem;display:flex}.lf-embed-root .lf-result{border-radius:var(--lf-radius);border:1px solid var(--lf-border);padding:1rem}.lf-embed-root .lf-result-passed{background:#10b9811a;border-color:#10b98166}.lf-embed-root .lf-result-failed{background:#ef44441a;border-color:#ef444466}.lf-embed-root .lf-score{margin:0 0 .5rem;font-weight:600}.lf-embed-root .lf-image-grid-exercise{margin:.75rem 0}.lf-embed-root .lf-image-grid-targets{flex-wrap:wrap;gap:.6rem;margin:.5rem 0 1.5rem;display:flex}.lf-embed-root .lf-image-grid-target{border:2px solid var(--lf-accent);object-fit:cover;border-radius:4px;width:64px;height:64px}.lf-embed-root .lf-image-grid-board{gap:6px;display:grid;overflow-x:auto}.lf-embed-root .lf-grid-cell{border:2px solid var(--lf-border);cursor:pointer;background:0 0;border-radius:4px;padding:0;transition:border-color .15s,box-shadow .15s;overflow:hidden}.lf-embed-root .lf-grid-cell img{object-fit:cover;width:100%;height:100%;display:block}.lf-embed-root .lf-grid-selected{border-color:var(--lf-accent);box-shadow:0 0 0 2px color-mix(in srgb, var(--lf-accent) 25%, transparent)}.lf-embed-root .lf-grid-correct{border-color:#10b981;box-shadow:0 0 0 2px #10b98140}.lf-embed-root .lf-grid-missed{border-color:#f59e0b;box-shadow:0 0 0 2px #f59e0b40}.lf-embed-root .lf-grid-wrong{border-color:#ef4444;box-shadow:0 0 0 2px #ef444440}.lf-embed-root .lf-result-passed-text{color:#059669}.lf-embed-root .lf-result-failed-text{color:#b91c1c}.lf-embed-root .lf-hidden{display:none}@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-leading:initial;--tw-font-weight: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-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}}}@layer theme{:root,:host{--font-sans:"Inter", system-ui, sans-serif;--font-mono:ui-monospace, Consolas, monospace;--spacing:.25rem;--container-2xl:42rem;--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-3xl:1.875rem;--text-3xl--line-height:calc(2.25 / 1.875);--font-weight-normal:400;--font-weight-semibold:600;--radius-md:.375rem;--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);--font-heading:"Nunito", system-ui, sans-serif}}@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;-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}}@layer components;@layer utilities{.pointer-events-none{pointer-events:none}.visible{visibility:visible}.absolute{position:absolute}.relative{position:relative}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.top-5{top:calc(var(--spacing) * 5)}.right-5{right:calc(var(--spacing) * 5)}.container{width:100%}@media (width>=40rem){.container{max-width:40rem}}@media (width>=48rem){.container{max-width:48rem}}@media (width>=64rem){.container{max-width:64rem}}@media (width>=80rem){.container{max-width:80rem}}@media (width>=96rem){.container{max-width:96rem}}.m-0\!{margin:calc(var(--spacing) * 0)!important}.mx-auto\!{margin-inline:auto!important}.my-6{margin-block:calc(var(--spacing) * 6)}.my-8{margin-block:calc(var(--spacing) * 8)}.-mt-3\!{margin-top:calc(var(--spacing) * -3)!important}.mt-1{margin-top:calc(var(--spacing) * 1)}.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-6{margin-top:calc(var(--spacing) * 6)}.mt-8{margin-top:calc(var(--spacing) * 8)}.mt-14{margin-top:calc(var(--spacing) * 14)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.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-12{margin-bottom:calc(var(--spacing) * 12)}.ml-auto{margin-left:auto}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.inline-flex\!{display:inline-flex!important}.h-7\!{height:calc(var(--spacing) * 7)!important}.h-10{height:calc(var(--spacing) * 10)}.h-14{height:calc(var(--spacing) * 14)}.h-16{height:calc(var(--spacing) * 16)}.max-h-80{max-height:calc(var(--spacing) * 80)}.w-1\/2{width:50%}.w-10\!{width:calc(var(--spacing) * 10)!important}.w-16{width:calc(var(--spacing) * 16)}.w-40\!{width:calc(var(--spacing) * 40)!important}.w-48\!{width:calc(var(--spacing) * 48)!important}.w-full{width:100%}.max-w-2xl{max-width:var(--container-2xl)}.max-w-32{max-width:calc(var(--spacing) * 32)}.max-w-48{max-width:calc(var(--spacing) * 48)}.max-w-full\!{max-width:100%!important}.min-w-60{min-width:calc(var(--spacing) * 60)}.flex-1{flex:1}.shrink-0{flex-shrink:0}.grow{flex-grow:1}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.cursor-pointer{cursor:pointer}.resize{resize:both}.list-decimal{list-style-type:decimal}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-\[max-content_1fr\]{grid-template-columns:max-content 1fr}.flex-col{flex-direction:column}.flex-row\!{flex-direction:row!important}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-end{align-items:flex-end}.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)}:where(.space-y-10>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 10) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 10) * calc(1 - var(--tw-space-y-reverse)))}.gap-x-4{column-gap:calc(var(--spacing) * 4)}.gap-y-2{row-gap:calc(var(--spacing) * 2)}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.rounded{border-radius:.25rem}.rounded-md{border-radius:var(--radius-md)}.border{border-style:var(--tw-border-style);border-width:1px}.border-0\!{border-style:var(--tw-border-style)!important;border-width:0!important}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.border-\(--accent\){border-color:var(--accent)}.border-\(--border\){border-color:var(--border)}.border-\(--success-border\)\!{border-color:var(--success-border)!important}.border-\(--text\){border-color:var(--text)}.border-transparent{border-color:#0000}.bg-\(--bg-surface\){background-color:var(--bg-surface)}.bg-\(--success-bg\)\!{background-color:var(--success-bg)!important}.bg-\(--surface\){background-color:var(--surface)}.object-cover{object-fit:cover}.p-0\!{padding:calc(var(--spacing) * 0)!important}.p-1\.5{padding:calc(var(--spacing) * 1.5)}.p-3{padding:calc(var(--spacing) * 3)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-8{padding-block:calc(var(--spacing) * 8)}.py-12{padding-block:calc(var(--spacing) * 12)}.py-16{padding-block:calc(var(--spacing) * 16)}.pt-2{padding-top:calc(var(--spacing) * 2)}.pt-4{padding-top:calc(var(--spacing) * 4)}.pt-5{padding-top:calc(var(--spacing) * 5)}.pt-6{padding-top:calc(var(--spacing) * 6)}.pt-8{padding-top:calc(var(--spacing) * 8)}.pb-4{padding-bottom:calc(var(--spacing) * 4)}.pb-5{padding-bottom:calc(var(--spacing) * 5)}.pb-8{padding-bottom:calc(var(--spacing) * 8)}.pl-7{padding-left:calc(var(--spacing) * 7)}.pl-8{padding-left:calc(var(--spacing) * 8)}.text-center{text-align:center}.font-mono{font-family:var(--font-mono)}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--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-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.leading-10{--tw-leading:calc(var(--spacing) * 10);line-height:calc(var(--spacing) * 10)}.leading-none{--tw-leading:1;line-height:1}.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)}.text-nowrap{text-wrap:nowrap}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.text-\(--danger\){color:var(--danger)}.text-\(--success\){color:var(--success)}.text-\(--success\)\!{color:var(--success)!important}.text-\(--text\){color:var(--text)}.text-\(--text-h\){color:var(--text-h)}.opacity-40{opacity:.4}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.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)}.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,)}.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,)}.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-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))}@media (hover:hover){.hover\:border-\(--accent\):hover{border-color:var(--accent)}.hover\:bg-\(--border\):hover{background-color:var(--border)}.hover\:text-\(--accent\):hover{color:var(--accent)}.hover\:opacity-70:hover{opacity:.7}.hover\:opacity-100:hover{opacity:1}}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-30:disabled{opacity:.3}@media (width>=40rem){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width>=64rem){.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}}.app-nav{background:var(--bg);border-bottom:1px solid var(--border);z-index:100;padding:0 1rem;position:sticky;top:0}.nav-inner{justify-content:space-between;align-items:center;max-width:1126px;height:56px;margin:0 auto;display:flex}.nav-brand{font-family:var(--heading);color:var(--accent);font-size:1.25rem;font-weight:700;text-decoration:none}.nav-links{align-items:center;gap:1rem;display:flex}.nav-links a{color:var(--text);font-size:.9rem;text-decoration:none}.nav-links a:hover,.nav-links a[data-status=active]{color:var(--accent)}.nav-btn{border:1px solid var(--border);color:var(--text-h);cursor:pointer;background:0 0;border-radius:4px;padding:.25rem .75rem;font-size:.9rem;font-weight:500}.nav-btn:hover{background:var(--bg-surface)}.nav-left{align-items:center;gap:1rem;display:flex}.nav-language-select{background:var(--bg);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:4px;padding:.2rem .5rem;font-size:.9rem}.page{max-width:900px;margin:2rem auto;padding:0 1rem}.card-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-top:1rem;display:grid}.card{border:1px solid var(--border);background:var(--bg);border-radius:8px;padding:1.25rem}.card h3{margin:0 0 .5rem}.card h3 a{color:var(--text-h);text-decoration:none}.card h3 a:hover{color:var(--accent)}.card-locked{opacity:.6}.card-meta{flex-wrap:wrap;gap:.5rem;margin:.5rem 0;display:flex}.badge{background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-border);border-radius:12px;padding:.15rem .5rem;font-size:.75rem;display:inline-block}.badge-success{background:var(--success-bg);color:var(--success);border-color:var(--success-border)}.badge-locked{background:var(--danger-bg);color:var(--danger);border-color:var(--danger-border)}.badge-progress{background:var(--warning-bg);color:var(--warning);border-color:var(--warning-border)}.price{color:var(--text-h);font-weight:600}.price.free{color:var(--success)}.data-table{border-collapse:collapse;width:100%;margin-top:1rem}.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--border);padding:.6rem .75rem}.data-table th{color:var(--text);font-size:.85rem;font-weight:600}.btn{background:var(--btn-bg);color:var(--btn-text);cursor:pointer;border:none;border-radius:6px;padding:.5rem 1rem;font-size:.9rem;font-weight:600;text-decoration:none;display:inline-block}.btn:hover{opacity:.9}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn-sm{padding:.25rem .6rem;font-size:.8rem}.btn-secondary{background:var(--bg-surface);color:var(--text-h);border:1px solid var(--border);cursor:pointer;border-radius:6px;padding:.5rem 1rem;font-size:.9rem;font-weight:600;text-decoration:none;display:inline-block}.btn-secondary:hover{background:var(--border)}.btn-danger{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border);cursor:pointer;border-radius:6px;padding:.5rem 1rem;font-weight:600}.btn-danger.btn-sm,.btn-secondary.btn-sm{padding:.25rem .6rem;font-size:.8rem}.page-header{justify-content:space-between;align-items:center;display:flex}.pagination{justify-content:center;align-items:center;gap:1rem;margin-top:1rem;display:flex}.search-bar{margin-bottom:1rem}.confirm-overlay{z-index:10000;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.confirm-dialog{background:var(--bg);border:1px solid var(--border);min-width:300px;max-width:480px;box-shadow:var(--shadow);border-radius:10px;padding:1.5rem}.confirm-dialog p{color:var(--text-h);margin-bottom:1.25rem;font-size:.95rem}.confirm-actions{justify-content:flex-end;align-items:center;gap:.75rem;min-width:0;display:flex}.confirm-actions button{white-space:nowrap;flex-shrink:0}.confirm-actions .confirm-middle{text-overflow:ellipsis;flex-shrink:1;min-width:0;max-width:14rem;overflow:hidden}.share-dialog{background:var(--bg);border:1px solid var(--border);width:min(70vw,960px);max-width:70vw;max-height:90vh;box-shadow:var(--shadow);border-radius:10px;flex-direction:column;gap:20px;padding:1.5rem;display:flex;overflow-y:auto}.share-dialog h2{font-size:1.1rem}.share-dialog h3{font-size:.95rem;font-weight:600}.share-dialog code{background:var(--bg-surface);border-radius:4px;padding:.1rem .35rem}.status-badge{text-transform:uppercase;letter-spacing:.02em;border:1px solid #0000;border-radius:5px;padding:.15rem .5rem;font-size:.7rem;font-weight:600;display:inline-block}.status-badge.status-not-started{background:var(--bg-surface);color:var(--text);border-color:var(--border)}.status-badge.status-in-progress{background:var(--accent)}@supports (color:color-mix(in lab, red, red)){.status-badge.status-in-progress{background:color-mix(in srgb, var(--accent) 15%, transparent)}}.status-badge.status-in-progress{color:var(--accent);border-color:var(--accent)}@supports (color:color-mix(in lab, red, red)){.status-badge.status-in-progress{border-color:color-mix(in srgb, var(--accent) 40%, transparent)}}.status-badge.status-passed{background:var(--success-bg);color:var(--success);border-color:var(--success-border)}.status-badge.status-failed{background:var(--danger-bg);color:var(--danger);border-color:var(--danger-border)}.app-main.embedded{padding:0}.shared-container{max-width:720px;margin:0 auto;padding:2rem 1.5rem}.shared-container h1{margin-top:0}.shared-questions{flex-direction:column;gap:2rem;margin-top:2rem;display:flex}.shared-question{border:1px solid var(--border);background:var(--bg-surface);border-radius:10px;padding:1rem}.shared-question h3{margin:0 0 .5rem;font-size:.95rem}.shared-question .question-text{margin:0 0 1rem}.shared-lesson{border:1px solid var(--border);background:var(--bg-surface);border-radius:10px;margin-top:2rem;padding:1.5rem}.shared-lesson h2{margin-top:0}.shared-stepper-actions{justify-content:space-between;gap:1rem;margin-top:1.5rem;display:flex}.shared-result{border:1px solid var(--border);text-align:center;border-radius:12px;margin-top:2rem;padding:2rem}.shared-result h2{margin:0 0 .5rem}.shared-result-passed{background:var(--success-bg);color:var(--success);border-color:var(--success-border)}.shared-result-failed{background:var(--danger-bg);color:var(--danger);border-color:var(--danger-border)}.shared-score{margin:.5rem 0;font-size:1.5rem;font-weight:600}.search-bar input{border:1px solid var(--border);border-radius:6px;width:100%;max-width:400px;padding:.5rem;font-size:.9rem}.auth-page{justify-content:center;align-items:center;min-height:60vh;padding:2rem;display:flex}.auth-card{border:1px solid var(--border);background:var(--bg);border-radius:12px;width:100%;max-width:420px;padding:2rem}.auth-card h1{margin:0 0 .5rem}.auth-card p{color:var(--text);margin-bottom:1.5rem}.auth-card form{flex-direction:column;gap:1rem;display:flex}.auth-card label{font-size:.9rem;font-weight:600}.auth-card input,.auth-card select{border:1px solid var(--border);box-sizing:border-box;border-radius:6px;width:100%;margin-top:.25rem;padding:.6rem;font-size:.95rem}.auth-card button[type=submit]{background:var(--btn-bg);color:var(--btn-text);cursor:pointer;border:none;border-radius:6px;padding:.7rem;font-size:1rem;font-weight:600}.auth-card button[type=submit]:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.error{color:#dc3545;font-size:.9rem}.admin-layout{min-height:calc(100vh - 56px);display:flex}.admin-sidebar{border-right:1px solid var(--border);flex-shrink:0;width:220px;height:calc(100vh - 56px);padding:1.5rem 1rem 1.5rem 2rem;position:sticky;top:56px;overflow-y:auto}.admin-sidebar h2{color:var(--text);margin:0 0 1rem;font-size:1rem}.admin-sidebar nav{flex-direction:column;gap:.5rem;display:flex}.admin-sidebar a{color:var(--text);border-radius:6px;padding:.4rem .6rem;font-size:.9rem;text-decoration:none}.admin-sidebar a:hover,.admin-sidebar a[data-status=active]{background:var(--accent-bg);color:var(--accent)}.admin-content{flex:1;max-width:900px;padding:1.5rem 2rem}.admin-form{flex-direction:column;gap:1rem;max-width:500px;display:flex}.admin-form label{flex-direction:column;gap:.25rem;font-size:.9rem;font-weight:600;display:flex}.admin-form input,.admin-form select,.admin-form textarea{border:1px solid var(--border);border-radius:6px;padding:.5rem;font-family:inherit;font-size:.9rem}.admin-form textarea{resize:vertical}.checkbox-label{align-items:center;flex-direction:row!important;gap:.5rem!important}.inline-form{flex-direction:row;align-items:flex-end;max-width:100%}.inline-form input{flex:1}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;margin:1rem 0 2rem;display:grid}.stat-card{border:1px solid var(--border);text-align:center;border-radius:8px;padding:1rem}.stat-value{color:var(--accent);margin:0;font-size:1.75rem;font-weight:700}.stat-label{color:var(--text);margin:.25rem 0 0;font-size:.8rem}.lesson-editor,.question-editor{border:1px solid var(--border);border-radius:8px;margin-bottom:1rem;padding:1rem;overflow:visible}.lesson-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.lesson-title-input{border:1px solid var(--border);border-radius:4px;flex:1;margin-right:.5rem;padding:.3rem .5rem;font-size:1rem;font-weight:600}.lesson-editor textarea,.question-editor textarea{border:1px solid var(--border);width:100%;font-family:var(--mono);box-sizing:border-box;border-radius:4px;padding:.5rem;font-size:.85rem}.question-editor label{flex-direction:column;gap:.25rem;margin-bottom:.5rem;font-size:.85rem;font-weight:600;display:flex}.question-editor select,.question-editor input{border:1px solid var(--border);border-radius:4px;padding:.4rem}.question-layout{gap:1.5rem;margin-top:1rem;display:flex}.question-list{flex-shrink:0;width:250px}.question-list-item{border:1px solid var(--border);cursor:pointer;color:var(--text);-webkit-user-select:none;user-select:none;border-radius:6px;align-items:center;gap:.5rem;margin-bottom:.35rem;padding:.5rem .75rem;font-size:.85rem;display:flex}.question-list-item:hover{background:var(--accent-bg)}.question-list-item.active{background:var(--accent-bg);border-color:var(--accent);color:var(--text-h);font-weight:600}.drag-handle{cursor:grab;opacity:.4;font-size:.75rem}.drag-handle:active{cursor:grabbing}.question-list-label{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.question-detail{flex:1;min-width:0;overflow:visible}.editor-js-container{border:1px solid var(--border);background:var(--bg);z-index:1;border-radius:8px;min-height:200px;padding:.5rem;position:relative;overflow:visible}.editor-js-container:focus-within{z-index:50}.editor-js-container .codex-editor__redactor{padding-bottom:100px!important}.editor-js-container .ce-block__content,.editor-js-container .ce-toolbar__content{max-width:100%}.editor-js-container .ce-paragraph,.editor-js-container .ce-header,.editor-js-container .ce-block{color:var(--text-h)}.editor-js-container .ce-toolbar__plus,.editor-js-container .ce-toolbar__settings-btn{color:var(--text);background:var(--bg-surface);border:1px solid var(--border)}.editor-js-container .ce-toolbar__plus:hover,.editor-js-container .ce-toolbar__settings-btn:hover{background:var(--border)}.editor-js-container .ce-inline-toolbar,.editor-js-container .ce-conversion-toolbar,.editor-js-container .ce-settings,.editor-js-container .ce-toolbox,.editor-js-container .ce-popover{background:var(--bg-surface);border-color:var(--border);color:var(--text-h)}.editor-js-container .ce-popover-item__title{color:var(--text-h)}.editor-js-container .ce-popover-item__icon{color:var(--text);background:var(--bg);border-color:var(--border)}.editor-js-container .cdx-input{background:var(--bg);color:var(--text-h);border-color:var(--border)}.editor-js-container .ce-code__textarea{background:var(--code-bg);color:var(--text-h)}.editor-js-container .cdx-search-field{background:var(--bg);color:var(--text-h);border-color:var(--border)}.editor-js-container .cdx-search-field__input{color:var(--text-h)}:is(.editor-js-container:has(.ce-popover--opened) .ce-toolbar__plus,.editor-js-container:has(.ce-popover--opened) .ce-toolbar__settings-btn){display:none!important}.editor-js-container .ce-popover{z-index:9999!important;pointer-events:auto!important}.editor-js-container .ce-settings{position:relative;z-index:9999!important}.editor-js-container .ce-toolbar{z-index:9998!important}.editor-js-container .ce-block{z-index:1;position:relative}.editor-js-container .ce-block--focused{z-index:2}.editor-js-container .codex-editor{overflow:visible!important}.editor-js-container .ce-popover__container{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-h);box-shadow:var(--shadow);border-radius:8px}.editor-js-container .ce-popover__items{scrollbar-color:var(--border) transparent;scrollbar-width:thin}.editor-js-container .ce-popover__container::-webkit-scrollbar{width:6px}.editor-js-container .ce-popover__items::-webkit-scrollbar{width:6px}.editor-js-container .ce-popover__container::-webkit-scrollbar-track{background:0 0}.editor-js-container .ce-popover__items::-webkit-scrollbar-track{background:0 0}.editor-js-container .ce-popover__container::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.editor-js-container .ce-popover__items::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.editor-js-container .ce-popover-item__icon svg{color:var(--text)}.editor-js-container .ce-popover-item{color:var(--text-h)}.editor-js-container .ce-popover-item:hover{background:var(--accent-bg)}.editor-js-container .cdx-search-field{background:var(--bg);border-color:var(--border)}.editor-js-container .cdx-search-field__icon{display:none}.editor-js-container .ce-toolbar__actions{background:var(--bg-surface)}.editor-js-container .ce-settings__button{color:var(--text)}.editor-js-container .ce-settings__button:hover{background:var(--accent-bg)}.editor-js-container .ce-inline-toolbar,.editor-js-container .ce-inline-toolbar__buttons,.editor-js-container .ce-inline-toolbar__dropdown{background:var(--bg-surface);border-color:var(--border);color:var(--text-h)}.editor-js-container .ce-conversion-toolbar{color:var(--text-h);background:var(--bg-surface)!important;border-color:var(--border)!important}.editor-js-container .ce-conversion-tool{color:var(--text-h)}.editor-js-container .ce-conversion-tool:hover{background:var(--accent-bg)}.editor-js-container .ce-conversion-tool__icon{background:var(--bg)!important;border-color:var(--border)!important}.editor-js-container .ce-inline-tool{color:var(--text)}.editor-js-container .ce-inline-tool:hover{background:var(--accent-bg)}.igb{color:var(--text-h)}.igb-title{color:var(--text-h);margin:0 0 12px}.igb-config{gap:16px;margin-bottom:12px;display:flex}.igb-label{color:var(--text-h);flex-direction:column;gap:4px;font-size:13px;font-weight:600;display:flex}.igb-input{border:1px solid var(--border);background:var(--bg);width:80px;color:var(--text-h);border-radius:4px;padding:4px 8px}.igb-section{border:1px solid var(--border);background:var(--bg-surface);border-radius:8px;margin-bottom:12px;padding:12px}.igb-section-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.igb-section-label{color:var(--text-h);font-size:13px}.igb-upload-btn{border:1px solid var(--border);background:var(--bg);color:var(--text-h);cursor:pointer;border-radius:4px;padding:4px 12px;font-size:12px}.igb-upload-btn:hover{background:var(--accent-bg)}.igb-thumbs{flex-wrap:wrap;gap:6px;display:flex}.igb-thumb{border:1px solid var(--border);border-radius:4px;width:60px;height:60px;position:relative;overflow:hidden}.igb-thumb img{object-fit:cover;width:100%;height:100%}.igb-remove{color:#fff;cursor:pointer;background:#0009;border:none;border-radius:0 4px;width:18px;height:18px;font-size:12px;line-height:1;position:absolute;top:0;right:0}.igb-preview-btn{border:1px solid var(--border);background:var(--bg);color:var(--text-h);cursor:pointer;border-radius:6px;margin-top:12px;padding:6px 16px}.igb-preview-btn:hover{background:var(--accent-bg)}.igb-preview{margin-top:12px}.igb-grid{gap:4px;display:grid}.igb-cell{border:1px solid var(--border);border-radius:4px;width:40px;height:40px;overflow:hidden}.igb-cell img{object-fit:cover;width:100%;height:100%}.igb-cell--target{border:2px solid var(--accent)}.igb-note{color:var(--text);margin-top:8px;font-size:12px}.btn:disabled,.btn-sm:disabled{opacity:.4;cursor:not-allowed}.test-questions{flex-direction:column;gap:1.5rem;margin:1.5rem 0;display:flex}.question-card{border:1px solid var(--border);border-radius:8px;padding:1.25rem}.question-number{color:var(--accent);margin:0 0 .25rem;font-size:.8rem;font-weight:600}.question-text{margin:0 0 1rem;font-size:1.05rem}.options{flex-direction:column;gap:.5rem;display:flex}.option-label{border:1px solid var(--border);cursor:pointer;border-radius:6px;align-items:center;gap:.5rem;padding:.5rem;display:flex}.option-label:hover{background:var(--accent-bg)}.option-label input[type=radio]{margin:0}.submit-btn{background:var(--btn-bg);color:var(--btn-text);cursor:pointer;border:none;border-radius:6px;padding:.75rem 2rem;font-size:1rem;font-weight:600}.submit-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.result-card{text-align:center;border:1px solid var(--border);border-radius:12px;max-width:400px;margin:2rem auto;padding:2rem}.result-card .score{color:var(--accent);margin:0;font-size:2.5rem;font-weight:700}.module-desc{color:var(--text);margin-bottom:1rem;font-size:1.05rem}.purchase-prompt{border:1px solid var(--border);text-align:left;border-radius:12px;margin-top:1.5rem;padding:2rem}.purchase-prompt ol{margin:1rem 0}.module-content{margin-top:1.5rem}.module-lesson{border-bottom:1px solid var(--border);margin-bottom:2.5rem;padding-bottom:2rem}.module-lesson:last-child{border-bottom:none}.lessons-count{color:var(--text);margin:.5rem 0 0;font-size:.85rem}.locked-title{color:var(--text);opacity:.6}.editor-content figure{margin:1rem 0}.editor-content figure img{border-radius:8px;max-width:100%}.editor-content figcaption{color:var(--text);text-align:center;margin-top:.5rem;font-size:.85rem}.embed-wrapper{margin:1rem 0}.embed-wrapper iframe{border:none;border-radius:8px;width:100%;min-height:400px}.embed-caption{color:var(--text);text-align:center;font-size:.85rem}.image-grid-exercise{margin:1.5rem 0}.image-grid{gap:6px;display:grid;overflow-x:auto}.grid-cell{border:2px solid var(--border);cursor:pointer;border-radius:4px;width:64px;height:64px;transition:border-color .15s;overflow:hidden}.grid-cell img{object-fit:cover;width:100%;height:100%}.grid-cell.empty{background:var(--bg-surface);cursor:default}.grid-cell.selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-bg)}.grid-cell.correct{border-color:var(--success);box-shadow:0 0 0 2px var(--success-bg)}.grid-cell.missed{border-color:var(--warning);box-shadow:0 0 0 2px var(--warning-bg)}.grid-cell.wrong{border-color:var(--danger);box-shadow:0 0 0 2px var(--danger-bg)}.toast-container{z-index:1000;flex-direction:column;gap:.5rem;display:flex;position:fixed;bottom:1.5rem;right:1.5rem}.toast{box-shadow:var(--shadow);border-radius:8px;padding:.75rem 1.25rem;font-size:.9rem;font-weight:500;animation:.2s ease-out toast-in}.toast-success{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}.toast-error{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border)}@keyframes toast-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}:root{--text:#4b5563;--text-h:#1f2937;--bg:#fff;--bg-surface:#f9fafb;--border:#d1d5db;--code-bg:#f3f4f6;--accent:#7c3aed;--accent-bg:#7c3aed14;--accent-border:#7c3aed66;--btn-bg:#7c3aed;--btn-text:#fff;--success:#0d542b;--success-bg:#d1fae5;--success-border:#a7f3d0;--danger:#7f1d1d;--danger-bg:#fee2e2;--danger-border:#fecaca;--warning:#713f12;--warning-bg:#fef3c7;--warning-border:#fde68a;--shadow:#00000014 0 10px 15px -3px, #0000000a 0 4px 6px -2px;font:16px/160% var(--font-sans);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial;--text:#d1d5db;--text-h:#f3f4f6;--bg:#0f1117;--bg-surface:#1a1b23;--border:#374151;--code-bg:#1f2028;--accent:#a78bfa;--accent-bg:#a78bfa1f;--accent-border:#a78bfa66;--btn-bg:#6d28d9;--btn-text:#fff;--success:#6ee7b7;--success-bg:#6ee7b726;--success-border:#6ee7b74d;--danger:#fca5a5;--danger-bg:#fca5a526;--danger-border:#fca5a54d;--warning:#fcd34d;--warning-bg:#fcd34d26;--warning-border:#fcd34d4d;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}}body{margin:0}#root{box-sizing:border-box;flex-direction:column;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2,h3{font-family:var(--font-heading);color:var(--text-h)}h1{letter-spacing:-.5px;margin:1.5rem 0;font-size:2.5rem;font-weight:800}@media (width<=768px){h1{font-size:1.75rem}}h2{letter-spacing:-.25px;margin:0 0 .5rem;font-size:1.5rem;font-weight:700}h3{font-size:1.15rem;font-weight:700}p{margin:0}code{font-family:var(--font-mono);background:var(--code-bg);color:var(--text-h);border-radius:4px;padding:2px 6px;font-size:.85rem}input,select,textarea{background:var(--bg);color:var(--text-h);border:1px solid var(--border);font-family:inherit}input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);outline-offset:1px}@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-leading{syntax:"*";inherits:false}@property --tw-font-weight{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-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}
