@font-face{font-family:Outfit;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/b2ea385cb5ae8625-s.866357a4.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Outfit;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1b99372b3eaef0c8-s.p.758e15a8.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Outfit Fallback;src:local(Arial);ascent-override:100.18%;descent-override:26.05%;line-gap-override:0.0%;size-adjust:99.82%}.outfit_9f4f9187-module__4LtYgq__className{font-family:Outfit,Outfit Fallback;font-style:normal}.outfit_9f4f9187-module__4LtYgq__variable{--font-outfit:"Outfit","Outfit Fallback"}
@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/13bf9871fe164e7f-s.f2220059.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/cc545e633e20c56d-s.f6f1950f.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/71b036adf157cdcf-s.bd5f4d11.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/89b21bb081cb7469-s.51c18f09.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/3fe682a82f50d426-s.23358719.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/70bc3e132a0a741e-s.p.15008bfb.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:JetBrains Mono Fallback;src:local(Arial);ascent-override:75.79%;descent-override:22.29%;line-gap-override:0.0%;size-adjust:134.59%}.jetbrains_mono_17db8d30-module__Lc4KjW__className{font-family:JetBrains Mono,JetBrains Mono Fallback;font-style:normal}.jetbrains_mono_17db8d30-module__Lc4KjW__variable{--font-mono-var:"JetBrains Mono","JetBrains Mono Fallback"}
@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-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-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}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-red-500:#fb2c36;--color-green-500:#00c758;--color-blue-500:#3080ff;--color-gray-200:#e5e7eb;--color-white:#fff;--spacing:.25rem;--container-6xl:72rem;--container-7xl:80rem;--text-xs:.75rem;--text-sm:.875rem;--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-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:3rem;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--leading-tight:1.25;--leading-snug:1.375;--leading-normal:1.5;--leading-relaxed:1.625;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--shadow-sm:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--ease-in:cubic-bezier(.4,0,1,1);--ease-out:cubic-bezier(0,0,.2,1);--animate-spin:spin 1s linear infinite;--animate-pulse:pulse 2s cubic-bezier(.4,0,.6,1)infinite;--animate-bounce:bounce 1s 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)}@supports (color:lab(0% 0 0)){:root,:host{--color-red-500:lab(55.4814% 75.0732 48.8528);--color-green-500:lab(70.5521% -66.5147 45.8073);--color-blue-500:lab(54.1736% 13.3369 -74.6839);--color-gray-200:lab(91.6229% -.159115 -2.26791)}}}@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{.\@container{container-type:inline-size}.collapse{visibility:collapse}.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}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.top-0{top:calc(var(--spacing)*0)}.top-4{top:calc(var(--spacing)*4)}.right-0{right:calc(var(--spacing)*0)}.right-4{right:calc(var(--spacing)*4)}.left-0{left:calc(var(--spacing)*0)}.left-4{left:calc(var(--spacing)*4)}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-40{z-index:40}.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}}.m-6{margin:calc(var(--spacing)*6)}.mx-auto{margin-inline:auto}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-flex{display:inline-flex}.inline-grid{display:inline-grid}.table{display:table}.size-6{width:calc(var(--spacing)*6);height:calc(var(--spacing)*6)}.size-8{width:calc(var(--spacing)*8);height:calc(var(--spacing)*8)}.h-4{height:calc(var(--spacing)*4)}.h-6{height:calc(var(--spacing)*6)}.h-12{height:calc(var(--spacing)*12)}.h-14{height:calc(var(--spacing)*14)}.h-48{height:calc(var(--spacing)*48)}.w-6{width:calc(var(--spacing)*6)}.w-8{width:calc(var(--spacing)*8)}.w-12{width:calc(var(--spacing)*12)}.w-32{width:calc(var(--spacing)*32)}.w-64{width:calc(var(--spacing)*64)}.w-\[200px\]{width:200px}.w-full{width:100%}.max-w-6xl{max-width:var(--container-6xl)}.max-w-7xl{max-width:var(--container-7xl)}.flex-shrink,.shrink{flex-shrink:1}.shrink-0{flex-shrink:0}.flex-grow,.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,)}.animate-bounce{animation:var(--animate-bounce)}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.cursor-pointer{cursor:pointer}.resize{resize:both}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-nowrap{flex-wrap:nowrap}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.gap-2{gap:calc(var(--spacing)*2)}.gap-6{gap:calc(var(--spacing)*6)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.\!rounded-full{border-radius:3.40282e38px!important}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-gray-200{border-color:var(--color-gray-200)}.border-white\/10{border-color:#ffffff1a}@supports (color:color-mix(in lab, red, red)){.border-white\/10{border-color:color-mix(in oklab,var(--color-white)10%,transparent)}}.bg-blue-500{background-color:var(--color-blue-500)}.bg-green-500{background-color:var(--color-green-500)}.bg-red-500{background-color:var(--color-red-500)}.bg-transparent{background-color:#0000}.bg-white\/10{background-color:#ffffff1a}@supports (color:color-mix(in lab, red, red)){.bg-white\/10{background-color:color-mix(in oklab,var(--color-white)10%,transparent)}}.bg-white\/80{background-color:#fffc}@supports (color:color-mix(in lab, red, red)){.bg-white\/80{background-color:color-mix(in oklab,var(--color-white)80%,transparent)}}.from-blue-500{--tw-gradient-from:var(--color-blue-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))}.object-cover{object-fit:cover}.px-3{padding-inline:calc(var(--spacing)*3)}.px-4{padding-inline:calc(var(--spacing)*4)}.px-6{padding-inline:calc(var(--spacing)*6)}.px-8{padding-inline:calc(var(--spacing)*8)}.py-2{padding-block:calc(var(--spacing)*2)}.py-4{padding-block:calc(var(--spacing)*4)}.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-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-red-500{color:var(--color-red-500)}.italic{font-style:italic}.underline{text-decoration-line:underline}.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)}.shadow-\[0_4px_20px_rgba\(0\,0\,0\,0\.1\)\]{--tw-shadow:0 4px 20px 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)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a),0 4px 6px -4px 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)}.shadow-md{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a),0 2px 4px -2px 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)}.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,)}.drop-shadow{--tw-drop-shadow-size:drop-shadow(0 1px 2px var(--tw-drop-shadow-color,#0000001a))drop-shadow(0 1px 1px var(--tw-drop-shadow-color,#0000000f));--tw-drop-shadow:drop-shadow(0 1px 2px #0000001a)drop-shadow(0 1px 1px #0000000f);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,)}.sepia{--tw-sepia:sepia(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))}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.ease-in{--tw-ease:var(--ease-in);transition-timing-function:var(--ease-in)}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.outline-none{--tw-outline-style:none;outline-style:none}.focus\:ring-2:focus{--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)}.focus\:ring-blue-500:focus{--tw-ring-color:var(--color-blue-500)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.focus-visible\:ring-2:focus-visible{--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)}.focus-visible\:ring-blue-500:focus-visible{--tw-ring-color:var(--color-blue-500)}@media (min-width:40rem){.sm\:px-6{padding-inline:calc(var(--spacing)*6)}}@media (min-width:48rem){.md\:px-6{padding-inline:calc(var(--spacing)*6)}}}:root{--clr-bg:#f8fafc;--clr-bg-alt:#eff6ff;--clr-surface:#fff;--clr-border:#e2e8f0;--clr-border-strong:#cbd5e1;--clr-text:#0f172a;--clr-text-muted:#64748b;--clr-text-subtle:#94a3b8;--clr-primary:#0ea5e9;--clr-primary-hover:#0284c7;--clr-primary-light:#e0f2fe;--clr-primary-dark:#0369a1;--clr-accent:#10b981;--clr-accent-light:#d1fae5;--clr-accent-dark:#059669;--clr-warning-bg:#fffbeb;--clr-warning-border:#f59e0b;--clr-warning-text:#92400e;--clr-info-bg:#eff6ff;--clr-info-border:#3b82f6;--clr-info-text:#1e40af;--clr-success-bg:#f0fdf4;--clr-success-border:#22c55e;--clr-success-text:#166534;--clr-code-bg:#0f172a;--clr-code-header:#1e293b;--clr-inline-code-bg:#e0f2fe;--clr-inline-code-text:#0369a1;--font-sans:var(--font-outfit,"Outfit",system-ui,-apple-system,sans-serif);--font-mono:var(--font-mono-var,"JetBrains Mono","Fira Code",monospace);--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-md:1.0625rem;--text-lg:1.125rem;--text-xl:1.375rem;--text-2xl:1.75rem;--text-3xl:2.25rem;--text-4xl:3rem;--text-5xl:3.75rem;--leading-tight:1.2;--leading-snug:1.4;--leading-normal:1.65;--leading-relaxed:1.8;--sp-1:.25rem;--sp-2:.5rem;--sp-3:.75rem;--sp-4:1rem;--sp-5:1.25rem;--sp-6:1.5rem;--sp-8:2rem;--sp-10:2.5rem;--sp-12:3rem;--sp-16:4rem;--sp-20:5rem;--sp-24:6rem;--r-sm:.25rem;--r-md:.5rem;--r-lg:.75rem;--r-xl:1rem;--r-2xl:1.5rem;--r-full:9999px;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 4px #0000000f,0 1px 2px #0000000a;--shadow-md:0 4px 12px #00000014,0 2px 4px #0000000d;--shadow-lg:0 12px 32px #0000001a,0 4px 8px #0000000f;--ease-out:cubic-bezier(.22,1,.36,1);--t-fast:.12s var(--ease-out);--t-base:.22s var(--ease-out);--t-slow:.38s var(--ease-out);--header-h:3.75rem;--sidebar-w:256px;--content-w:860px;--page-max:1360px;--page-pad:var(--sp-6)}[data-theme=dark]{--clr-bg:#0f172a;--clr-bg-alt:#1e293b;--clr-surface:#1e293b;--clr-border:#334155;--clr-border-strong:#475569;--clr-text:#f1f5f9;--clr-text-muted:#94a3b8;--clr-text-subtle:#64748b;--clr-primary:#38bdf8;--clr-primary-hover:#7dd3fc;--clr-primary-light:#0c4a6e;--clr-primary-dark:#bae6fd;--clr-accent:#34d399;--clr-accent-light:#064e3b;--clr-accent-dark:#6ee7b7;--clr-warning-bg:#451a03;--clr-warning-border:#d97706;--clr-warning-text:#fcd34d;--clr-info-bg:#172554;--clr-info-border:#3b82f6;--clr-info-text:#93c5fd;--clr-success-bg:#052e16;--clr-success-border:#22c55e;--clr-success-text:#86efac;--clr-code-bg:#020617;--clr-code-header:#0f172a;--clr-inline-code-bg:#0c4a6e;--clr-inline-code-text:#7dd3fc;--shadow-xs:0 1px 2px #0003;--shadow-sm:0 1px 4px #0000004d,0 1px 2px #0003;--shadow-md:0 4px 12px #0006,0 2px 4px #00000040;--shadow-lg:0 12px 32px #00000080,0 4px 8px #0000004d}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:16px}body{background-color:var(--clr-bg);color:var(--clr-text);font-family:var(--font-sans);font-size:var(--text-md);line-height:var(--leading-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;transition:background-color .2s,color .2s}a{color:var(--clr-primary);text-underline-offset:3px;transition:color var(--t-fast),opacity var(--t-fast);text-decoration-thickness:1px}a:hover{color:var(--clr-primary-hover);opacity:1}img,svg{max-width:100%;display:block}code,pre,kbd{font-family:var(--font-mono)}:focus-visible{outline:2px solid var(--clr-primary);outline-offset:3px;border-radius:var(--r-sm)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--clr-border-strong);border-radius:var(--r-full)}::-webkit-scrollbar-thumb:hover{background:var(--clr-text-subtle)}.site-wrapper{flex-direction:column;min-height:100dvh;display:flex}.site-main{flex:1}.container{width:100%;max-width:var(--page-max);padding:0 var(--page-pad);margin:0 auto}.header{z-index:100;height:var(--header-h);background:var(--clr-bg);align-items:center;display:flex;position:sticky;top:0}@supports (color:color-mix(in lab, red, red)){.header{background:color-mix(in srgb,var(--clr-bg)88%,transparent)}}.header{-webkit-backdrop-filter:blur(16px)saturate(180%);border-bottom:1px solid var(--clr-border);transition:border-color var(--t-base),background-color var(--t-base)}.header__inner{align-items:center;gap:var(--sp-6);height:100%;display:flex}.header__logo{font-size:var(--text-base);color:var(--clr-text);letter-spacing:-.02em;align-items:center;gap:var(--sp-2);flex-shrink:0;font-weight:700;text-decoration:none;display:flex}.header__logo:hover{opacity:.8;color:var(--clr-text)}.header__logo-mark{background:linear-gradient(135deg,var(--clr-primary),var(--clr-accent));border-radius:var(--r-md);color:#fff;width:28px;height:28px;font-size:var(--text-xs);flex-shrink:0;justify-content:center;align-items:center;font-weight:800;display:inline-flex}.header__nav{align-items:center;gap:var(--sp-1);margin-left:auto;display:flex}.header__link{font-size:var(--text-sm);color:var(--clr-text-muted);padding:var(--sp-1)var(--sp-3);border-radius:var(--r-md);transition:color var(--t-fast),background-color var(--t-fast);font-weight:500;text-decoration:none}.header__link:hover,.header__link[data-active=true]{color:var(--clr-text);background-color:var(--clr-bg-alt)}.theme-toggle{border:1px solid var(--clr-border-strong);border-radius:var(--r-full);width:2.125rem;height:2.125rem;color:var(--clr-text-muted);cursor:pointer;transition:color var(--t-fast),background-color var(--t-fast),border-color var(--t-fast);background:0 0;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.theme-toggle:hover{color:var(--clr-text);background-color:var(--clr-bg-alt)}.theme-toggle svg{pointer-events:none;width:1rem;height:1rem}.footer{border-top:1px solid var(--clr-border);padding:var(--sp-8)0;text-align:center;color:var(--clr-text-muted);font-size:var(--text-sm)}.footer a{color:var(--clr-text-muted);font-weight:600;text-decoration:none}.footer a:hover{color:var(--clr-primary)}.hero{padding:var(--sp-24)0 var(--sp-16);position:relative;overflow:hidden}.hero:after{content:"";background:radial-gradient(circle,var(--clr-primary)0%,transparent 65%);width:700px;height:700px;position:absolute;top:-160px;right:-80px}@supports (color:color-mix(in lab, red, red)){.hero:after{background:radial-gradient(circle,color-mix(in srgb,var(--clr-primary)12%,transparent)0%,transparent 65%)}}.hero:after{pointer-events:none;z-index:0}.hero__inner{z-index:1;position:relative}.hero__badge{align-items:center;gap:var(--sp-2);font-size:var(--text-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--clr-primary);background:var(--clr-primary-light);padding:var(--sp-1)var(--sp-3);border-radius:var(--r-full);margin-bottom:var(--sp-6);font-weight:700;display:inline-flex}.hero__title{font-size:clamp(var(--text-3xl),5.5vw,var(--text-5xl));letter-spacing:-.04em;margin-bottom:var(--sp-5);max-width:14ch;font-weight:800;line-height:1.08}.hero__title em{background:linear-gradient(135deg,var(--clr-primary)0%,var(--clr-accent)100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-style:normal}.hero__subtitle{font-size:var(--text-xl);color:var(--clr-text-muted);line-height:var(--leading-relaxed);max-width:52ch;margin-bottom:var(--sp-10)}.hero__meta{align-items:center;gap:var(--sp-5);flex-wrap:wrap;display:flex}.hero__stat{align-items:center;gap:var(--sp-2);font-size:var(--text-sm);color:var(--clr-text-muted);font-weight:500;display:flex}.hero__stat-dot{background:var(--clr-accent);border-radius:50%;flex-shrink:0;width:6px;height:6px}.lessons-section{padding:var(--sp-16)0 var(--sp-24)}.lessons-section__header{margin-bottom:var(--sp-10)}.lessons-section__eyebrow{font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--clr-text-subtle);margin-bottom:var(--sp-2);font-weight:700}.lessons-section__title{font-size:var(--text-2xl);letter-spacing:-.025em;color:var(--clr-text);font-weight:700}.card-grid{gap:var(--sp-5);grid-template-columns:repeat(auto-fill,minmax(268px,1fr));display:grid}.lesson-card{padding:var(--sp-6);background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--r-xl);color:inherit;transition:transform var(--t-base),box-shadow var(--t-base),border-color var(--t-base);flex-direction:column;text-decoration:none;display:flex;position:relative;overflow:hidden}.lesson-card:before{content:"";border-radius:inherit;background:linear-gradient(135deg,var(--clr-primary),transparent 60%);position:absolute;inset:0}@supports (color:color-mix(in lab, red, red)){.lesson-card:before{background:linear-gradient(135deg,color-mix(in srgb,var(--clr-primary)4%,transparent),transparent 60%)}}.lesson-card:before{opacity:0;transition:opacity var(--t-base)}.lesson-card:hover{box-shadow:var(--shadow-lg);border-color:var(--clr-primary);opacity:1;transform:translateY(-4px)}.lesson-card:hover:before{opacity:1}.card__number{background:var(--clr-primary-light);width:2rem;height:2rem;color:var(--clr-primary-dark);border-radius:var(--r-md);font-size:var(--text-xs);font-weight:800;font-family:var(--font-mono);letter-spacing:.02em;margin-bottom:var(--sp-4);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.card__title{font-size:var(--text-xl);letter-spacing:-.025em;color:var(--clr-text);margin-bottom:var(--sp-3);font-weight:700;line-height:var(--leading-snug)}.card__description{font-size:var(--text-sm);color:var(--clr-text-muted);line-height:var(--leading-relaxed);margin-bottom:var(--sp-5);flex:1}.card__cta{align-items:center;gap:var(--sp-2);font-size:var(--text-sm);color:var(--clr-primary);transition:gap var(--t-fast);font-weight:600;display:inline-flex}.lesson-card:hover .card__cta{gap:var(--sp-3)}.lesson-page{grid-template-columns:var(--sidebar-w)minmax(0,1fr);max-width:var(--page-max);padding:0 var(--page-pad);gap:var(--sp-12);align-items:start;margin:0 auto;display:grid}@media (max-width:900px){.lesson-page{grid-template-columns:1fr;gap:0}}.sidebar{top:calc(var(--header-h) + var(--sp-8));padding:var(--sp-8)0 var(--sp-16);align-self:start;position:sticky}@media (max-width:900px){.sidebar{display:none}}.toc__label{font-size:var(--text-xs);letter-spacing:.09em;text-transform:uppercase;color:var(--clr-text-subtle);margin-bottom:var(--sp-4);padding-left:var(--sp-3);font-weight:700}.toc__list{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.toc__link{font-size:var(--text-sm);color:var(--clr-text-muted);padding:5px var(--sp-3);border-left:2px solid var(--clr-border);line-height:var(--leading-snug);transition:color var(--t-fast),border-color var(--t-fast),background-color var(--t-fast);border-radius:0 var(--r-sm)var(--r-sm)0;text-decoration:none;display:block}.toc__link:hover{color:var(--clr-text);border-left-color:var(--clr-border-strong);background:var(--clr-bg-alt);opacity:1}.toc__link[data-active=true]{color:var(--clr-primary);border-left-color:var(--clr-primary);background:var(--clr-primary-light);opacity:1;font-weight:600}.lesson-content{padding:var(--sp-8)0 var(--sp-20);max-width:var(--content-w)}.lesson-header{margin-bottom:var(--sp-12);padding-bottom:var(--sp-10);border-bottom:1px solid var(--clr-border)}.lesson-header__eyebrow{align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-5);display:flex}.lesson-header__num{background:var(--clr-primary-light);width:1.75rem;height:1.75rem;color:var(--clr-primary-dark);border-radius:var(--r-md);font-size:var(--text-xs);font-weight:800;font-family:var(--font-mono);justify-content:center;align-items:center;display:inline-flex}.lesson-header__label{font-size:var(--text-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--clr-text-subtle);font-weight:700}.lesson-header__title{font-size:clamp(var(--text-2xl),4vw,var(--text-4xl));letter-spacing:-.04em;margin-bottom:var(--sp-4);color:var(--clr-text);font-weight:800;line-height:1.1}.lesson-header__subtitle{font-size:var(--text-lg);color:var(--clr-text-muted);line-height:var(--leading-relaxed);max-width:58ch}.lesson-content h2{font-size:var(--text-2xl);letter-spacing:-.03em;font-weight:700;line-height:var(--leading-snug);margin-top:var(--sp-16);margin-bottom:var(--sp-5);color:var(--clr-text);scroll-margin-top:calc(var(--header-h) + var(--sp-8))}.lesson-content h3{font-size:var(--text-xl);letter-spacing:-.02em;font-weight:700;line-height:var(--leading-snug);margin-top:var(--sp-10);margin-bottom:var(--sp-4);color:var(--clr-text);scroll-margin-top:calc(var(--header-h) + var(--sp-8))}.lesson-content h4{font-size:var(--text-base);margin-top:var(--sp-6);margin-bottom:var(--sp-3);color:var(--clr-text);font-weight:700}.lesson-content p{margin-bottom:var(--sp-5);line-height:var(--leading-relaxed);color:var(--clr-text)}.lesson-content p:last-child{margin-bottom:0}.lesson-content ul,.lesson-content ol{padding-left:var(--sp-6);margin-bottom:var(--sp-5)}.lesson-content li{margin-bottom:var(--sp-2);line-height:var(--leading-relaxed)}.lesson-content code{background:var(--clr-inline-code-bg);color:var(--clr-inline-code-text);border-radius:var(--r-sm);font-size:.875em;font-family:var(--font-mono);padding:.15em .4em;font-weight:500}.lesson-content pre code{color:inherit;background:0 0;border-radius:0;padding:0;font-weight:400}.lesson-content section{border-bottom:1px solid var(--clr-border);padding-bottom:var(--sp-10);margin-bottom:0}.lesson-content section:last-of-type{border-bottom:none}.code-block{margin:var(--sp-6)0;border-radius:var(--r-lg);box-shadow:var(--shadow-md);border:1px solid #20293c;position:relative;overflow:hidden}.code-block__header{padding:var(--sp-2)var(--sp-4);background:var(--clr-code-header);justify-content:space-between;align-items:center;gap:var(--sp-4);border-bottom:1px solid #20293c;display:flex}.code-block__dots{flex-shrink:0;gap:5px;display:flex}.code-block__dot{border-radius:50%;width:10px;height:10px}.code-block__dot--red{background:#ff5f57}.code-block__dot--yellow{background:#febc2e}.code-block__dot--green{background:#28c840}.code-block__lang{font-size:var(--text-xs);color:#7b879d;text-transform:uppercase;letter-spacing:.07em;font-weight:600;font-family:var(--font-mono);padding-left:var(--sp-3);margin-right:auto}.code-block__copy{align-items:center;gap:var(--sp-1);font-size:var(--text-xs);color:#7b879d;border-radius:var(--r-sm);cursor:pointer;transition:color var(--t-fast),border-color var(--t-fast),background-color var(--t-fast);background:0 0;border:1px solid #303a50;flex-shrink:0;padding:3px 10px;font-family:inherit;font-weight:600;display:inline-flex}.code-block__copy:hover{color:#fff;background:#2a3346;border-color:#56698f}.code-block__copy--copied{color:var(--clr-accent)!important;border-color:var(--clr-accent)!important}.code-block pre{font-size:var(--text-sm)!important;line-height:1.7!important;font-family:var(--font-mono)!important;border-radius:0!important;margin:0!important}.live-editor{margin:var(--sp-8)0;border:1px solid var(--clr-border);border-radius:var(--r-xl);box-shadow:var(--shadow-md);overflow:hidden}.live-editor__toolbar{background:var(--clr-bg-alt);border-bottom:1px solid var(--clr-border);padding:var(--sp-2)var(--sp-3);align-items:center;gap:var(--sp-2);display:flex}.live-editor__tab{font-size:var(--text-sm);color:var(--clr-text-muted);padding:var(--sp-1)var(--sp-3);border-radius:var(--r-md);cursor:pointer;transition:color var(--t-fast),background-color var(--t-fast);font-weight:600;font-family:var(--font-mono);background:0 0;border:none}.live-editor__tab:hover{color:var(--clr-text);background:var(--clr-border)}.live-editor__tab[data-active=true]{color:var(--clr-primary);background:var(--clr-primary-light)}.live-editor__toolbar-right{align-items:center;gap:var(--sp-2);margin-left:auto;display:flex}.live-editor__reset{font-size:var(--text-xs);color:var(--clr-text-muted);border:1px solid var(--clr-border);border-radius:var(--r-sm);cursor:pointer;transition:color var(--t-fast),border-color var(--t-fast);background:0 0;padding:3px 10px;font-family:inherit;font-weight:600}.live-editor__reset:hover{color:var(--clr-text);border-color:var(--clr-border-strong)}.live-editor__expand{width:28px;height:28px;color:var(--clr-text-muted);border:1px solid var(--clr-border);border-radius:var(--r-sm);cursor:pointer;transition:color var(--t-fast),border-color var(--t-fast),background-color var(--t-fast);background:0 0;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.live-editor__expand:hover{color:var(--clr-primary);border-color:var(--clr-primary);background:var(--clr-primary-light)}.live-editor-backdrop{-webkit-backdrop-filter:blur(4px);z-index:200;background:#0000008c;animation:.18s leBackdropIn;position:fixed;inset:0}.live-editor--expanded{inset:var(--sp-4);z-index:201;border-radius:var(--r-xl);animation:leEditorIn .2s var(--ease-out);flex-direction:column;display:flex;position:fixed;overflow:hidden;box-shadow:0 32px 80px #00000073}.live-editor--expanded .live-editor__body{flex:1;min-height:0}.live-editor--expanded .live-editor__code-area{overflow-y:auto}.live-editor--expanded .live-editor__iframe{height:100%;min-height:0}@keyframes leBackdropIn{0%{opacity:0}to{opacity:1}}@keyframes leEditorIn{0%{opacity:0;transform:scale(.97)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.live-editor__body{grid-template-columns:1fr 1fr;min-height:300px;display:grid}@media (max-width:680px){.live-editor__body{grid-template-rows:240px auto;grid-template-columns:1fr}}.live-editor__code-area{background:#0d1117;border-right:1px solid #222a39;overflow-y:auto}.live-editor__textarea{width:100%;height:100%;min-height:300px;padding:var(--sp-4);color:#cdd9e5;font-family:var(--font-mono);font-size:var(--text-sm);resize:none;tab-size:2;caret-color:var(--clr-primary);background:0 0;border:none;outline:none;line-height:1.7}.live-editor__preview-area{background:#fff;position:relative}.live-editor__iframe{border:none;width:100%;height:100%;min-height:300px;display:block}.live-editor__preview-label{top:var(--sp-2);right:var(--sp-3);font-size:var(--text-xs);color:#94a3b8;letter-spacing:.06em;text-transform:uppercase;pointer-events:none;font-weight:600;font-family:var(--font-mono);position:absolute}.live-editor__code-area pre[class*=language-],.live-editor__code-area code[class*=language-]{text-shadow:none;background:0 0}.live-editor__code-area .token.comment{color:#768390;font-style:italic}.live-editor__code-area .token.tag{color:#7ee787}.live-editor__code-area .token.attr-name{color:#79c0ff}.live-editor__code-area .token.attr-value,.live-editor__code-area .token.string{color:#a5d6ff}.live-editor__code-area .token.punctuation{color:#768390}.live-editor__code-area .token.selector{color:#7ee787}.live-editor__code-area .token.property{color:#79c0ff}.live-editor__code-area .token.number,.live-editor__code-area .token.unit,.live-editor__code-area .token.hexcode{color:#f2cc60}.live-editor__code-area .token.function{color:#d2a8ff}.live-editor__code-area .token.keyword,.live-editor__code-area .token.atrule{color:#ff7b72}.live-editor__code-area .token.important{color:#ff7b72;font-weight:700}.solution-preview{border:1px solid var(--clr-border);border-radius:var(--r-lg);margin:1rem 0 0;overflow:hidden}.solution-preview__label{background:var(--clr-bg-alt);border-bottom:1px solid var(--clr-border);color:var(--clr-text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.7rem;font-weight:700;font-family:var(--font-mono);align-items:center;gap:.375rem;padding:5px 12px;display:flex}.solution-preview__iframe{background:#fff;border:none;width:100%;display:block}.callout{gap:var(--sp-4);padding:var(--sp-5)var(--sp-6);border-radius:var(--r-lg);margin:var(--sp-6)0;border-left:4px solid;display:flex}.callout--info{background:var(--clr-info-bg);border-left-color:var(--clr-info-border);color:var(--clr-text)}.callout--tip{background:var(--clr-success-bg);border-left-color:var(--clr-success-border);color:var(--clr-text)}.callout--warning{background:var(--clr-warning-bg);border-left-color:var(--clr-warning-border);color:var(--clr-text)}.callout__icon{font-size:var(--text-lg);flex-shrink:0;margin-top:1px;line-height:1.5}.callout__body{font-size:var(--text-sm);line-height:var(--leading-relaxed);flex:1}.callout__title{font-weight:700;font-size:var(--text-base);margin-bottom:var(--sp-1);display:block}.callout--info .callout__title{color:var(--clr-info-text)}.callout--tip .callout__title{color:var(--clr-success-text)}.callout--warning .callout__title{color:var(--clr-warning-text)}.callout__body p{margin:0}.callout__body p+p{margin-top:var(--sp-2)}.exercises-block{background:var(--clr-bg-alt);border:1px solid var(--clr-border);border-radius:var(--r-xl);padding:var(--sp-8);margin:var(--sp-8)0}.exercises-block__title{font-size:var(--text-lg);margin-bottom:var(--sp-6);color:var(--clr-text);align-items:center;gap:var(--sp-2);font-weight:700;display:flex}.exercises-block__icon{font-size:var(--text-xl)}.exercise-item{padding:var(--sp-5)0;border-bottom:1px solid var(--clr-border)}.exercise-item:first-of-type{padding-top:0}.exercise-item:last-child{border-bottom:none;padding-bottom:0}.exercise-item__badge{font-size:var(--text-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--clr-primary);margin-bottom:var(--sp-2);align-items:center;gap:var(--sp-2);font-weight:700;display:flex}.exercise-item__title{font-size:var(--text-base);color:var(--clr-text);margin-bottom:var(--sp-2);font-weight:700}.exercise-item__desc{font-size:var(--text-sm);color:var(--clr-text-muted);line-height:var(--leading-relaxed)}.exercise-item__desc ul{margin-top:var(--sp-2);padding-left:var(--sp-5)}.exercise-item__desc li{margin-bottom:var(--sp-1)}.resources-block{margin:var(--sp-8)0}.resources-block__title{font-size:var(--text-lg);color:var(--clr-text);margin-bottom:var(--sp-5);align-items:center;gap:var(--sp-2);font-weight:700;display:flex}.resource-list{gap:var(--sp-3);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.resource-link{align-items:center;gap:var(--sp-4);padding:var(--sp-4)var(--sp-5);background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--r-lg);color:var(--clr-text);transition:border-color var(--t-fast),box-shadow var(--t-fast),transform var(--t-fast);text-decoration:none;display:flex}.resource-link:hover{border-color:var(--clr-primary);box-shadow:var(--shadow-sm);opacity:1;transform:translate(2px)}.resource-link__icon{font-size:var(--text-xl);flex-shrink:0}.resource-link__body{flex-direction:column;gap:2px;display:flex}.resource-link__name{font-weight:600;font-size:var(--text-sm)}.resource-link__desc{font-size:var(--text-xs);color:var(--clr-text-muted)}.lesson-nav{justify-content:space-between;align-items:stretch;gap:var(--sp-4);margin-top:var(--sp-16);padding-top:var(--sp-8);border-top:1px solid var(--clr-border);flex-wrap:wrap;display:flex}.lesson-nav__link{gap:var(--sp-1);padding:var(--sp-4)var(--sp-5);background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--r-lg);color:var(--clr-text);min-width:140px;max-width:260px;transition:border-color var(--t-fast),box-shadow var(--t-fast);flex-direction:column;flex:1;text-decoration:none;display:flex}.lesson-nav__link:hover{border-color:var(--clr-primary);box-shadow:var(--shadow-sm);opacity:1}.lesson-nav__label{font-size:var(--text-xs);letter-spacing:.07em;text-transform:uppercase;color:var(--clr-text-subtle);font-weight:700}.lesson-nav__title{font-size:var(--text-base);color:var(--clr-primary);font-weight:700}.lesson-nav__link--next{text-align:right;margin-left:auto}.lesson-content table{border-collapse:collapse;width:100%;margin:var(--sp-6)0;font-size:var(--text-sm);border:1px solid var(--clr-border);border-radius:var(--r-md);overflow:hidden}.lesson-content th{padding:var(--sp-3)var(--sp-4);background:var(--clr-bg-alt);text-align:left;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--clr-text-muted);border-bottom:1px solid var(--clr-border);font-weight:700}.lesson-content td{padding:var(--sp-3)var(--sp-4);border-bottom:1px solid var(--clr-border)}.lesson-content tr:last-child td{border-bottom:none}.comparison-grid{gap:var(--sp-4);margin:var(--sp-6)0;grid-template-columns:1fr 1fr;display:grid}@media (max-width:580px){.comparison-grid{grid-template-columns:1fr}}.comparison-col{padding:var(--sp-5);border-radius:var(--r-lg);border:1px solid var(--clr-border)}.comparison-col--bad{background:#fff1f2;border-color:#fecdd3}.comparison-col--good{background:var(--clr-success-bg);border-color:#bbf7d0}[data-theme=dark] .comparison-col--bad{background:#200909;border-color:#541c1c}[data-theme=dark] .comparison-col--good{background:#08160d;border-color:#194328}.comparison-col__label{font-size:var(--text-xs);letter-spacing:.08em;text-transform:uppercase;margin-bottom:var(--sp-3);font-weight:700;display:block}.comparison-col--bad .comparison-col__label{color:#be123c}.comparison-col--good .comparison-col__label{color:var(--clr-success-text)}.pattern-grid{gap:var(--sp-4);margin:var(--sp-6)0;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.pattern-card{padding:var(--sp-5);background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--r-lg)}.pattern-card__num{font-size:var(--text-xs);font-weight:800;font-family:var(--font-mono);color:var(--clr-accent);margin-bottom:var(--sp-2)}.pattern-card__title{font-size:var(--text-base);margin-bottom:var(--sp-2);color:var(--clr-text);font-weight:700}.pattern-card__desc{font-size:var(--text-sm);color:var(--clr-text-muted);line-height:var(--leading-relaxed)}.input-type-grid{gap:var(--sp-3);margin:var(--sp-5)0;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));display:grid}.input-type-card{padding:var(--sp-4);background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--r-lg)}.input-type-card__name{font-size:var(--text-sm);font-weight:700;font-family:var(--font-mono);color:var(--clr-primary);margin-bottom:var(--sp-1)}.input-type-card__desc{font-size:var(--text-xs);color:var(--clr-text-muted)}.checklist{margin:var(--sp-4)0;gap:var(--sp-3);flex-direction:column;padding:0;list-style:none;display:flex}.checklist__item{align-items:flex-start;gap:var(--sp-3);font-size:var(--text-sm);line-height:var(--leading-relaxed);display:flex}.checklist__icon{font-size:var(--text-base);flex-shrink:0;margin-top:1px}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@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-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-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}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{50%{opacity:.5}}@keyframes bounce{0%,to{animation-timing-function:cubic-bezier(.8,0,1,1);transform:translateY(-25%)}50%{animation-timing-function:cubic-bezier(0,0,.2,1);transform:none}}
