@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-border-style:solid;--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}}}@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-black:#000;--spacing:.25rem;--container-4xl:56rem;--text-base:1rem;--text-base--line-height: 1.5 ;--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-5xl:3rem;--text-5xl--line-height:1;--text-7xl:4.5rem;--text-7xl--line-height:1;--font-weight-semibold:600;--font-weight-extrabold:800;--radius-lg:.5rem;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-engineer-dark-gray:#383838;--color-hacker-orange:#e9570e;--color-off-white:#f7f6f6}}@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;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{.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.top-0{top:calc(var(--spacing)*0)}.top-full{top:100%}.right-0{right:calc(var(--spacing)*0)}.left-0{left:calc(var(--spacing)*0)}.isolate{isolation:isolate}.z-50{z-index:50}.prose{color:var(--tw-prose-body);max-width:65ch}.prose :where(p):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.25em;margin-bottom:1.25em}.prose :where([class~=lead]):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-lead);margin-top:1.2em;margin-bottom:1.2em;font-size:1.25em;line-height:1.6}.prose :where(a):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-links);font-weight:500;text-decoration:underline}.prose :where(strong):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-bold);font-weight:600}.prose :where(a strong):not(:where([class~=not-prose],[class~=not-prose] *)),.prose :where(blockquote strong):not(:where([class~=not-prose],[class~=not-prose] *)),.prose :where(thead th strong):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit}.prose :where(ol):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.25em;margin-bottom:1.25em;padding-inline-start:1.625em;list-style-type:decimal}.prose :where(ol[type=A]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:upper-alpha}.prose :where(ol[type=a]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:lower-alpha}.prose :where(ol[type=A s]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:upper-alpha}.prose :where(ol[type=a s]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:lower-alpha}.prose :where(ol[type=I]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:upper-roman}.prose :where(ol[type=i]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:lower-roman}.prose :where(ol[type=I s]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:upper-roman}.prose :where(ol[type=i s]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:lower-roman}.prose :where(ol[type="1"]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:decimal}.prose :where(ul):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.25em;margin-bottom:1.25em;padding-inline-start:1.625em;list-style-type:disc}.prose :where(ol>li):not(:where([class~=not-prose],[class~=not-prose] *))::marker{color:var(--tw-prose-counters);font-weight:400}.prose :where(ul>li):not(:where([class~=not-prose],[class~=not-prose] *))::marker{color:var(--tw-prose-bullets)}.prose :where(dt):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-headings);margin-top:1.25em;font-weight:600}.prose :where(hr):not(:where([class~=not-prose],[class~=not-prose] *)){border-color:var(--tw-prose-hr);border-top-width:1px;margin-top:3em;margin-bottom:3em}.prose :where(blockquote):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-quotes);border-inline-start-width:.25rem;border-inline-start-color:var(--tw-prose-quote-borders);quotes:"“""”""‘""’";margin-top:1.6em;margin-bottom:1.6em;padding-inline-start:1em;font-style:italic;font-weight:500}.prose :where(blockquote p:first-of-type):not(:where([class~=not-prose],[class~=not-prose] *)):before{content:open-quote}.prose :where(blockquote p:last-of-type):not(:where([class~=not-prose],[class~=not-prose] *)):after{content:close-quote}.prose :where(h1):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-headings);margin-top:0;margin-bottom:.888889em;font-size:2.25em;font-weight:800;line-height:1.11111}.prose :where(h1 strong):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit;font-weight:900}.prose :where(h2):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-headings);margin-top:2em;margin-bottom:1em;font-size:1.5em;font-weight:700;line-height:1.33333}.prose :where(h2 strong):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit;font-weight:800}.prose :where(h3):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-headings);margin-top:1.6em;margin-bottom:.6em;font-size:1.25em;font-weight:600;line-height:1.6}.prose :where(h3 strong):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit;font-weight:700}.prose :where(h4):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-headings);margin-top:1.5em;margin-bottom:.5em;font-weight:600;line-height:1.5}.prose :where(h4 strong):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit;font-weight:700}.prose :where(img):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:2em;margin-bottom:2em}.prose :where(picture):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:2em;margin-bottom:2em;display:block}.prose :where(video):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:2em;margin-bottom:2em}.prose :where(kbd):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-kbd);box-shadow:0 0 0 1px var(--tw-prose-kbd-shadows),0 3px 0 var(--tw-prose-kbd-shadows);padding-top:.1875em;padding-inline-end:.375em;padding-bottom:.1875em;border-radius:.3125rem;padding-inline-start:.375em;font-family:inherit;font-size:.875em;font-weight:500}.prose :where(code):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-code);font-size:.875em;font-weight:600}.prose :where(code):not(:where([class~=not-prose],[class~=not-prose] *)):before,.prose :where(code):not(:where([class~=not-prose],[class~=not-prose] *)):after{content:"`"}.prose :where(a code):not(:where([class~=not-prose],[class~=not-prose] *)),.prose :where(h1 code):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit}.prose :where(h2 code):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit;font-size:.875em}.prose :where(h3 code):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit;font-size:.9em}.prose :where(h4 code):not(:where([class~=not-prose],[class~=not-prose] *)),.prose :where(blockquote code):not(:where([class~=not-prose],[class~=not-prose] *)),.prose :where(thead th code):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit}.prose :where(pre):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-pre-code);background-color:var(--tw-prose-pre-bg);padding-top:.857143em;padding-inline-end:1.14286em;padding-bottom:.857143em;border-radius:.375rem;margin-top:1.71429em;margin-bottom:1.71429em;padding-inline-start:1.14286em;font-size:.875em;font-weight:400;line-height:1.71429;overflow-x:auto}.prose :where(pre code):not(:where([class~=not-prose],[class~=not-prose] *)){font-weight:inherit;color:inherit;font-size:inherit;font-family:inherit;line-height:inherit;background-color:#0000;border-width:0;border-radius:0;padding:0}.prose :where(pre code):not(:where([class~=not-prose],[class~=not-prose] *)):before,.prose :where(pre code):not(:where([class~=not-prose],[class~=not-prose] *)):after{content:none}.prose :where(table):not(:where([class~=not-prose],[class~=not-prose] *)){table-layout:auto;width:100%;margin-top:2em;margin-bottom:2em;font-size:.875em;line-height:1.71429}.prose :where(thead):not(:where([class~=not-prose],[class~=not-prose] *)){border-bottom-width:1px;border-bottom-color:var(--tw-prose-th-borders)}.prose :where(thead th):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-headings);vertical-align:bottom;padding-inline-end:.571429em;padding-bottom:.571429em;padding-inline-start:.571429em;font-weight:600}.prose :where(tbody tr):not(:where([class~=not-prose],[class~=not-prose] *)){border-bottom-width:1px;border-bottom-color:var(--tw-prose-td-borders)}.prose :where(tbody tr:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){border-bottom-width:0}.prose :where(tbody td):not(:where([class~=not-prose],[class~=not-prose] *)){vertical-align:baseline}.prose :where(tfoot):not(:where([class~=not-prose],[class~=not-prose] *)){border-top-width:1px;border-top-color:var(--tw-prose-th-borders)}.prose :where(tfoot td):not(:where([class~=not-prose],[class~=not-prose] *)){vertical-align:top}.prose :where(th,td):not(:where([class~=not-prose],[class~=not-prose] *)){text-align:start}.prose :where(figure>*):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0;margin-bottom:0}.prose :where(figcaption):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-captions);margin-top:.857143em;font-size:.875em;line-height:1.42857}.prose{--tw-prose-body:oklch(37.3% .034 259.733);--tw-prose-headings:oklch(21% .034 264.665);--tw-prose-lead:oklch(44.6% .03 256.802);--tw-prose-links:oklch(21% .034 264.665);--tw-prose-bold:oklch(21% .034 264.665);--tw-prose-counters:oklch(55.1% .027 264.364);--tw-prose-bullets:oklch(87.2% .01 258.338);--tw-prose-hr:oklch(92.8% .006 264.531);--tw-prose-quotes:oklch(21% .034 264.665);--tw-prose-quote-borders:oklch(92.8% .006 264.531);--tw-prose-captions:oklch(55.1% .027 264.364);--tw-prose-kbd:oklch(21% .034 264.665);--tw-prose-kbd-shadows:oklab(21% -.00316127 -.0338527/.1);--tw-prose-code:oklch(21% .034 264.665);--tw-prose-pre-code:oklch(92.8% .006 264.531);--tw-prose-pre-bg:oklch(27.8% .033 256.848);--tw-prose-th-borders:oklch(87.2% .01 258.338);--tw-prose-td-borders:oklch(92.8% .006 264.531);--tw-prose-invert-body:oklch(87.2% .01 258.338);--tw-prose-invert-headings:#fff;--tw-prose-invert-lead:oklch(70.7% .022 261.325);--tw-prose-invert-links:#fff;--tw-prose-invert-bold:#fff;--tw-prose-invert-counters:oklch(70.7% .022 261.325);--tw-prose-invert-bullets:oklch(44.6% .03 256.802);--tw-prose-invert-hr:oklch(37.3% .034 259.733);--tw-prose-invert-quotes:oklch(96.7% .003 264.542);--tw-prose-invert-quote-borders:oklch(37.3% .034 259.733);--tw-prose-invert-captions:oklch(70.7% .022 261.325);--tw-prose-invert-kbd:#fff;--tw-prose-invert-kbd-shadows:#ffffff1a;--tw-prose-invert-code:#fff;--tw-prose-invert-pre-code:oklch(87.2% .01 258.338);--tw-prose-invert-pre-bg:#00000080;--tw-prose-invert-th-borders:oklch(44.6% .03 256.802);--tw-prose-invert-td-borders:oklch(37.3% .034 259.733);font-size:1rem;line-height:1.75}.prose :where(picture>img):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0;margin-bottom:0}.prose :where(li):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.5em;margin-bottom:.5em}.prose :where(ol>li):not(:where([class~=not-prose],[class~=not-prose] *)),.prose :where(ul>li):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-start:.375em}.prose :where(.prose>ul>li p):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.75em;margin-bottom:.75em}.prose :where(.prose>ul>li>p:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.25em}.prose :where(.prose>ul>li>p:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-bottom:1.25em}.prose :where(.prose>ol>li>p:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.25em}.prose :where(.prose>ol>li>p:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-bottom:1.25em}.prose :where(ul ul,ul ol,ol ul,ol ol):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.75em;margin-bottom:.75em}.prose :where(dl):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.25em;margin-bottom:1.25em}.prose :where(dd):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.5em;padding-inline-start:1.625em}.prose :where(hr+*):not(:where([class~=not-prose],[class~=not-prose] *)),.prose :where(h2+*):not(:where([class~=not-prose],[class~=not-prose] *)),.prose :where(h3+*):not(:where([class~=not-prose],[class~=not-prose] *)),.prose :where(h4+*):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0}.prose :where(thead th:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-start:0}.prose :where(thead th:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-end:0}.prose :where(tbody td,tfoot td):not(:where([class~=not-prose],[class~=not-prose] *)){padding-top:.571429em;padding-inline-end:.571429em;padding-bottom:.571429em;padding-inline-start:.571429em}.prose :where(tbody td:first-child,tfoot td:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-start:0}.prose :where(tbody td:last-child,tfoot td:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-end:0}.prose :where(figure):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:2em;margin-bottom:2em}.prose :where(.prose>:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0}.prose :where(.prose>:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-bottom:0}.mt-0\.5{margin-top:calc(var(--spacing)*.5)}.mt-1{margin-top:calc(var(--spacing)*1)}.mt-2{margin-top:calc(var(--spacing)*2)}.mt-\[25vh\]{margin-top:25vh}.mr-2{margin-right:calc(var(--spacing)*2)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-5{margin-bottom:calc(var(--spacing)*5)}.mb-10{margin-bottom:calc(var(--spacing)*10)}.ml-1{margin-left:calc(var(--spacing)*1)}.ml-\[-5px\]{margin-left:-5px}.block{display:block}.contents{display:contents}.flex{display:flex}.h-0\.5{height:calc(var(--spacing)*.5)}.h-\[50px\]{height:50px}.min-h-screen{min-height:100vh}.w-\[10ch\]{width:10ch}.w-\[200px\]{width:200px}.w-fit{width:fit-content}.max-w-4xl{max-width:var(--container-4xl)}.max-w-\[50ch\]{max-width:50ch}.max-w-\[80ch\]{max-width:80ch}.min-w-\[220px\]{min-width:220px}.min-w-screen{min-width:100vw}.cursor-pointer{cursor:pointer}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:calc(var(--spacing)*1)}.gap-2{gap:calc(var(--spacing)*2)}.gap-4{gap:calc(var(--spacing)*4)}.gap-5{gap:calc(var(--spacing)*5)}.overflow-x-auto{overflow-x:auto}.overflow-x-hidden{overflow-x:hidden}.rounded{border-radius:.25rem}.rounded-lg{border-radius:var(--radius-lg)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.border-dotted{--tw-border-style:dotted;border-style:dotted}.border-none{--tw-border-style:none;border-style:none}.border-hacker-orange{border-color:var(--color-hacker-orange)}.border-b-transparent{border-bottom-color:#0000}.bg-off-white{background-color:var(--color-off-white)}.bg-transparent{background-color:#0000}.p-0{padding:calc(var(--spacing)*0)}.p-2\.5{padding:calc(var(--spacing)*2.5)}.px-5{padding-inline:calc(var(--spacing)*5)}.pt-0\.5{padding-top:calc(var(--spacing)*.5)}.pt-\[50px\]{padding-top:50px}.pl-1{padding-left:calc(var(--spacing)*1)}.pl-2{padding-left:calc(var(--spacing)*2)}.pl-7{padding-left:calc(var(--spacing)*7)}.text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--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-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.font-extrabold{--tw-font-weight:var(--font-weight-extrabold);font-weight:var(--font-weight-extrabold)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-\[5px\]{--tw-tracking:5px;letter-spacing:5px}.whitespace-nowrap{white-space:nowrap}.text-black{color:var(--color-black)}.text-engineer-dark-gray{color:var(--color-engineer-dark-gray)}.text-hacker-orange{color:var(--color-hacker-orange)}.shadow-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a),0 8px 10px -6px 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)}.prose-neutral{--tw-prose-body:oklch(37.1% 0 0);--tw-prose-headings:oklch(20.5% 0 0);--tw-prose-lead:oklch(43.9% 0 0);--tw-prose-links:oklch(20.5% 0 0);--tw-prose-bold:oklch(20.5% 0 0);--tw-prose-counters:oklch(55.6% 0 0);--tw-prose-bullets:oklch(87% 0 0);--tw-prose-hr:oklch(92.2% 0 0);--tw-prose-quotes:oklch(20.5% 0 0);--tw-prose-quote-borders:oklch(92.2% 0 0);--tw-prose-captions:oklch(55.6% 0 0);--tw-prose-kbd:oklch(20.5% 0 0);--tw-prose-kbd-shadows:oklab(20.5% 0 0/.1);--tw-prose-code:oklch(20.5% 0 0);--tw-prose-pre-code:oklch(92.2% 0 0);--tw-prose-pre-bg:oklch(26.9% 0 0);--tw-prose-th-borders:oklch(87% 0 0);--tw-prose-td-borders:oklch(92.2% 0 0);--tw-prose-invert-body:oklch(87% 0 0);--tw-prose-invert-headings:#fff;--tw-prose-invert-lead:oklch(70.8% 0 0);--tw-prose-invert-links:#fff;--tw-prose-invert-bold:#fff;--tw-prose-invert-counters:oklch(70.8% 0 0);--tw-prose-invert-bullets:oklch(43.9% 0 0);--tw-prose-invert-hr:oklch(37.1% 0 0);--tw-prose-invert-quotes:oklch(97% 0 0);--tw-prose-invert-quote-borders:oklch(37.1% 0 0);--tw-prose-invert-captions:oklch(70.8% 0 0);--tw-prose-invert-kbd:#fff;--tw-prose-invert-kbd-shadows:#ffffff1a;--tw-prose-invert-code:#fff;--tw-prose-invert-pre-code:oklch(87% 0 0);--tw-prose-invert-pre-bg:#00000080;--tw-prose-invert-th-borders:oklch(43.9% 0 0);--tw-prose-invert-td-borders:oklch(37.1% 0 0)}.outline-none{--tw-outline-style:none;outline-style:none}@media(hover:hover){.group-hover\:text-hacker-orange:is(:where(.group):hover *){color:var(--color-hacker-orange)}.hover\:cursor-pointer:hover{cursor:pointer}.hover\:border-b-hacker-orange:hover{border-bottom-color:var(--color-hacker-orange)}.hover\:text-hacker-orange:hover{color:var(--color-hacker-orange)}}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}@media(min-width:48rem){.md\:text-7xl{font-size:var(--text-7xl);line-height:var(--tw-leading,var(--text-7xl--line-height))}}}body{background-color:var(--color-off-white)}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@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}.proj-bitmasking{--bg: #0d1117;--surface: #161b22;--surface2: #21262d;--border: #30363d;--text: #c9d1d9;--muted: #8b949e;--accent: #58a6ff;--green: #3fb950;--orange: #d29922;--red: #f85149;--purple: #bc8cff;--yellow: #e3b341;--cyan: #79c0ff;--pink: #ff7b72;font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);min-height:calc(100vh - 50px)}.proj-bitmasking *,.proj-bitmasking *:before,.proj-bitmasking *:after{box-sizing:border-box;margin:0;padding:0}.proj-bitmasking .bm-header{background:var(--surface);border-bottom:1px solid var(--border);padding:1.25rem 2rem;display:flex;align-items:center;gap:1rem}.proj-bitmasking .bm-header h1{font-size:1.35rem;font-weight:700;letter-spacing:-.01em}.proj-bitmasking .bm-header h1 span{color:var(--accent)}.proj-bitmasking .bm-header p{font-size:.85rem;color:var(--muted);margin-left:auto}.proj-bitmasking nav.tabs{background:var(--surface);border-bottom:1px solid var(--border);padding:0 2rem;display:flex;gap:0}.proj-bitmasking nav.tabs button{background:none;border:none;border-bottom:2px solid transparent;color:var(--muted);cursor:pointer;font-size:.9rem;padding:.75rem 1.1rem;transition:color .15s,border-color .15s}.proj-bitmasking nav.tabs button:hover{color:var(--text)}.proj-bitmasking nav.tabs button.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.proj-bitmasking .bm-main{max-width:900px;margin:0 auto;padding:2rem}.proj-bitmasking .explorer-controls{display:flex;gap:1rem;align-items:flex-end;flex-wrap:wrap;margin-bottom:1.5rem}.proj-bitmasking .control-group{display:flex;flex-direction:column;gap:.3rem}.proj-bitmasking .control-group label{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.proj-bitmasking .control-group input,.proj-bitmasking .control-group select{background:var(--surface2);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:1rem;font-family:Courier New,monospace;padding:.45rem .75rem;width:120px;outline:none}.proj-bitmasking .control-group input:focus,.proj-bitmasking .control-group select:focus{border-color:var(--accent)}.proj-bitmasking .control-group select{width:180px;cursor:pointer}.proj-bitmasking .bit-board{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:1.25rem 1.5rem;font-family:Courier New,monospace;overflow-x:auto}.proj-bitmasking .bit-row{display:flex;align-items:center;gap:.5rem;margin:.3rem 0}.proj-bitmasking .bit-row-label{width:48px;font-size:.8rem;color:var(--muted);text-align:right;flex-shrink:0}.proj-bitmasking .bit-row-label strong{color:var(--text);font-size:.9rem}.proj-bitmasking .bit-row-meta{font-size:.78rem;color:var(--muted);margin-left:.5rem;white-space:nowrap}.proj-bitmasking .bits{display:flex;gap:3px}.proj-bitmasking .bit-group-sep{width:8px;flex-shrink:0}.proj-bitmasking .bit-cell{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:5px;font-size:1rem;font-weight:700;border:1px solid transparent;transition:background .15s,color .15s;flex-shrink:0}.proj-bitmasking .bit-cell.zero{background:var(--surface2);color:var(--muted);border-color:var(--border)}.proj-bitmasking .bit-cell.one{background:var(--surface2);color:var(--text);border-color:var(--border)}.proj-bitmasking .bit-cell.result-and{background:#1a3a1a;color:var(--green);border-color:var(--green)}.proj-bitmasking .bit-cell.result-or{background:#3a2e0a;color:var(--yellow);border-color:var(--yellow)}.proj-bitmasking .bit-cell.result-xor{background:#2d1a4a;color:var(--purple);border-color:var(--purple)}.proj-bitmasking .bit-cell.result-not{background:#0a2a3a;color:var(--cyan);border-color:var(--cyan)}.proj-bitmasking .bit-cell.result-lshift,.proj-bitmasking .bit-cell.result-rshift{background:#1a2a3a;color:var(--accent);border-color:var(--accent)}.proj-bitmasking .bit-pos-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.proj-bitmasking .bit-pos-row .spacer{width:48px;flex-shrink:0}.proj-bitmasking .bit-pos{width:34px;text-align:center;font-size:.68rem;color:var(--muted);flex-shrink:0}.proj-bitmasking .bit-pos-sep{width:8px;flex-shrink:0}.proj-bitmasking .op-divider{border:none;border-top:1px solid var(--border);margin:.6rem 0}.proj-bitmasking .result-summary{display:flex;gap:1.5rem;margin-top:1rem;flex-wrap:wrap}.proj-bitmasking .result-pill{background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:.3rem .9rem;font-size:.85rem;font-family:Courier New,monospace}.proj-bitmasking .result-pill span{color:var(--muted);font-size:.75rem;margin-right:.3rem}.proj-bitmasking .op-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;margin-bottom:1.25rem;overflow:hidden}.proj-bitmasking .op-card-header{padding:1rem 1.5rem;display:flex;align-items:center;gap:1rem;border-bottom:1px solid var(--border)}.proj-bitmasking .op-badge{font-family:Courier New,monospace;font-size:1.3rem;font-weight:900;background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:.15rem .5rem;min-width:48px;text-align:center}.proj-bitmasking .op-card-name{font-size:1rem;font-weight:700}.proj-bitmasking .op-card-desc{font-size:.85rem;color:var(--muted);margin-left:auto;max-width:340px;text-align:right}.proj-bitmasking .op-card-body{padding:1.25rem 1.5rem;display:flex;gap:1.5rem;flex-wrap:wrap}.proj-bitmasking .op-card-body>div{flex:1;min-width:200px}.proj-bitmasking .truth-table{border-collapse:collapse;font-family:Courier New,monospace;font-size:.85rem;width:auto}.proj-bitmasking .truth-table th,.proj-bitmasking .truth-table td{border:1px solid var(--border);padding:.3rem .75rem;text-align:center}.proj-bitmasking .truth-table th{background:var(--surface2);color:var(--muted);font-weight:600}.proj-bitmasking .truth-table .t1{color:var(--green);font-weight:700}.proj-bitmasking .truth-table .t0{color:var(--muted)}.proj-bitmasking .lang-tabs{display:flex;gap:0;margin-bottom:.5rem;overflow-x:auto;flex-wrap:nowrap}.proj-bitmasking .lang-tab{background:var(--surface2);border:1px solid var(--border);color:var(--muted);cursor:pointer;font-size:.75rem;padding:.25rem .5rem;border-right:none;white-space:nowrap}.proj-bitmasking .lang-tab:first-child{border-radius:5px 0 0 5px}.proj-bitmasking .lang-tab:last-child{border-radius:0 5px 5px 0;border-right:1px solid var(--border)}.proj-bitmasking .lang-tab.active{background:var(--surface);color:var(--accent);border-bottom-color:var(--surface)}.proj-bitmasking pre{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:.75rem 1rem;font-size:.82rem;font-family:Courier New,monospace;line-height:1.55;overflow-x:auto;white-space:pre}.proj-bitmasking pre .c{color:var(--muted);font-style:italic}.proj-bitmasking pre .kw{color:var(--accent)}.proj-bitmasking pre .num{color:var(--green)}.proj-bitmasking pre .str{color:var(--yellow)}.proj-bitmasking .use-cases{margin-top:.75rem}.proj-bitmasking .use-cases h4{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.4rem}.proj-bitmasking .use-cases ul{list-style:none;padding:0}.proj-bitmasking .use-cases li{font-size:.83rem;padding:.2rem 0}.proj-bitmasking .use-cases li:before{content:"▸ ";color:var(--accent)}.proj-bitmasking .note{background:#1a2a1a;border-left:3px solid var(--green);border-radius:0 4px 4px 0;font-size:.82rem;padding:.6rem .8rem;margin-top:.6rem;line-height:1.5}.proj-bitmasking .note.warn{background:#2a1a0a;border-left-color:var(--orange)}.proj-bitmasking .pattern-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:1.25rem 1.5rem;margin-bottom:1rem}.proj-bitmasking .pattern-card h3{font-size:.95rem;font-weight:700;margin-bottom:.3rem;display:flex;align-items:center;gap:.5rem}.proj-bitmasking .pattern-num{background:var(--accent);color:#000;border-radius:50%;width:20px;height:20px;font-size:.7rem;font-weight:900;display:flex;align-items:center;justify-content:center;flex-shrink:0}.proj-bitmasking .pattern-card p{font-size:.85rem;color:var(--muted);margin-bottom:.75rem;line-height:1.5}.proj-bitmasking .pattern-card .how{font-size:.82rem;color:var(--text);background:var(--surface2);border-left:3px solid var(--accent);padding:.5rem .75rem;border-radius:0 4px 4px 0;margin-top:.6rem;line-height:1.55}.proj-bitmasking .quiz-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.proj-bitmasking .quiz-score{font-size:.9rem;color:var(--muted)}.proj-bitmasking .quiz-score strong{color:var(--green);font-size:1.1rem}.proj-bitmasking .quiz-progress{height:4px;background:var(--surface2);border-radius:2px;margin-bottom:1.5rem;overflow:hidden}.proj-bitmasking .quiz-progress-bar{height:100%;background:var(--accent);border-radius:2px;transition:width .3s}.proj-bitmasking .question-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:1.5rem}.proj-bitmasking .question-type{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:.4rem}.proj-bitmasking .question-text{font-size:1.05rem;font-weight:600;margin-bottom:1.25rem;line-height:1.5}.proj-bitmasking .question-code{font-family:Courier New,monospace;background:var(--surface2);border:1px solid var(--border);border-radius:5px;padding:.6rem .9rem;font-size:.95rem;margin-bottom:1.25rem}.proj-bitmasking .options{display:flex;flex-direction:column;gap:.55rem}.proj-bitmasking .option-btn{background:var(--surface2);border:1px solid var(--border);border-radius:7px;color:var(--text);cursor:pointer;display:flex;align-items:center;gap:.75rem;font-size:.9rem;font-family:Courier New,monospace;padding:.75rem 1rem;text-align:left;transition:border-color .15s,background .15s}.proj-bitmasking .option-btn:hover:not(:disabled){border-color:var(--accent);background:#0d2040}.proj-bitmasking .option-btn .option-letter{background:var(--border);border-radius:4px;color:var(--muted);font-size:.72rem;font-weight:700;padding:.1rem .4rem;flex-shrink:0}.proj-bitmasking .option-btn.correct{background:#0d2a10;border-color:var(--green);color:var(--green)}.proj-bitmasking .option-btn.correct .option-letter{background:var(--green);color:#000}.proj-bitmasking .option-btn.wrong{background:#2a0d0d;border-color:var(--red);color:var(--red)}.proj-bitmasking .option-btn.wrong .option-letter{background:var(--red);color:#fff}.proj-bitmasking .option-btn:disabled{cursor:default}.proj-bitmasking .quiz-explanation{margin-top:1rem;background:var(--surface2);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:0 6px 6px 0;padding:.75rem 1rem;font-size:.85rem;line-height:1.6}.proj-bitmasking .quiz-actions{display:flex;justify-content:space-between;align-items:center;margin-top:1.25rem}.proj-bitmasking .btn{background:var(--accent);border:none;border-radius:7px;color:#000;cursor:pointer;font-size:.9rem;font-weight:700;padding:.6rem 1.4rem;transition:opacity .15s}.proj-bitmasking .btn:hover{opacity:.85}.proj-bitmasking .btn:disabled{opacity:.4;cursor:default}.proj-bitmasking .quiz-complete{text-align:center;padding:2.5rem 1rem}.proj-bitmasking .quiz-complete .big-score{font-size:3rem;font-weight:900;color:var(--green)}.proj-bitmasking .quiz-complete p{color:var(--muted);margin-top:.5rem;margin-bottom:1.5rem}.proj-bitmasking .section-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:1rem}@media(max-width:600px){.proj-bitmasking .bm-main{padding:1rem}.proj-bitmasking .bm-header{flex-direction:column;align-items:flex-start;gap:.3rem}.proj-bitmasking .bm-header p{margin-left:0}.proj-bitmasking nav.tabs{overflow-x:auto}.proj-bitmasking .explorer-controls{gap:.75rem}.proj-bitmasking .control-group input,.proj-bitmasking .control-group select{width:100%}.proj-bitmasking .op-card-body{flex-direction:column}.proj-bitmasking .op-card-desc{max-width:none;text-align:left}}
