*,:before,:after,::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border:0 solid #e5e7eb}:before,:after{--tw-content:""}html,:host{-webkit-text-size-adjust:100%;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;line-height:1.5}body{line-height:inherit;margin:0}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:#0000;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{margin:0;padding:0;list-style:none}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.pointer-events-none{pointer-events:none}.\!visible{visibility:visible!important}.visible{visibility:visible}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.-bottom-1{bottom:-.25rem}.-right-1{right:-.25rem}.-top-1{top:-.25rem}.-top-3{top:-.75rem}.left-0{left:0}.left-1\/2{left:50%}.left-3{left:.75rem}.right-0{right:0}.right-3{right:.75rem}.top-1\/2{top:50%}.top-3{top:.75rem}.top-full{top:100%}.z-10{z-index:10}.my-3{margin-top:.75rem;margin-bottom:.75rem}.my-4{margin-top:1rem;margin-bottom:1rem}.-mb-px{margin-bottom:-1px}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.ml-1{margin-left:.25rem}.ml-5{margin-left:1.25rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.h-1\.5{height:.375rem}.h-12{height:3rem}.h-2{height:.5rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-44{height:11rem}.h-5{height:1.25rem}.h-7{height:1.75rem}.h-8{height:2rem}.h-full{height:100%}.max-h-\[520px\]{max-height:520px}.max-h-\[640px\]{max-height:640px}.min-h-\[1\.25rem\]{min-height:1.25rem}.min-h-\[320px\]{min-height:320px}.min-h-\[3rem\]{min-height:3rem}.w-12{width:3rem}.w-2{width:.5rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-7{width:1.75rem}.w-full{width:100%}.min-w-0{min-width:0}.max-w-2xl{max-width:42rem}.max-w-md{max-width:28rem}.max-w-sm{max-width:24rem}.flex-1{flex:1}.shrink-0{flex-shrink:0}.border-collapse{border-collapse:collapse}.-translate-x-1\/2{--tw-translate-x:-50%;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-y-1\/2{--tw-translate-y:-50%;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rotate-45{--tw-rotate:45deg;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-crosshair{cursor:crosshair}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.touch-none{touch-action:none}.select-none{-webkit-user-select:none;user-select:none}.list-decimal{list-style-type:decimal}.list-disc{list-style-type:disc}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-visible{overflow:visible}.overflow-x-auto{overflow-x:auto}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.rounded-t{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-t{border-top-width:1px}.border-amber-300{--tw-border-opacity:1;border-color:rgb(252 211 77/var(--tw-border-opacity,1))}.border-blue-600{--tw-border-opacity:1;border-color:rgb(37 99 235/var(--tw-border-opacity,1))}.border-rose-300{--tw-border-opacity:1;border-color:rgb(253 164 175/var(--tw-border-opacity,1))}.border-slate-200{--tw-border-opacity:1;border-color:rgb(226 232 240/var(--tw-border-opacity,1))}.border-slate-300{--tw-border-opacity:1;border-color:rgb(203 213 225/var(--tw-border-opacity,1))}.border-slate-900{--tw-border-opacity:1;border-color:rgb(15 23 42/var(--tw-border-opacity,1))}.border-transparent{border-color:#0000}.border-white{--tw-border-opacity:1;border-color:rgb(255 255 255/var(--tw-border-opacity,1))}.border-yellow-200{--tw-border-opacity:1;border-color:rgb(254 240 138/var(--tw-border-opacity,1))}.bg-amber-400{--tw-bg-opacity:1;background-color:rgb(251 191 36/var(--tw-bg-opacity,1))}.bg-amber-50{--tw-bg-opacity:1;background-color:rgb(255 251 235/var(--tw-bg-opacity,1))}.bg-amber-500{--tw-bg-opacity:1;background-color:rgb(245 158 11/var(--tw-bg-opacity,1))}.bg-blue-600{--tw-bg-opacity:1;background-color:rgb(37 99 235/var(--tw-bg-opacity,1))}.bg-fuchsia-50\/60{background-color:#fdf4ff99}.bg-rose-50{--tw-bg-opacity:1;background-color:rgb(255 241 242/var(--tw-bg-opacity,1))}.bg-rose-500{--tw-bg-opacity:1;background-color:rgb(244 63 94/var(--tw-bg-opacity,1))}.bg-rose-600{--tw-bg-opacity:1;background-color:rgb(225 29 72/var(--tw-bg-opacity,1))}.bg-sky-50\/60{background-color:#f0f9ff99}.bg-slate-100{--tw-bg-opacity:1;background-color:rgb(241 245 249/var(--tw-bg-opacity,1))}.bg-slate-50{--tw-bg-opacity:1;background-color:rgb(248 250 252/var(--tw-bg-opacity,1))}.bg-slate-800{--tw-bg-opacity:1;background-color:rgb(30 41 59/var(--tw-bg-opacity,1))}.bg-slate-900{--tw-bg-opacity:1;background-color:rgb(15 23 42/var(--tw-bg-opacity,1))}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-white\/80{background-color:#fffc}.bg-yellow-50{--tw-bg-opacity:1;background-color:rgb(254 252 232/var(--tw-bg-opacity,1))}.stroke-amber-300{stroke:#fcd34d}.stroke-rose-400{stroke:#fb7185}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.pl-9{padding-left:2.25rem}.pr-3{padding-right:.75rem}.text-left{text-align:left}.text-center{text-align:center}.align-top{vertical-align:top}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-\[0\.85em\]{font-size:.85em}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.leading-relaxed{line-height:1.625}.tracking-wide{letter-spacing:.025em}.text-amber-500{--tw-text-opacity:1;color:rgb(245 158 11/var(--tw-text-opacity,1))}.text-amber-600{--tw-text-opacity:1;color:rgb(217 119 6/var(--tw-text-opacity,1))}.text-blue-600{--tw-text-opacity:1;color:rgb(37 99 235/var(--tw-text-opacity,1))}.text-emerald-600{--tw-text-opacity:1;color:rgb(5 150 105/var(--tw-text-opacity,1))}.text-fuchsia-500{--tw-text-opacity:1;color:rgb(217 70 239/var(--tw-text-opacity,1))}.text-rose-600{--tw-text-opacity:1;color:rgb(225 29 72/var(--tw-text-opacity,1))}.text-sky-400{--tw-text-opacity:1;color:rgb(56 189 248/var(--tw-text-opacity,1))}.text-sky-500{--tw-text-opacity:1;color:rgb(14 165 233/var(--tw-text-opacity,1))}.text-slate-400{--tw-text-opacity:1;color:rgb(148 163 184/var(--tw-text-opacity,1))}.text-slate-500{--tw-text-opacity:1;color:rgb(100 116 139/var(--tw-text-opacity,1))}.text-slate-600{--tw-text-opacity:1;color:rgb(71 85 105/var(--tw-text-opacity,1))}.text-slate-700{--tw-text-opacity:1;color:rgb(51 65 85/var(--tw-text-opacity,1))}.text-slate-800{--tw-text-opacity:1;color:rgb(30 41 59/var(--tw-text-opacity,1))}.text-slate-900{--tw-text-opacity:1;color:rgb(15 23 42/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.underline{text-decoration-line:underline}.underline-offset-2{text-underline-offset:2px}.shadow{--tw-shadow:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)}.shadow-inner{--tw-shadow:inset 0 2px 4px 0 #0000000d;--tw-shadow-colored:inset 0 2px 4px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 2px 0 #0000000d;--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)}.ring{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow,0 0 #0000)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur{--tw-backdrop-blur:blur(8px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter,backdrop-filter;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-transform{transition-property:transform;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.shiki-block .shiki,.shiki-block .shiki span{color:var(--shiki-light);background-color:var(--shiki-light-bg);font-style:var(--shiki-light-font-style);font-weight:var(--shiki-light-font-weight);-webkit-text-decoration:var(--shiki-light-text-decoration);-webkit-text-decoration:var(--shiki-light-text-decoration);text-decoration:var(--shiki-light-text-decoration)}.dark .shiki-block .shiki,.dark .shiki-block .shiki span{color:var(--shiki-dark);background-color:var(--shiki-dark-bg);font-style:var(--shiki-dark-font-style);font-weight:var(--shiki-dark-font-weight);-webkit-text-decoration:var(--shiki-dark-text-decoration);-webkit-text-decoration:var(--shiki-dark-text-decoration);text-decoration:var(--shiki-dark-text-decoration)}.shiki-block pre.shiki{margin:0;padding:1rem;font-size:.85rem;line-height:1.55}@keyframes procrastinator-wiggle-slow{0%,88%,to{transform:translate(0)}91%{transform:translate(-1.5px)}94%{transform:translate(1.5px)}97%{transform:translate(-1px)}}@keyframes procrastinator-wiggle-fast{0%,70%,to{transform:translate(0)}76%{transform:translate(-2px)}82%{transform:translate(2px)}88%{transform:translate(-1.5px)}}@keyframes procrastinator-shake{0%,to{transform:translate(0)}20%{transform:translate(-1px,.5px)}40%{transform:translate(1px,-.5px)}60%{transform:translate(-.5px,1px)}80%{transform:translate(.5px,-1px)}}.procrastinator-stale{animation:5s ease-in-out infinite procrastinator-wiggle-slow}.procrastinator-annoyed{animation:2.5s ease-in-out infinite procrastinator-wiggle-fast}.procrastinator-furious{animation:.6s linear infinite procrastinator-shake}@media (prefers-reduced-motion:reduce){.procrastinator-stale,.procrastinator-annoyed,.procrastinator-furious{animation:none}}.hover\:scale-110:hover{--tw-scale-x:1.1;--tw-scale-y:1.1;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:bg-amber-600:hover{--tw-bg-opacity:1;background-color:rgb(217 119 6/var(--tw-bg-opacity,1))}.hover\:bg-blue-700:hover{--tw-bg-opacity:1;background-color:rgb(29 78 216/var(--tw-bg-opacity,1))}.hover\:bg-rose-700:hover{--tw-bg-opacity:1;background-color:rgb(190 18 60/var(--tw-bg-opacity,1))}.hover\:bg-slate-100:hover{--tw-bg-opacity:1;background-color:rgb(241 245 249/var(--tw-bg-opacity,1))}.hover\:bg-slate-50:hover{--tw-bg-opacity:1;background-color:rgb(248 250 252/var(--tw-bg-opacity,1))}.hover\:bg-slate-800:hover{--tw-bg-opacity:1;background-color:rgb(30 41 59/var(--tw-bg-opacity,1))}.hover\:bg-white:hover{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.hover\:text-slate-800:hover{--tw-text-opacity:1;color:rgb(30 41 59/var(--tw-text-opacity,1))}.hover\:no-underline:hover{text-decoration-line:none}.focus\:outline-none:focus{outline-offset:2px;outline:2px solid #0000}.focus\:ring-2:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow,0 0 #0000)}.focus\:ring-blue-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(59 130 246/var(--tw-ring-opacity,1))}.focus-visible\:ring-2:focus-visible{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow,0 0 #0000)}.focus-visible\:ring-blue-500:focus-visible{--tw-ring-opacity:1;--tw-ring-color:rgb(59 130 246/var(--tw-ring-opacity,1))}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:bg-slate-200:disabled{--tw-bg-opacity:1;background-color:rgb(226 232 240/var(--tw-bg-opacity,1))}.disabled\:text-slate-400:disabled{--tw-text-opacity:1;color:rgb(148 163 184/var(--tw-text-opacity,1))}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:opacity-60:disabled{opacity:.6}.dark\:border-amber-700:is(.dark *){--tw-border-opacity:1;border-color:rgb(180 83 9/var(--tw-border-opacity,1))}.dark\:border-rose-700:is(.dark *){--tw-border-opacity:1;border-color:rgb(190 18 60/var(--tw-border-opacity,1))}.dark\:border-slate-100:is(.dark *){--tw-border-opacity:1;border-color:rgb(241 245 249/var(--tw-border-opacity,1))}.dark\:border-slate-600:is(.dark *){--tw-border-opacity:1;border-color:rgb(71 85 105/var(--tw-border-opacity,1))}.dark\:border-slate-700:is(.dark *){--tw-border-opacity:1;border-color:rgb(51 65 85/var(--tw-border-opacity,1))}.dark\:border-slate-800:is(.dark *){--tw-border-opacity:1;border-color:rgb(30 41 59/var(--tw-border-opacity,1))}.dark\:border-yellow-800:is(.dark *){--tw-border-opacity:1;border-color:rgb(133 77 14/var(--tw-border-opacity,1))}.dark\:bg-amber-900\/30:is(.dark *){background-color:#78350f4d}.dark\:bg-fuchsia-900\/20:is(.dark *){background-color:#701a7533}.dark\:bg-rose-900\/30:is(.dark *){background-color:#8813374d}.dark\:bg-slate-100:is(.dark *){--tw-bg-opacity:1;background-color:rgb(241 245 249/var(--tw-bg-opacity,1))}.dark\:bg-slate-700:is(.dark *){--tw-bg-opacity:1;background-color:rgb(51 65 85/var(--tw-bg-opacity,1))}.dark\:bg-slate-800:is(.dark *){--tw-bg-opacity:1;background-color:rgb(30 41 59/var(--tw-bg-opacity,1))}.dark\:bg-slate-800\/80:is(.dark *){background-color:#1e293bcc}.dark\:bg-slate-900:is(.dark *){--tw-bg-opacity:1;background-color:rgb(15 23 42/var(--tw-bg-opacity,1))}.dark\:bg-slate-900\/60:is(.dark *){background-color:#0f172a99}.dark\:bg-slate-950:is(.dark *){--tw-bg-opacity:1;background-color:rgb(2 6 23/var(--tw-bg-opacity,1))}.dark\:bg-yellow-900\/20:is(.dark *){background-color:#713f1233}.dark\:text-amber-400:is(.dark *){--tw-text-opacity:1;color:rgb(251 191 36/var(--tw-text-opacity,1))}.dark\:text-blue-400:is(.dark *){--tw-text-opacity:1;color:rgb(96 165 250/var(--tw-text-opacity,1))}.dark\:text-emerald-400:is(.dark *){--tw-text-opacity:1;color:rgb(52 211 153/var(--tw-text-opacity,1))}.dark\:text-rose-400:is(.dark *){--tw-text-opacity:1;color:rgb(251 113 133/var(--tw-text-opacity,1))}.dark\:text-slate-100:is(.dark *){--tw-text-opacity:1;color:rgb(241 245 249/var(--tw-text-opacity,1))}.dark\:text-slate-200:is(.dark *){--tw-text-opacity:1;color:rgb(226 232 240/var(--tw-text-opacity,1))}.dark\:text-slate-300:is(.dark *){--tw-text-opacity:1;color:rgb(203 213 225/var(--tw-text-opacity,1))}.dark\:text-slate-400:is(.dark *){--tw-text-opacity:1;color:rgb(148 163 184/var(--tw-text-opacity,1))}.dark\:text-slate-500:is(.dark *){--tw-text-opacity:1;color:rgb(100 116 139/var(--tw-text-opacity,1))}.dark\:text-slate-900:is(.dark *){--tw-text-opacity:1;color:rgb(15 23 42/var(--tw-text-opacity,1))}.dark\:hover\:bg-slate-700:hover:is(.dark *){--tw-bg-opacity:1;background-color:rgb(51 65 85/var(--tw-bg-opacity,1))}.dark\:hover\:bg-slate-700\/60:hover:is(.dark *){background-color:#33415599}.dark\:hover\:bg-slate-800:hover:is(.dark *){--tw-bg-opacity:1;background-color:rgb(30 41 59/var(--tw-bg-opacity,1))}.dark\:hover\:bg-white:hover:is(.dark *){--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.dark\:hover\:text-slate-200:hover:is(.dark *){--tw-text-opacity:1;color:rgb(226 232 240/var(--tw-text-opacity,1))}.dark\:disabled\:bg-slate-700:disabled:is(.dark *){--tw-bg-opacity:1;background-color:rgb(51 65 85/var(--tw-bg-opacity,1))}.App{text-align:center;color:#2b2f36;background-color:#f1f3f6;min-height:100vh}.reslug-banner{color:#1e293b;background-color:#eef2ff;border-bottom:1px solid #e0e7ff;flex-wrap:wrap;justify-content:center;align-items:center;gap:.75rem;padding:.6rem 1.25rem;font-size:.85rem;display:flex}.reslug-banner-text{text-align:center;flex:auto;margin:0}.reslug-banner-cta{color:#fff;background-color:#3b82f6;border-radius:6px;flex:none;padding:5px 12px;font-size:.8rem;font-weight:600;text-decoration:none;transition:background-color .2s}.reslug-banner-cta:hover{background-color:#2563eb}.reslug-banner-dismiss{color:#475569;cursor:pointer;background:0 0;border:none;border-radius:4px;flex:none;justify-content:center;align-items:center;padding:4px;display:inline-flex}.reslug-banner-dismiss:hover{color:#0f172a;background-color:#0000000f}.reslug-banner-dismiss:focus-visible{outline-offset:1px;outline:2px solid #3b82f6}@media (width<=640px){.reslug-banner{padding:.6rem 1rem}.reslug-banner-text{flex-basis:100%}}.App-logo{pointer-events:none;height:40vmin}@media (prefers-reduced-motion:no-preference){.App-logo{animation:20s linear infinite App-logo-spin}}.App-header{color:#2b2f36;background-color:#fff;border-bottom:1px solid #e5e7eb;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:.9rem 2rem;display:flex;box-shadow:0 1px 2px #00000008}.nav-left{align-items:center;gap:1.5rem;display:flex}.nav-brand{color:#2b2f36;letter-spacing:.5px;font-size:1.1rem;font-weight:700}.nav-link{color:#5b6270;font-size:.9rem;font-weight:500;text-decoration:none;transition:color .2s}.nav-link:hover{color:#2b2f36}.nav-link.is-active{color:#2b2f36;font-weight:600}.nav-brand{text-decoration:none}.nav-right{text-align:right;align-items:center;gap:1rem;display:flex}.nav-text h3{color:#2b2f36;margin:0;font-size:1rem;font-weight:600}.nav-text p{color:#6b7280;margin:2px 0 0;font-size:.8rem}.theme-toggle{color:#2b2f36;cursor:pointer;background-color:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;line-height:1;transition:background-color .2s,border-color .2s,color .2s;display:inline-flex}.theme-toggle:hover{background-color:#eef0f3}.App-link{color:#3b82f6}@keyframes App-logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.component-showcase{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;max-width:1400px;margin:0 auto;padding:2rem;display:grid}@media (width>=768px){.component-showcase{grid-template-columns:repeat(2,1fr)}}.component-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:10px;flex-direction:column;transition:transform .3s,box-shadow .3s;display:flex;overflow:hidden;box-shadow:0 1px 3px #0000000a}.component-card:hover{transform:translateY(-3px);box-shadow:0 6px 18px #00000012}.component-card h2{color:#2b2f36;background-color:#f8fafc;border-bottom:1px solid #e5e7eb;margin:0;padding:1rem 1.25rem;font-size:1.15rem;font-weight:600}.component-demo{background-color:#fff;flex-grow:1;padding:1.5rem}.component-description{background-color:#f8fafc;border-top:1px solid #e5e7eb;padding:.85rem 1.25rem}.component-description p{color:#5b6270;margin:0;font-size:.85rem}.feature-list{text-align:left;margin:10px 0 0;padding-left:20px}.feature-list li{margin-bottom:5px;font-size:14px}.login-container{width:100%;max-width:500px;padding:20px}.login-container h1{color:#2b2f36;margin-bottom:30px}.logout-button{color:#fff;cursor:pointer;background-color:sienna;border:none;border-radius:4px;margin-top:20px;padding:10px 20px;font-size:16px;transition:background-color .3s}.logout-button:hover{background-color:#8b4513}.logout-button:active{transform:translateY(1px)}.progress-demo{width:100%;margin:0 auto}.progress-demo h2{color:#2b2f36;margin-bottom:20px}.theme-selector{flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:20px;display:flex}.theme-button{color:#2b2f36;cursor:pointer;background-color:#eef0f3;border:1px solid #d8dbe0;border-radius:6px;padding:8px 15px;font-size:.85rem;transition:all .2s}.theme-button:hover{background-color:#e3e6ea}.theme-button.active{color:#fff;background-color:#3b82f6;border-color:#3b82f6;font-weight:600}.confetti-toggle{color:#5b6270;margin-bottom:20px;font-size:.9rem}.confetti-toggle input{margin-right:8px}.progress-controls{justify-content:center;gap:10px;margin-top:20px;display:flex}.progress-controls button{color:#fff;cursor:pointer;background-color:#3b82f6;border:none;border-radius:6px;padding:8px 15px;font-size:.85rem;font-weight:600;transition:all .2s}.progress-controls button:hover:not(:disabled){background-color:#2563eb}.progress-controls button:disabled{color:#9ca3af;cursor:not-allowed;background-color:#e3e6ea}.showcase-controls{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;max-width:1400px;margin:1.25rem auto 0;padding:0 2rem;display:flex}.category-chips{flex-wrap:wrap;gap:.5rem;display:flex}.category-chip{color:#4b5563;cursor:pointer;background-color:#fff;border:1px solid #e5e7eb;border-radius:999px;padding:5px 12px;font-size:.8rem;font-weight:500;transition:background-color .2s,color .2s,border-color .2s}.category-chip:hover{color:#111827;background-color:#f3f4f6}.category-chip.is-active{color:#fff;background-color:#111827;border-color:#111827}.search-wrap{flex:0 280px;min-width:200px}.showcase-search{color:#2b2f36;background-color:#fff;border:1px solid #e5e7eb;border-radius:8px;width:100%;padding:7px 12px;font-size:.85rem;transition:border-color .2s,box-shadow .2s}.showcase-search:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f626}.showcase-empty{text-align:center;color:#6b7280;max-width:1400px;margin:2rem auto;padding:2rem;font-size:.95rem}.page-section{padding:2.5rem 2rem 1rem}.page-section-inner{text-align:left;max-width:1400px;margin:0 auto}.page-section-header{margin-bottom:1.25rem}.page-section-header h2{color:#111827;margin:0;font-size:1.6rem;font-weight:700}.page-section-header p{color:#6b7280;margin:.25rem 0 0;font-size:.9rem}.page-section-grid{grid-template-columns:1fr;gap:1rem;display:grid}@media (width>=768px){.page-section-grid{grid-template-columns:repeat(2,1fr)}}.page-section-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:1.1rem 1.25rem;box-shadow:0 1px 3px #00000008}.page-section-card h3{color:#111827;margin:0 0 .5rem;font-size:1rem;font-weight:600}.page-section-card p,.page-section-card ul,.page-section-card ol{color:#4b5563;margin:.5rem 0;font-size:.875rem;line-height:1.55}.page-section-card ul,.page-section-card ol{padding-left:1.25rem}.page-section-card li{margin-bottom:.2rem}.page-section-card code{color:#0f172a;background-color:#f1f5f9;border-radius:4px;padding:1px 5px;font-size:.8em}.page-section-card pre{color:#e2e8f0;background-color:#0f172a;border-radius:6px;margin:.5rem 0 0;padding:.6rem .8rem;font-size:.78rem;line-height:1.5;overflow-x:auto}.page-section-card pre code{color:inherit;font-size:inherit;background:0 0;padding:0}.page-section-card kbd{color:#1f2937;background-color:#f9fafb;border:1px solid #d1d5db;border-bottom-width:2px;border-radius:4px;padding:0 5px;font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace;font-size:.75em;display:inline-block}.page-section-prose{max-width:720px}.page-section-prose h3{color:#111827;margin:1.75rem 0 .5rem;font-size:1rem;font-weight:600}.page-section-prose h3:first-child{margin-top:0}.page-section-prose p,.page-section-prose ul,.page-section-prose ol{color:#4b5563;margin:.5rem 0;font-size:.9rem;line-height:1.65}.page-section-prose ul,.page-section-prose ol{padding-left:1.25rem}.page-section-prose li{margin-bottom:.25rem}.page-section-prose code{color:#0f172a;background-color:#f1f5f9;border-radius:4px;padding:1px 5px;font-size:.85em}.page-section-prose pre{color:#e2e8f0;background-color:#0f172a;border-radius:6px;margin:.75rem 0;padding:.7rem .9rem;font-size:.8rem;line-height:1.5;overflow-x:auto}.page-section-prose pre code{color:inherit;font-size:inherit;background:0 0;padding:0}.page-section-prose kbd{color:#1f2937;background-color:#f9fafb;border:1px solid #d1d5db;border-bottom-width:2px;border-radius:4px;padding:0 5px;font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace;font-size:.75em;display:inline-block}.dark .App{color:#e5e7eb;background-color:#0f172a}.dark .App-header{color:#e5e7eb;background-color:#111827;border-bottom-color:#1f2937}.dark .nav-brand,.dark .nav-text h3{color:#f3f4f6}.dark .nav-link{color:#9ca3af}.dark .nav-link:hover,.dark .nav-link.is-active{color:#f3f4f6}.dark .nav-text p{color:#9ca3af}.dark .theme-toggle{color:#f3f4f6;background-color:#1f2937;border-color:#374151}.dark .theme-toggle:hover{background-color:#374151}.dark .component-card{background-color:#111827;border-color:#1f2937;box-shadow:0 1px 3px #0006}.dark .component-card:hover{box-shadow:0 6px 18px #00000080}.dark .component-card h2{color:#f3f4f6;background-color:#0f172a;border-bottom-color:#1f2937}.dark .component-demo{background-color:#111827}.dark .component-description{background-color:#0f172a;border-top-color:#1f2937}.dark .component-description p{color:#9ca3af}.dark .theme-button{color:#f3f4f6;background-color:#1f2937;border-color:#374151}.dark .theme-button:hover{background-color:#374151}.dark .confetti-toggle{color:#9ca3af}.dark .progress-controls button:disabled{color:#4b5563;background-color:#1f2937}.dark .category-chip{color:#d1d5db;background-color:#1f2937;border-color:#374151}.dark .category-chip:hover{color:#f3f4f6;background-color:#374151}.dark .category-chip.is-active{color:#111827;background-color:#f3f4f6;border-color:#f3f4f6}.dark .showcase-search{color:#f3f4f6;background-color:#1f2937;border-color:#374151}.dark .showcase-search:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa40}.dark .showcase-empty{color:#9ca3af}.dark .page-section-header h2,.dark .page-section-card h3{color:#f3f4f6}.dark .page-section-header p{color:#9ca3af}.dark .page-section-card{background-color:#111827;border-color:#1f2937;box-shadow:0 1px 3px #0000004d}.dark .page-section-card p,.dark .page-section-card ul,.dark .page-section-card ol{color:#cbd5e1}.dark .page-section-card code{color:#e5e7eb;background-color:#1f2937}.dark .page-section-card pre{color:#e2e8f0;background-color:#020617}.dark .page-section-card kbd{color:#f3f4f6;background-color:#1f2937;border-color:#374151}.dark .page-section-prose h3{color:#f3f4f6}.dark .page-section-prose p,.dark .page-section-prose ul,.dark .page-section-prose ol{color:#cbd5e1}.dark .page-section-prose code{color:#e5e7eb;background-color:#1f2937}.dark .page-section-prose pre{color:#e2e8f0;background-color:#020617}.dark .page-section-prose kbd{color:#f3f4f6;background-color:#1f2937;border-color:#374151}.dark .reslug-banner{color:#e0e7ff;background-color:#1e293b;border-bottom-color:#334155}.dark .reslug-banner-dismiss{color:#cbd5e1}.dark .reslug-banner-dismiss:hover{color:#fff;background-color:#ffffff14}@media (width<=768px){.App-header{flex-direction:column;align-items:flex-start}.nav-right{text-align:left;justify-content:space-between;width:100%}.theme-selector,.progress-controls{flex-direction:column;align-items:center}.progress-controls button{width:100%;max-width:200px}}.monkey-login-container{box-sizing:border-box;background-color:#fff;border-radius:10px;flex-direction:column;align-items:center;width:100%;max-width:24rem;margin:0 auto;padding:20px;display:flex;box-shadow:0 4px 12px #0000001a}.monkey{perspective:400px;width:100px;height:100px;margin-bottom:12px;position:relative}.monkey-face{justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative}.monkey-ears{justify-content:space-between;width:100%;display:flex;position:absolute;top:0}.ear{background-color:#8b4513;border-radius:50%;width:28px;height:28px}.left-ear{transform:translate(-6px)}.right-ear{transform:translate(6px)}.monkey-head{background-color:sienna;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:82px;height:82px;display:flex;position:relative}.eyes{justify-content:space-between;width:54px;margin-bottom:6px;display:flex}.eye{width:18px;height:18px;transform-style:preserve-3d;background-color:#fff;border-radius:50%;justify-content:center;align-items:flex-end;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 0 5px #0003}.pupil{transform-origin:50%;will-change:transform;background-color:#000;border-radius:50%;width:9px;height:9px;margin-bottom:3px;transition:height .2s,border-radius .2s,margin-bottom .2s;position:relative;box-shadow:0 0 2px 1px #0000004d}.pupil:after{content:"";opacity:.8;background-color:#fff;border-radius:50%;width:3px;height:3px;position:absolute;top:3px;left:3px}.pupil.closed{border-radius:2px;height:2px;margin-bottom:6px;transition:height .2s,border-radius .2s,margin-bottom .2s;transform:translateY(0)!important}.nose{background-color:#8b4513;border-radius:50%;width:14px;height:8px;margin-bottom:3px}.mouth{border-bottom:2px solid #5d4037;border-radius:0 0 50% 50%;width:22px;height:7px}.login-form{width:100%}.form-group{margin-bottom:10px}.form-group label{color:#333;margin-bottom:3px;font-size:13px;font-weight:600;display:block}.form-group input{box-sizing:border-box;border:1px solid #ddd;border-radius:4px;width:100%;padding:7px 9px;font-size:14px;transition:border-color .3s}.form-group input:focus{border-color:sienna;outline:none;box-shadow:0 0 0 2px #a0522d33}.login-button{color:#fff;cursor:pointer;background-color:sienna;border:none;border-radius:4px;width:100%;padding:8px;font-size:14px;font-weight:600;transition:background-color .3s}.login-button:hover{background-color:#8b4513}.login-button:active{transform:translateY(1px)}.dark .monkey-login-container{background-color:#111827;box-shadow:0 4px 12px #0006}.dark .form-group label{color:#e5e7eb}.dark .form-group input{color:#f3f4f6;background-color:#1f2937;border-color:#374151}.dark .form-group input::placeholder{color:#6b7280}.dark .form-group input:focus{border-color:#d97f4a;box-shadow:0 0 0 2px #d97f4a40}.interactive-progress-container{border-radius:10px;margin:20px 0;position:relative;overflow:hidden;box-shadow:0 2px 5px #0000001a}.progress-track{background-color:#f0f0f0;border-radius:10px;width:100%;height:100%;position:relative;overflow:hidden}.progress-fill{background-color:#4caf50;border-radius:10px;height:100%;transition:width .5s ease-out}.progress-text{color:#333;text-shadow:0 0 2px #ffffffb3;z-index:2;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.theme-space .progress-track{background-color:#0a1128;background-image:radial-gradient(#fff,#fff3 2px,#0000 2px),radial-gradient(#fff,#ffffff26 1px,#0000 1px);background-position:0 0,25px 25px;background-size:50px 50px,30px 30px}.theme-space .progress-fill{background:linear-gradient(90deg,#1a237e,#4a148c,#880e4f)}.theme-space .progress-text{color:#fff}.theme-nature .progress-track{background-color:#e8f5e9}.theme-nature .progress-fill{background:linear-gradient(90deg,#81c784,#4caf50,#2e7d32)}.theme-minimal .progress-track{background-color:#f5f5f5}.theme-minimal .progress-fill{background:linear-gradient(90deg,#42a5f5,#2196f3,#1976d2)}.theme-element{z-index:1;font-size:20px;position:absolute;top:50%;transform:translateY(-50%)}.theme-element.rocket{animation:.5s infinite alternate rocketShake}@keyframes rocketShake{0%{transform:translateY(-50%)rotate(-5deg)}to{transform:translateY(-50%)rotate(5deg)}}.theme-element-container{width:100%;height:100%;position:absolute;top:0;left:0}.theme-element.plant{transform-origin:bottom;position:absolute;bottom:0}.confetti-container{pointer-events:none;z-index:10;width:100%;height:100%;position:absolute;top:0;left:0;overflow:hidden}.confetti{border-radius:0;width:10px;height:10px;animation:3s linear forwards confetti-fall;position:absolute;top:-10px}@keyframes confetti-fall{0%{opacity:1;transform:translateY(0)rotate(0)}to{opacity:0;transform:translateY(300px)rotate(720deg)}}.confetti:nth-child(3n){border-radius:50%}.confetti:nth-child(3n+1){width:7px;height:14px}@media (width<=768px){.progress-text{font-size:12px}.theme-element.rocket,.theme-element.plant{font-size:16px}}
