/*! tailwindcss v4.3.1 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-duration:initial}}}@layer theme{:root,:host{--font-sans:"Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono:"JetBrains Mono", "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--leading-relaxed:1.625;--radius-lg:.5rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-text:var(--text-primary);--color-text-secondary:var(--text-secondary);--color-muted:var(--text-muted);--color-subtle:var(--text-subtle);--color-bg:var(--bg);--color-border:var(--border);--color-accent:var(--accent);--color-code:var(--code-bg);--font-hand:"Caveat", "Kalam", cursive}}@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%;-moz-tab-size:4;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]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance: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}.relative{position:relative}.static{position:static}.inset-0{top:0;right:0;bottom:0;left:0}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.-mx-6{margin-inline:calc(var(--spacing) * -6)}.mx-auto{margin-inline:auto}.my-4{margin-block:calc(var(--spacing) * 4)}.my-6{margin-block:calc(var(--spacing) * 6)}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-1{margin-top:var(--spacing)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mb-1{margin-bottom:var(--spacing)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-5{margin-bottom:calc(var(--spacing) * 5)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.mb-8{margin-bottom:calc(var(--spacing) * 8)}.mb-10{margin-bottom:calc(var(--spacing) * 10)}.mb-12{margin-bottom:calc(var(--spacing) * 12)}.mb-14{margin-bottom:calc(var(--spacing) * 14)}.mb-16{margin-bottom:calc(var(--spacing) * 16)}.ml-\[3px\]{margin-left:3px}.ml-auto{margin-left:auto}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.h-\[15px\]{height:15px}.h-auto{height:auto}.w-\[7px\]{width:7px}.w-full{width:100%}.max-w-\[620px\]{max-width:620px}.max-w-\[680px\]{max-width:680px}.max-w-\[720px\]{max-width:720px}.min-w-0{min-width:0}.flex-1{flex:1}.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,)}.flex-wrap{flex-wrap:wrap}.items-baseline{align-items:baseline}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-center{justify-content:center}.gap-1{gap:var(--spacing)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)))}.gap-x-3{column-gap:calc(var(--spacing) * 3)}.gap-x-4{column-gap:calc(var(--spacing) * 4)}.gap-y-1{row-gap:var(--spacing)}.overflow-hidden{overflow:hidden}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.rounded-r-lg{border-top-right-radius:var(--radius-lg);border-bottom-right-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-l-4{border-left-style:var(--tw-border-style);border-left-width:4px}.border-accent{border-color:var(--color-accent)}.border-border{border-color:var(--color-border)}.border-text{border-color:var(--color-text)}.bg-code{background-color:var(--color-code)}.bg-muted{background-color:var(--color-muted)}.bg-text{background-color:var(--color-text)}.p-4{padding:calc(var(--spacing) * 4)}.p-6{padding:calc(var(--spacing) * 6)}.px-1\.5{padding-inline:calc(var(--spacing) * 1.5)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-6{padding-inline:calc(var(--spacing) * 6)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:var(--spacing)}.py-2{padding-block:calc(var(--spacing) * 2)}.pt-16{padding-top:calc(var(--spacing) * 16)}.pb-20{padding-bottom:calc(var(--spacing) * 20)}.text-center{text-align:center}.align-\[-1px\]{vertical-align:-1px}.font-hand{font-family:var(--font-hand)}.font-mono{font-family:var(--font-mono)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[13px\]{font-size:13px}.text-\[15px\]{font-size:15px}.text-\[17px\]{font-size:17px}.text-\[clamp\(1\.75rem\,5vw\,2\.5rem\)\]{font-size:clamp(1.75rem,5vw,2.5rem)}.text-\[clamp\(1\.75rem\,6vw\,2\.5rem\)\]{font-size:clamp(1.75rem,6vw,2.5rem)}.text-\[clamp\(2rem\,6vw\,3rem\)\]{font-size:clamp(2rem,6vw,3rem)}.text-\[clamp\(2rem\,7vw\,3\.75rem\)\]{font-size:clamp(2rem,7vw,3.75rem)}.leading-\[1\.1\]{--tw-leading:1.1;line-height:1.1}.leading-\[1\.7\]{--tw-leading:1.7;line-height:1.7}.leading-\[1\.08\]{--tw-leading:1.08;line-height:1.08}.leading-\[1\.15\]{--tw-leading:1.15;line-height:1.15}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-\[-0\.02em\]{--tw-tracking:-.02em;letter-spacing:-.02em}.tracking-\[-0\.03em\]{--tw-tracking:-.03em;letter-spacing:-.03em}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.text-bg{color:var(--color-bg)}.text-muted{color:var(--color-muted)}.text-subtle{color:var(--color-subtle)}.text-text{color:var(--color-text)}.text-text-secondary{color:var(--color-text-secondary)}.text-text\/80{color:var(--color-text)}@supports (color:color-mix(in lab,red,red)){.text-text\/80{color:color-mix(in oklab,var(--color-text) 80%,transparent)}}.underline{text-decoration-line:underline}.opacity-60{opacity:.6}.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-\[4px_4px_0_0_var\(--text-primary\)\]{--tw-shadow:4px 4px 0 0 var(--tw-shadow-color,var(--text-primary));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}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-300{--tw-duration:.3s;transition-duration:.3s}@media (hover:hover){.group-hover\:text-accent:is(:where(.group):hover *){color:var(--color-accent)}.hover\:bg-accent:hover{background-color:var(--color-accent)}}@media (min-width:48rem){.md\:-mx-12{margin-inline:calc(var(--spacing) * -12)}.md\:pt-24{padding-top:calc(var(--spacing) * 24)}}@media (min-width:64rem){.lg\:-mx-24{margin-inline:calc(var(--spacing) * -24)}}}:root{--bg:#fff;--surface:#fafafa;--surface-elevated:#fff;--text:#111;--text-primary:#1a1a1a;--text-secondary:#333;--text-muted:#6b7280;--text-subtle:#9ca3af;--border:#e5e7eb;--border-strong:#d4d4d4;--ring:#1111111f;--overlay:#000000e6;--code-bg:#f3f4f6;--kbd-bg:#f3f4f6;--kbd-border:#e5e7eb;--note-bg:#eff6ff;--pre-bg:#f3f4f6;--pre-text:#1a1a1a;--pre-btn-border:#0000001f;--pre-btn-bg:#0000000d;--pre-btn-color:#0000008c;--loader-bg:#0a0a0a;--cursor-ring:#11111159;--icon-box-bg:#fafafa;--navbar-bg:#ffffffe0;--navbar-border:#e5e5e5cc;--link-hover-bg:#00000008;--link-active-bg:#0000000f;--inspector-highlight-bg:#2563eb14;--inspector-highlight-shadow:#2563eb33;--loader-line:#ffffffe6;--loader-line-glow:#fff6;--prose-link-underline:#1a1a1a4d}.dark{--bg:#07070a;--surface:#0f0f14;--surface-elevated:#13131a;--text:#f4f4f5;--text-primary:#e4e4e7;--text-secondary:#d4d4d8;--text-muted:#a1a1aa;--text-subtle:#a1a1aa;--border:#3f3f46;--border-strong:#52525b;--ring:#ffffff1a;--overlay:#000000eb;--code-bg:#18181b;--kbd-bg:#18181b;--kbd-border:#3f3f46;--note-bg:#2563eb1f;--pre-bg:#13131a;--pre-text:#f5f5f5;--pre-btn-border:#ffffff26;--pre-btn-bg:#ffffff14;--pre-btn-color:#ffffffa6;--loader-bg:#000;--cursor-ring:#ffffff40;--icon-box-bg:#2e2e3e;--navbar-bg:#13131ae0;--navbar-border:#3f3f46cc;--link-hover-bg:#ffffff0a;--link-active-bg:#ffffff14;--inspector-highlight-bg:#2563eb1f;--inspector-highlight-shadow:#2563eb4d;--loader-line:#ffffffe6;--loader-line-glow:#fff6;--prose-link-underline:#f4f4f54d}body{background-color:var(--bg);color:var(--text);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0}::selection{background-color:#2563eb26}.animate-blink{animation:1s step-end infinite blink}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.animate-float{animation:3s ease-in-out infinite float}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}html{scroll-behavior:smooth}::selection{background-color:#2563eb1f}.name-title{color:var(--text);transition:color .3s ease,transform .4s cubic-bezier(.22,1,.36,1)}@media (hover: hover){.name-title:hover{color:var(--accent)}}.name-title--hero{position:relative;display:inline-block;cursor:default;transition:color .35s ease,transform .5s cubic-bezier(.34,1.56,.64,1),letter-spacing .35s ease}.name-title--hero:before,.name-title--hero:after{content:"";position:absolute;left:50%;border-radius:4px;transform:translate(-50%);opacity:0}.name-title--hero:after{bottom:-6px;width:0;height:2.5px;background:linear-gradient(90deg,transparent 0%,color-mix(in srgb,var(--accent) 30%,transparent) 15%,var(--accent) 50%,color-mix(in srgb,var(--accent) 30%,transparent) 85%,transparent 100%);box-shadow:0 0 8px color-mix(in srgb,var(--accent) 20%,transparent),0 0 20px color-mix(in srgb,var(--accent) 10%,transparent);animation:underline-draw .8s cubic-bezier(.16,1,.3,1) 1.3s forwards;transition:box-shadow .5s ease,opacity .3s ease,height .4s ease}.name-title--hero:before{bottom:-10px;width:0;height:0;background:var(--accent);border-radius:50%;box-shadow:0 0 6px color-mix(in srgb,var(--accent) 60%,transparent),0 0 16px color-mix(in srgb,var(--accent) 30%,transparent);pointer-events:none}@keyframes underline-draw{0%{width:0;opacity:0}to{width:100%;opacity:.85}}@media (hover: hover){.name-title--hero:hover{color:var(--accent);transform:translateY(-4px) scale(1.03);letter-spacing:.015em}.name-title--hero:hover:after{box-shadow:0 0 12px color-mix(in srgb,var(--accent) 40%,transparent),0 0 30px color-mix(in srgb,var(--accent) 15%,transparent);opacity:1;height:3px}.name-title--hero:hover:before{animation:dot-appear .5s cubic-bezier(.34,1.56,.64,1) .1s forwards}}@keyframes dot-appear{0%{width:0;height:0;opacity:0}50%{opacity:1}to{width:5px;height:5px;opacity:.9}}.name-letters{display:inline-block;perspective:600px}.name-letter{display:inline-block;opacity:0;transform:translateY(40px) rotateX(-40deg) scale(.6);animation:letter-in .55s cubic-bezier(.34,1.56,.64,1) forwards;will-change:transform,opacity}@keyframes letter-in{0%{opacity:0;transform:translateY(40px) rotateX(-40deg) scale(.6)}60%{opacity:1}to{opacity:1;transform:translateY(0) rotateX(0) scale(1)}}.name-letters{position:relative}.name-letters:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(110deg,transparent 0%,transparent 25%,color-mix(in srgb,var(--accent) 18%,transparent) 40%,color-mix(in srgb,var(--accent) 8%,transparent) 50%,transparent 65%,transparent 100%);background-size:200% 100%;background-position:100% 0;pointer-events:none;animation:shimmer-sweep 1s cubic-bezier(.22,1,.36,1) 1.5s forwards;opacity:0}@keyframes shimmer-sweep{0%{background-position:100% 0;opacity:0}15%{opacity:1}85%{opacity:1}to{background-position:-30% 0;opacity:0}}.nowplaying{display:inline-flex;align-items:center;gap:.4rem;margin-top:.75rem;padding:.35rem .7rem;border-radius:999px;border:1px solid var(--border);background:var(--surface);font-size:12.5px;text-decoration:none;transition:border-color .2s ease,box-shadow .2s ease,opacity .3s ease;line-height:1}.nowplaying--active{color:var(--text-subtle)}.nowplaying--active:hover{border-color:#1db954;box-shadow:0 0 0 1px #1db95426}.nowplaying--paused{color:var(--text-subtle);opacity:.5}.nowplaying__icon{width:14px;height:14px;flex-shrink:0}.nowplaying__icon--active{color:#1db954}.nowplaying__art{width:18px;height:18px;border-radius:3px;object-fit:cover;flex-shrink:0}.nowplaying__track{font-weight:500;color:var(--text);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nowplaying__separator{color:var(--text-subtle)}.nowplaying__artist{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.navbar-wrapper{position:fixed;top:1rem;left:0;right:0;z-index:80;display:flex;justify-content:center;pointer-events:none}.floating-navbar{position:fixed;top:1.25rem;left:50%;transform:translate(-50%);z-index:80;display:flex;align-items:center;gap:.75rem;padding:.65rem .8rem .65rem 1.25rem;background:var(--navbar-bg);border:1px solid var(--navbar-border);border-radius:999px;box-shadow:0 4px 6px #00000005,0 16px 32px #0000000d;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);font-size:14px}.floating-navbar__brand a{font-weight:700;color:var(--text);text-decoration:none;letter-spacing:-.02em;padding-right:1rem;border-right:1px solid var(--border);transition:color .2s ease;font-size:15px}.floating-navbar__brand a:hover{color:var(--accent)}.floating-navbar__links{display:flex;align-items:center;gap:.35rem}.floating-navbar__links a{padding:.45rem .9rem;border-radius:999px;color:var(--text-muted);text-decoration:none;transition:color .2s ease,background .2s ease}.floating-navbar__links a:hover{color:var(--text-primary);background:var(--link-hover-bg)}.floating-navbar__links a.active{color:var(--text-primary);background:var(--link-active-bg);font-weight:500}.floating-navbar__palette{display:flex;align-items:center;gap:.35rem;padding-left:.5rem;border-left:1px solid var(--border)}.color-dot{width:18px;height:18px;border-radius:50%;border:2px solid transparent;background:var(--dot-color);cursor:pointer;transition:transform .2s ease,border-color .2s ease}.color-dot:hover{transform:scale(1.15)}.color-dot--active{border-color:var(--text-primary);transform:scale(1.1)}.theme-toggle,.inspect-toggle{display:flex;align-items:center;justify-content:center;gap:.4rem;margin-left:.25rem;padding:.45rem .95rem;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:12px;font-weight:500;cursor:pointer;user-select:none;-webkit-user-select:none;white-space:nowrap;transition:all .15s ease}.theme-toggle{padding:.45rem .7rem}.theme-toggle:hover,.inspect-toggle:hover{border-color:var(--accent);color:var(--accent)}.theme-toggle:active,.inspect-toggle:active{transform:scale(.94)}.inspect-toggle--active{background:var(--accent);border-color:var(--accent);color:var(--bg)}.inspect-toggle--active:active{background:color-mix(in srgb,var(--accent) 80%,black);border-color:color-mix(in srgb,var(--accent) 80%,black)}.theme-toggle__icon,.inspect-toggle__icon{font-size:12px;line-height:1}.inspector-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;pointer-events:auto;cursor:crosshair}.inspector-highlight{position:absolute;outline:2px solid var(--accent);outline-offset:1px;background:var(--inspector-highlight-bg);border-radius:2px;box-shadow:0 0 0 1px var(--inspector-highlight-shadow)}.inspector-tooltip{position:absolute;z-index:71;min-width:180px;max-width:260px;padding:.5rem .75rem;background:var(--text-primary);color:var(--surface);border-radius:8px;font-family:JetBrains Mono,monospace;font-size:11px;line-height:1.5;box-shadow:0 8px 24px #0003;pointer-events:none}.inspector-tooltip__header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.25rem}.inspector-tooltip__tag{color:#60a5fa;font-weight:600;text-transform:lowercase}.inspector-tooltip__size{color:var(--text-subtle);font-size:10px}.inspector-tooltip__id{color:#fbbf24}.inspector-tooltip__classes{color:#a78bfa;word-break:break-all}.inspector-hint{position:fixed;bottom:1rem;right:1rem;z-index:71;padding:.4rem .75rem;background:var(--text-primary);color:var(--bg);border-radius:999px;font-family:JetBrains Mono,monospace;font-size:11px;pointer-events:none}.inspector-hint kbd{background:var(--border);color:var(--text-primary);padding:.05rem .3rem;border-radius:4px}.motion-page{width:100%;min-height:100vh}.app-shell{min-height:100vh;background:var(--surface);color:var(--text-primary);transition:opacity .7s cubic-bezier(.22,1,.36,1)}.app-shell--out{opacity:0}.app-shell--in{opacity:1}.loader{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;pointer-events:none}.loader-half{position:absolute;top:0;bottom:0;width:50%;background:var(--loader-bg);transition:transform .7s cubic-bezier(.76,0,.24,1)}.loader-half--left{left:0;transform:translate(0)}.loader-half--right{right:0;transform:translate(0)}.loader-line{position:absolute;top:0;bottom:0;left:50%;width:2px;background:var(--loader-line);transform:translate(-50%) scaleY(0);transform-origin:top;transition:transform .35s cubic-bezier(.22,1,.36,1),opacity .2s ease;box-shadow:0 0 20px var(--loader-line-glow);z-index:2}.loader.pulse .loader-line{transform:translate(-50%) scaleY(1);opacity:1}.loader.split .loader-half--left{transform:translate(-100%)}.loader.split .loader-half--right{transform:translate(100%)}.loader.split .loader-line{opacity:0}.skip-link{position:absolute;top:1rem;left:1rem;z-index:50;transform:translateY(-150%);transition:transform .2s ease;padding:.5rem 1rem;background:var(--bg);border-radius:.5rem;border:1px solid var(--border);font-size:.875rem}.skip-link:focus{transform:translateY(0)}.grain{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E")}.dark .grain{filter:invert(1)}.sprite{position:relative;display:inline-flex;color:var(--text-primary);transition:transform .25s cubic-bezier(.34,1.56,.64,1),color .2s ease;animation:sprite-bob 2.4s ease-in-out infinite;cursor:pointer}@media (hover: hover){.sprite:hover{transform:translateY(-5px) scale(1.12) rotate(-3deg);color:var(--accent)}}@keyframes sprite-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.particle{position:absolute;top:50%;left:50%;width:var(--size);height:var(--size);margin:calc(var(--size) / -2) 0 0 calc(var(--size) / -2);background:var(--color);border-radius:0;pointer-events:none;shape-rendering:crispEdges;animation:particle-explode .85s cubic-bezier(.25,.46,.45,.94) forwards}@keyframes particle-explode{0%{transform:translate(-50%,-50%) rotate(0) scale(1);opacity:1}to{transform:translate(calc(-50% + var(--vx)),calc(-50% + var(--vy) + 60px)) rotate(var(--rot)) scale(0);opacity:0}}.inline-link{position:relative;color:var(--text-primary);font-weight:500;text-decoration:none;background-image:linear-gradient(currentColor,currentColor);background-position:0% 100%;background-repeat:no-repeat;background-size:0% 1px;transition:background-size .3s cubic-bezier(.22,1,.36,1),color .2s ease;padding-bottom:1px}.inline-link:hover{background-size:100% 1px;color:var(--accent)}.subtle-link{color:var(--text-subtle);text-decoration:none;transition:color .2s ease,transform .2s ease}.subtle-link:hover{color:var(--text-primary);transform:translate(3px)}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.animate-blink{animation:blink 1.05s step-end infinite}.section-divider{position:relative;display:inline-flex;align-items:center;margin-bottom:1.25rem;padding-bottom:.5rem}.section-divider:after{content:"";position:absolute;left:0;bottom:0;width:24px;height:2px;background:color-mix(in srgb,var(--accent) 50%,transparent);border-radius:1px;transition:width .3s ease,opacity .3s ease;opacity:.7}.section-divider:hover:after{width:100%;opacity:1}.section-divider span{font-family:JetBrains Mono,monospace;font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-subtle)}.dark .section-divider:after{opacity:.85}.project-card{position:relative;background:var(--bg);border:1px solid var(--border);border-radius:16px;padding:1.15rem;transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s ease,border-color .3s ease;box-shadow:0 1px 2px #00000005}@media (hover: hover){.project-card:hover{transform:translateY(-3px);border-color:var(--border-strong);box-shadow:0 12px 28px #0000000d}}.icon-box{display:flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:14px;background:var(--icon-box-bg);border:1px solid var(--border);flex-shrink:0;transition:transform .3s cubic-bezier(.34,1.56,.64,1),border-color .3s ease,background .2s ease}@media (hover: hover){.project-card:hover .icon-box{transform:scale(1.08) rotate(-3deg);border-color:var(--accent)}}.tag{font-size:11px;font-weight:500;color:var(--text-muted);background:var(--code-bg);padding:3px 8px;border-radius:999px;letter-spacing:.02em;transition:background .2s ease,color .2s ease}@media (hover: hover){.project-card:hover .tag{background:var(--note-bg);color:var(--accent)}}.photo-desk{display:flex;flex-wrap:wrap;justify-content:center;gap:0;padding:1.5rem 0 2rem}.polaroid{flex:0 0 auto;width:130px;background:#fff;padding:7px 7px 22px;border-radius:3px;box-shadow:0 1px 1px #00000014,0 4px 8px #0000000f,0 10px 20px #00000014;transform:rotate(var(--rotate, 0deg));transition:transform .35s cubic-bezier(.34,1.56,.64,1),box-shadow .35s ease,z-index 0s;margin-left:-18px;position:relative;z-index:1}.polaroid:first-child{margin-left:0}.polaroid img{display:block;width:100%;height:100px;object-fit:cover;border-radius:2px;background:#f3f4f6}.polaroid figcaption{font-family:Caveat,Kalam,cursive;font-size:.95rem;color:#1a1a1a;text-align:center;margin-top:8px;line-height:1.2;transform:rotate(-1deg)}@media (hover: hover){.polaroid:hover{transform:rotate(0) translateY(-8px) scale(1.06);box-shadow:0 8px 16px #0000001f,0 20px 40px #00000024,0 40px 72px #0000002e;z-index:20}}.footer{border-top:1px solid var(--border);padding-top:1.5rem}.footer__top{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.footer__brand{display:flex;flex-direction:column;gap:.25rem}.footer__name{font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.footer__role{font-size:14px;color:var(--text-muted)}.footer__links{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;font-size:14px}.footer__links,.footer__rss{display:inline-flex;align-items:center;color:var(--text-subtle);opacity:.4;text-decoration:none;transition:opacity .2s ease,color .2s ease}.footer__rss:hover{opacity:.9;color:#f26522}.footer__link{color:var(--text-primary);text-decoration:none;position:relative;transition:color .2s ease}.footer__link:after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .25s ease}.footer__link:hover{color:var(--accent)}.footer__link:hover:after{transform:scaleX(1);transform-origin:left}.footer__bottom{text-align:center;font-size:13px;color:var(--text-subtle);display:flex;flex-direction:column;align-items:center;gap:.5rem}.footer__bottom .nowplaying{margin-top:0}.guestbook-form{margin-bottom:2rem;transition:opacity .3s ease}.guestbook-form--sent{animation:guestbookPulse .5s ease}@keyframes guestbookPulse{0%{transform:scale(1)}50%{transform:scale(1.01)}to{transform:scale(1)}}.guestbook-form__label{display:block;font-size:14px;font-weight:500;color:var(--text);margin-bottom:.5rem}.guestbook-form__row{display:flex;gap:.5rem;align-items:stretch}.guestbook-form__input{flex:1;padding:.7rem .85rem;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--text);font-size:14px;font-family:inherit;line-height:1.5;outline:none;resize:none;transition:border-color .2s ease,box-shadow .2s ease}.guestbook-form__input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #2563eb14}.guestbook-form__input:disabled{opacity:.5}.guestbook-form__input::placeholder{color:var(--text-subtle);opacity:.5}.guestbook-form__btn{display:flex;align-items:center;justify-content:center;min-width:72px;padding:.7rem 1.2rem;border:1px solid var(--accent);border-radius:10px;background:var(--accent);color:#fff;font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;white-space:nowrap;transition:opacity .2s ease,transform .15s ease}.guestbook-form__btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.guestbook-form__btn:not(:disabled):hover{opacity:.85}.guestbook-form__btn:not(:disabled):active{transform:scale(.96)}.guestbook-form__spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:guestbookSpin .6s linear infinite}@keyframes guestbookSpin{to{transform:rotate(360deg)}}.guestbook-form__footer{display:flex;justify-content:space-between;align-items:center;margin-top:.35rem;gap:.5rem}.guestbook-form__captcha{--turnstile-scale: .78;transform:scale(var(--turnstile-scale));transform-origin:left center}.guestbook-form__count{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text-subtle);opacity:.5;transition:opacity .2s ease,color .2s ease}.guestbook-form__count--warn{opacity:1;color:var(--accent)}.guestbook-entries{display:flex;flex-direction:column;gap:.75rem}.guestbook-entry{display:block;padding:1rem 1.1rem;border:1px solid var(--border);border-radius:10px;background:var(--surface);text-decoration:none;animation:guestbookFadeIn .4s ease both;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}@keyframes guestbookFadeIn{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.guestbook-entry:hover{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent);transform:translateY(-1px)}.guestbook-entry__message{font-size:15px;line-height:1.55;color:var(--text);margin-bottom:.4rem;word-break:break-word}.guestbook-entry__meta{display:flex;flex-direction:column;align-items:flex-start;gap:.1rem;font-size:12px;color:var(--text-subtle);font-family:JetBrains Mono,monospace}.guestbook-entry__author{font-weight:500}.guestbook-entry__date{opacity:.5;font-size:11px}@media (min-width: 640px){.footer__top{flex-direction:row;justify-content:space-between;align-items:flex-start}}.prose{color:var(--text-secondary);font-size:17px;line-height:1.75}.prose h1,.prose h2,.prose h3{color:var(--text);font-weight:700;letter-spacing:-.02em;line-height:1.25;margin-top:2.5rem;margin-bottom:1rem;position:relative;display:inline-block}.prose h2:after,.prose h3:after{content:"";position:absolute;left:0;bottom:-6px;width:2rem;height:2px;background:var(--accent);border-radius:1px;opacity:.5}.prose h1{font-size:1.75rem}.prose h2{font-size:1.35rem}.prose h3{font-size:1.1rem}.prose p{margin-bottom:1.25rem}.prose ul,.prose ol{margin-bottom:1.25rem;padding-left:1.5rem}.prose li{margin-bottom:.5rem}.prose a{color:var(--text-primary);font-weight:500;text-decoration:none;position:relative}.prose a:after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:right;transition:transform .35s cubic-bezier(.16,1,.3,1)}.prose a:hover{color:var(--accent)}.prose a:hover:after{transform:scaleX(1);transform-origin:left}.prose code{font-family:JetBrains Mono,monospace;font-size:.9em;background:var(--code-bg);padding:.15rem .35rem;border-radius:4px;color:var(--text-primary)}.prose pre{background:var(--pre-bg);color:var(--pre-text);padding:1.25rem;border-radius:12px;overflow-x:auto;margin-bottom:1.25rem;border:1px solid var(--border);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent) 8%,transparent),0 4px 24px -8px color-mix(in srgb,var(--accent) 10%,transparent);transition:box-shadow .3s ease}.prose pre:hover{box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent) 15%,transparent),0 8px 32px -10px color-mix(in srgb,var(--accent) 15%,transparent)}.prose pre code{background:transparent;color:inherit;padding:0;font-size:14px}.prose strong{color:var(--text);font-weight:600}.prose hr{border:0;height:1px;background:var(--border);margin:2rem 0}.prose table{width:100%;border-collapse:separate;border-spacing:0;margin-bottom:1.5rem;font-size:15px;border:1px solid var(--border);border-radius:10px;overflow:hidden}.prose th,.prose td{padding:.75rem 1rem;border-bottom:1px solid var(--border);text-align:left}.prose th:not(:last-child),.prose td:not(:last-child){border-right:1px solid var(--border)}.prose th{background:var(--surface);font-weight:600;color:var(--text);letter-spacing:.01em}.prose tbody tr{transition:background .2s ease}.prose tbody tr:hover{background:color-mix(in srgb,var(--accent) 4%,transparent)}.prose tr:last-child td{border-bottom:0}.prose input[type=checkbox]{margin-right:.5rem;accent-color:var(--accent)}.prose img{max-width:100%;border-radius:12px;margin:1.25rem 0}.prose blockquote{position:relative;border-left:3px solid var(--accent);background:color-mix(in srgb,var(--accent) 4%,transparent);padding:1.25rem 1.25rem 1.25rem 1.5rem;border-radius:0 12px 12px 0;margin:1.5rem 0;color:var(--text-secondary);font-style:italic}.prose blockquote p{margin-bottom:.5rem}.prose blockquote p:last-child{margin-bottom:0}.prose kbd{font-family:JetBrains Mono,monospace;font-size:.85em;background:var(--code-bg);border:1px solid var(--border-strong);border-bottom-width:2px;border-radius:4px;padding:.1rem .35rem}.prose mark{background:var(--note-bg);color:var(--text-primary);padding:.05rem .2rem;border-radius:2px}.math-inline{display:inline-flex;align-items:center}.math-block{display:flex;justify-content:center;margin:1.25rem 0;overflow-x:auto}.garden-wrapper{width:100%;border-radius:16px;overflow:hidden;box-shadow:0 24px 60px #0003;background:#050510}.garden-ambient-drift{animation:garden-drift var(--garden-drift-duration, 4s) ease-in-out infinite alternate;animation-delay:var(--garden-drift-delay, 0ms)}@keyframes garden-drift{0%{transform:translate(0)}to{transform:translate(var(--garden-drift-x, 12px),var(--garden-drift-y, 8px))}}.reading-progress{position:fixed;top:0;left:0;right:0;height:2px;background:var(--accent);transform-origin:left;z-index:9999;box-shadow:0 0 8px color-mix(in srgb,var(--accent) 50%,transparent)}.blog-list{display:flex;flex-direction:column;gap:1rem}.blog-item{position:relative;border:1px solid var(--border);border-radius:1rem;overflow:hidden;transition:all .35s cubic-bezier(.16,1,.3,1)}.blog-item:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(135deg,transparent 0%,color-mix(in srgb,var(--accent) 10%,transparent) 50%,transparent 100%);opacity:0;transition:opacity .4s ease;pointer-events:none}.blog-item:after{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%) scaleY(0);width:3px;height:40%;background:var(--accent);border-radius:0 3px 3px 0;transition:transform .35s cubic-bezier(.16,1,.3,1)}@media (hover: hover){.blog-item:hover{background:var(--surface);border-color:transparent;transform:translateY(-3px);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 15%,transparent),0 20px 40px -10px color-mix(in srgb,var(--accent) 10%,transparent)}.blog-item:hover:before{opacity:1}.blog-item:hover:after{transform:translateY(-50%) scaleY(1)}}.blog-item__link{display:block;padding:1.5rem;position:relative;z-index:1}.blog-item__header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.75rem}@media (min-width: 640px){.blog-item__header{flex-direction:row;align-items:baseline;justify-content:space-between}}.blog-item__title{font-size:1.125rem;font-weight:650;color:var(--text);letter-spacing:-.01em;line-height:1.35;transition:color .25s ease}@media (hover: hover){.blog-item:hover .blog-item__title{color:var(--accent)}}.blog-item__meta{display:flex;flex-direction:column;align-items:flex-end;gap:.15rem;flex-shrink:0}.blog-item__date{font-family:JetBrains Mono,monospace;font-size:.8rem;color:var(--text-subtle);transition:transform .35s cubic-bezier(.16,1,.3,1);flex-shrink:0}.blog-item__readtime{font-family:JetBrains Mono,monospace;font-size:.7rem;color:var(--text-subtle);opacity:.5}@media (hover: hover){.blog-item:hover .blog-item__meta{transform:translate(-4px)}}.blog-item__summary{font-size:.95rem;line-height:1.65;color:var(--text-secondary);margin-bottom:1rem;transition:color .25s ease}@media (hover: hover){.blog-item:hover .blog-item__summary{color:var(--text)}}.blog-item__arrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.8125rem;font-weight:600;color:var(--accent);transform:translate(-.5rem);opacity:0;transition:all .35s cubic-bezier(.16,1,.3,1)}.blog-item__arrow svg{transition:transform .3s cubic-bezier(.16,1,.3,1)}@media (hover: hover){.blog-item:hover .blog-item__arrow{transform:translate(0);opacity:1}.blog-item:hover .blog-item__arrow svg{transform:translate(3px)}}@media (prefers-reduced-motion: reduce){.loader,.loader-half,.loader-line,.slider-track,.sprite,.polaroid,.project-card,.inline-link,.subtle-link{transition:none;animation:none}.app-shell{opacity:1}}@media (max-width: 640px){.floating-navbar{gap:.4rem;padding:.45rem .5rem .45rem .85rem}.floating-navbar__brand a{font-size:13px;padding-right:.5rem}.floating-navbar__links a{padding:.35rem .55rem;font-size:12px}.floating-navbar__palette{gap:.2rem;padding-left:.3rem}.color-dot{width:14px;height:14px}.theme-toggle{padding:.35rem .5rem;margin-left:.1rem}.inspect-toggle{padding:.3rem .5rem;margin-left:.1rem}.inspect-toggle__label{display:none}.theme-toggle:active,.inspect-toggle:active{transform:scale(.92)}.polaroid{width:130px;margin-left:-22px}.polaroid img{height:100px}.blog-list{gap:.75rem}.blog-item__link{padding:1rem}.prose{font-size:16px}.prose pre{padding:.75rem;font-size:13px}.app-shell>main{padding-left:1rem;padding-right:1rem}}@media (min-width: 641px){.inspect-toggle__label{display:inline}}@media (pointer: fine){html,body,a,button,[role=button],input,textarea,select{cursor:none}}.custom-cursor{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;border-radius:50%;transform:translate(-100px,-100px);will-change:transform}.custom-cursor--dot{width:8px;height:8px;margin-top:-4px;margin-left:-4px;background:var(--text);mix-blend-mode:difference;transition:width .15s ease,height .15s ease,margin .15s ease,background .15s ease}.custom-cursor--ring{width:32px;height:32px;margin-top:-16px;margin-left:-16px;border:1px solid var(--cursor-ring);transition:width .2s ease,height .2s ease,margin .2s ease,border-color .2s ease,background .2s ease}.custom-cursor--hover.custom-cursor--dot{width:12px;height:12px;margin-top:-6px;margin-left:-6px;background:var(--accent);mix-blend-mode:normal}.custom-cursor--hover.custom-cursor--ring{width:48px;height:48px;margin-top:-24px;margin-left:-24px;border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,transparent)}.custom-cursor--click.custom-cursor--dot{width:5px;height:5px;margin-top:-2.5px;margin-left:-2.5px}.custom-cursor--click.custom-cursor--ring{width:38px;height:38px;margin-top:-19px;margin-left:-19px;border-color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent)}.custom-cursor--ripple{width:8px;height:8px;margin-top:-4px;margin-left:-4px;border:1px solid var(--accent);background:transparent;animation:cursor-ripple .5s ease-out forwards}@keyframes cursor-ripple{0%{width:8px;height:8px;margin-top:-4px;margin-left:-4px;opacity:.8}to{width:64px;height:64px;margin-top:-32px;margin-left:-32px;opacity:0}}.custom-cursor--hidden{opacity:0;transition:opacity .2s ease}.code-copy-btn{position:absolute;top:.6rem;right:.6rem;display:flex;align-items:center;justify-content:center;width:30px;height:30px;padding:0;border:1px solid var(--pre-btn-border);border-radius:8px;background:var(--pre-btn-bg);color:var(--pre-btn-color);cursor:pointer;opacity:0;transform:translateY(-4px);transition:opacity .25s ease,transform .25s ease,background .2s ease,border-color .2s ease,color .2s ease}.prose pre:hover .code-copy-btn,.code-copy-btn:focus-visible{opacity:1;transform:translateY(0)}.code-copy-btn:hover{background:color-mix(in srgb,var(--pre-text) 12%,transparent);border-color:color-mix(in srgb,var(--pre-text) 22%,transparent);color:var(--pre-text)}.code-copy-btn--copied{background:#22c55e2e;border-color:#22c55e59;color:#22c55e}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;z-index:100;display:flex;flex-direction:column;gap:.5rem;pointer-events:none}.toast{padding:.65rem 1rem;background:var(--text-primary);color:var(--bg);border-radius:999px;font-size:13px;font-weight:500;box-shadow:0 12px 28px #0000002e;animation:toast-in .35s cubic-bezier(.22,1,.36,1) forwards}.toast:last-child{animation:toast-in .35s cubic-bezier(.22,1,.36,1) forwards,toast-out .3s ease 1.9s forwards}@keyframes toast-in{0%{opacity:0;transform:translateY(12px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes theme-wipe{0%{width:0;height:0;margin-top:0;margin-left:0}to{width:calc(var(--ripple-r) * 2);height:calc(var(--ripple-r) * 2);margin-top:calc(var(--ripple-r) * -1);margin-left:calc(var(--ripple-r) * -1)}}.theme-transitioning:before{content:"";position:fixed;top:var(--ripple-y);left:var(--ripple-x);width:0;height:0;border-radius:50%;z-index:99999;pointer-events:none;box-shadow:0 0 0 9999px var(--ripple-bg, #ffffff);animation:theme-wipe .85s cubic-bezier(.16,1,.3,1) both;transform:translateZ(0)}@keyframes toast-out{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(8px) scale(.96)}}
