/*! 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-divide-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;--color-red-400:oklch(70.4% .191 22.216);--color-red-500:oklch(63.7% .237 25.331);--color-yellow-500:oklch(79.5% .184 86.047);--color-blue-400:oklch(70.7% .165 254.624);--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-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--text-3xl:1.875rem;--text-3xl--line-height: 1.2 ;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tighter:-.05em;--tracking-tight:-.025em;--tracking-wider:.05em;--tracking-widest:.1em;--leading-tight:1.25;--leading-relaxed:1.625;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--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-surface:var(--surface);--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%;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{.visible{visibility:visible}.absolute{position:absolute}.relative{position:relative}.static{position:static}.inset-0{inset:0}.top-0{top:0}.right-0{right:0}.right-2{right:calc(var(--spacing) * 2)}.bottom-0{bottom:0}.left-2{left:calc(var(--spacing) * 2)}.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)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mb-1{margin-bottom:var(--spacing)}.mb-1\.5{margin-bottom:calc(var(--spacing) * 1.5)}.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-1{margin-left:var(--spacing)}.ml-\[3px\]{margin-left:3px}.ml-auto{margin-left:auto}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.table{display:table}.h-0\.5{height:calc(var(--spacing) * .5)}.h-1\.5{height:calc(var(--spacing) * 1.5)}.h-2{height:calc(var(--spacing) * 2)}.h-4{height:calc(var(--spacing) * 4)}.h-5{height:calc(var(--spacing) * 5)}.h-10{height:calc(var(--spacing) * 10)}.h-12{height:calc(var(--spacing) * 12)}.h-40{height:calc(var(--spacing) * 40)}.h-\[15px\]{height:15px}.h-auto{height:auto}.h-full{height:100%}.max-h-full{max-height:100%}.w-1\.5{width:calc(var(--spacing) * 1.5)}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.w-8{width:calc(var(--spacing) * 8)}.w-10{width:calc(var(--spacing) * 10)}.w-12{width:calc(var(--spacing) * 12)}.w-16{width:calc(var(--spacing) * 16)}.w-20{width:calc(var(--spacing) * 20)}.w-24{width:calc(var(--spacing) * 24)}.w-28{width:calc(var(--spacing) * 28)}.w-40{width:calc(var(--spacing) * 40)}.w-\[7px\]{width:7px}.w-\[40\%\]{width:40%}.w-fit{width:fit-content}.w-full{width:100%}.max-w-\[120px\]{max-width:120px}.max-w-\[220px\]{max-width:220px}.max-w-\[560px\]{max-width:560px}.max-w-\[620px\]{max-width:620px}.max-w-\[680px\]{max-width:680px}.max-w-\[720px\]{max-width:720px}.max-w-\[760px\]{max-width:760px}.max-w-full{max-width:100%}.min-w-0{min-width:0}.min-w-\[36px\]{min-width:36px}.min-w-\[60px\]{min-width:60px}.flex-1{flex:1}.shrink-0{flex-shrink:0}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-pulse{animation:var(--animate-pulse)}.cursor-pointer{cursor:pointer}.scroll-mt-20{scroll-margin-top:calc(var(--spacing) * 20)}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-baseline{align-items:baseline}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-0\.5{gap:calc(var(--spacing) * .5)}.gap-1{gap:var(--spacing)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}:where(.space-y-1>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(var(--spacing) * var(--tw-space-y-reverse));margin-block-end:calc(var(--spacing) * calc(1 - var(--tw-space-y-reverse)))}: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)))}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-8>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 8) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 8) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-10>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 10) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 10) * calc(1 - var(--tw-space-y-reverse)))}.gap-x-3{column-gap:calc(var(--spacing) * 3)}.gap-x-4{column-gap:calc(var(--spacing) * 4)}.gap-y-1{row-gap:var(--spacing)}:where(.divide-y>:not(:last-child)){--tw-divide-y-reverse:0;border-bottom-style:var(--tw-border-style);border-top-style:var(--tw-border-style);border-top-width:calc(1px * var(--tw-divide-y-reverse));border-bottom-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)))}:where(.divide-border\/10>:not(:last-child)){border-color:var(--color-border)}@supports (color:color-mix(in lab,red,red)){:where(.divide-border\/10>:not(:last-child)){border-color:color-mix(in oklab,var(--color-border) 10%,transparent)}}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-l-full{border-top-left-radius:3.40282e38px;border-bottom-left-radius:3.40282e38px}.rounded-r-full{border-top-right-radius:3.40282e38px;border-bottom-right-radius:3.40282e38px}.rounded-r-lg{border-top-right-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg)}.rounded-bl-lg{border-bottom-left-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-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.border-l-4{border-left-style:var(--tw-border-style);border-left-width:4px}.border-dashed{--tw-border-style:dashed;border-style:dashed}.border-none{--tw-border-style:none;border-style:none}.border-accent,.border-accent\/40{border-color:var(--color-accent)}@supports (color:color-mix(in lab,red,red)){.border-accent\/40{border-color:color-mix(in oklab,var(--color-accent) 40%,transparent)}}.border-border,.border-border\/10{border-color:var(--color-border)}@supports (color:color-mix(in lab,red,red)){.border-border\/10{border-color:color-mix(in oklab,var(--color-border) 10%,transparent)}}.border-border\/20{border-color:var(--color-border)}@supports (color:color-mix(in lab,red,red)){.border-border\/20{border-color:color-mix(in oklab,var(--color-border) 20%,transparent)}}.border-border\/30{border-color:var(--color-border)}@supports (color:color-mix(in lab,red,red)){.border-border\/30{border-color:color-mix(in oklab,var(--color-border) 30%,transparent)}}.border-border\/40{border-color:var(--color-border)}@supports (color:color-mix(in lab,red,red)){.border-border\/40{border-color:color-mix(in oklab,var(--color-border) 40%,transparent)}}.border-border\/50{border-color:var(--color-border)}@supports (color:color-mix(in lab,red,red)){.border-border\/50{border-color:color-mix(in oklab,var(--color-border) 50%,transparent)}}.border-text{border-color:var(--color-text)}.bg-accent,.bg-accent\/5{background-color:var(--color-accent)}@supports (color:color-mix(in lab,red,red)){.bg-accent\/5{background-color:color-mix(in oklab,var(--color-accent) 5%,transparent)}}.bg-accent\/10{background-color:var(--color-accent)}@supports (color:color-mix(in lab,red,red)){.bg-accent\/10{background-color:color-mix(in oklab,var(--color-accent) 10%,transparent)}}.bg-accent\/15{background-color:var(--color-accent)}@supports (color:color-mix(in lab,red,red)){.bg-accent\/15{background-color:color-mix(in oklab,var(--color-accent) 15%,transparent)}}.bg-accent\/60{background-color:var(--color-accent)}@supports (color:color-mix(in lab,red,red)){.bg-accent\/60{background-color:color-mix(in oklab,var(--color-accent) 60%,transparent)}}.bg-accent\/70{background-color:var(--color-accent)}@supports (color:color-mix(in lab,red,red)){.bg-accent\/70{background-color:color-mix(in oklab,var(--color-accent) 70%,transparent)}}.bg-accent\/\[0\.03\]{background-color:var(--color-accent)}@supports (color:color-mix(in lab,red,red)){.bg-accent\/\[0\.03\]{background-color:color-mix(in oklab,var(--color-accent) 3%,transparent)}}.bg-blue-400\/60{background-color:#54a2ff99}@supports (color:color-mix(in lab,red,red)){.bg-blue-400\/60{background-color:color-mix(in oklab,var(--color-blue-400) 60%,transparent)}}.bg-border{background-color:var(--color-border)}.bg-code{background-color:var(--color-code)}.bg-muted{background-color:var(--color-muted)}.bg-red-500{background-color:var(--color-red-500)}.bg-red-500\/5{background-color:#fb2c360d}@supports (color:color-mix(in lab,red,red)){.bg-red-500\/5{background-color:color-mix(in oklab,var(--color-red-500) 5%,transparent)}}.bg-surface{background-color:var(--color-surface)}.bg-text{background-color:var(--color-text)}.bg-transparent{background-color:#0000}.bg-yellow-500\/5{background-color:#edb2000d}@supports (color:color-mix(in lab,red,red)){.bg-yellow-500\/5{background-color:color-mix(in oklab,var(--color-yellow-500) 5%,transparent)}}.object-contain{object-fit:contain}.p-1{padding:var(--spacing)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-6{padding:calc(var(--spacing) * 6)}.p-8{padding:calc(var(--spacing) * 8)}.px-1{padding-inline:var(--spacing)}.px-1\.5{padding-inline:calc(var(--spacing) * 1.5)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.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-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-12{padding-block:calc(var(--spacing) * 12)}.pt-2{padding-top:calc(var(--spacing) * 2)}.pt-16{padding-top:calc(var(--spacing) * 16)}.pt-24{padding-top:calc(var(--spacing) * 24)}.pb-1{padding-bottom:var(--spacing)}.pb-2{padding-bottom:calc(var(--spacing) * 2)}.pb-3{padding-bottom:calc(var(--spacing) * 3)}.pb-6{padding-bottom:calc(var(--spacing) * 6)}.pb-20{padding-bottom:calc(var(--spacing) * 20)}.text-center{text-align:center}.text-right{text-align:right}.align-\[-1px\]{vertical-align:-1px}.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-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--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-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[8px\]{font-size:8px}.text-\[9px\]{font-size:9px}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.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\,3\.25rem\)\]{font-size:clamp(2rem,6vw,3.25rem)}.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)}.leading-tight{--tw-leading:var(--leading-tight);line-height:var(--leading-tight)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.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)}.tracking-tighter{--tw-tracking:var(--tracking-tighter);letter-spacing:var(--tracking-tighter)}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.tracking-widest{--tw-tracking:var(--tracking-widest);letter-spacing:var(--tracking-widest)}.text-\[var\(--text-subtle\)\]{color:var(--text-subtle)}.text-accent,.text-accent\/60{color:var(--color-accent)}@supports (color:color-mix(in lab,red,red)){.text-accent\/60{color:color-mix(in oklab,var(--color-accent) 60%,transparent)}}.text-accent\/80{color:var(--color-accent)}@supports (color:color-mix(in lab,red,red)){.text-accent\/80{color:color-mix(in oklab,var(--color-accent) 80%,transparent)}}.text-bg{color:var(--color-bg)}.text-blue-400\/60{color:#54a2ff99}@supports (color:color-mix(in lab,red,red)){.text-blue-400\/60{color:color-mix(in oklab,var(--color-blue-400) 60%,transparent)}}.text-blue-400\/80{color:#54a2ffcc}@supports (color:color-mix(in lab,red,red)){.text-blue-400\/80{color:color-mix(in oklab,var(--color-blue-400) 80%,transparent)}}.text-muted,.text-muted\/50{color:var(--color-muted)}@supports (color:color-mix(in lab,red,red)){.text-muted\/50{color:color-mix(in oklab,var(--color-muted) 50%,transparent)}}.text-muted\/60{color:var(--color-muted)}@supports (color:color-mix(in lab,red,red)){.text-muted\/60{color:color-mix(in oklab,var(--color-muted) 60%,transparent)}}.text-muted\/70{color:var(--color-muted)}@supports (color:color-mix(in lab,red,red)){.text-muted\/70{color:color-mix(in oklab,var(--color-muted) 70%,transparent)}}.text-muted\/80{color:var(--color-muted)}@supports (color:color-mix(in lab,red,red)){.text-muted\/80{color:color-mix(in oklab,var(--color-muted) 80%,transparent)}}.text-red-400\/80{color:#ff6568cc}@supports (color:color-mix(in lab,red,red)){.text-red-400\/80{color:color-mix(in oklab,var(--color-red-400) 80%,transparent)}}.text-red-500{color:var(--color-red-500)}.text-subtle{color:var(--color-subtle)}.text-text{color:var(--color-text)}.text-text-secondary{color:var(--color-text-secondary)}.text-text\/60{color:var(--color-text)}@supports (color:color-mix(in lab,red,red)){.text-text\/60{color:color-mix(in oklab,var(--color-text) 60%,transparent)}}.text-text\/70{color:var(--color-text)}@supports (color:color-mix(in lab,red,red)){.text-text\/70{color:color-mix(in oklab,var(--color-text) 70%,transparent)}}.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)}}.text-text\/90{color:var(--color-text)}@supports (color:color-mix(in lab,red,red)){.text-text\/90{color:color-mix(in oklab,var(--color-text) 90%,transparent)}}.uppercase{text-transform:uppercase}.opacity-30{opacity:.3}.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)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-sm{--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)}.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-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-shadow{transition-property:box-shadow;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)}.group-hover\:shadow-md:is(:where(.group):hover *){--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.hover\:border-accent\/60:hover{border-color:var(--color-accent)}@supports (color:color-mix(in lab,red,red)){.hover\:border-accent\/60:hover{border-color:color-mix(in oklab,var(--color-accent) 60%,transparent)}}.hover\:bg-accent:hover,.hover\:bg-accent\/\[0\.03\]:hover{background-color:var(--color-accent)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-accent\/\[0\.03\]:hover{background-color:color-mix(in oklab,var(--color-accent) 3%,transparent)}}.hover\:bg-surface:hover{background-color:var(--color-surface)}.hover\:text-accent:hover{color:var(--color-accent)}.hover\:text-text:hover{color:var(--color-text)}}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-30:disabled{opacity:.3}@media (min-width:48rem){.md\:-mx-12{margin-inline:calc(var(--spacing) * -12)}.md\:pt-24{padding-top:calc(var(--spacing) * 24)}.md\:pt-32{padding-top:calc(var(--spacing) * 32)}}@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:#00000014;--border-strong:#00000024;--ring:#1111111f;--overlay:#000000e6;--code-bg:#f3f4f6;--kbd-bg:#f3f4f6;--kbd-border:#0000001f;--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;--polaroid-bg:#fff;--score-good:#16a34a;--score-good-bg:#16a34a}@supports (color:color-mix(in lab,red,red)){:root{--score-good-bg:color-mix(in srgb, #16a34a 10%, var(--surface))}}:root{--score-ok:#d97706;--score-ok-bg:#d97706}@supports (color:color-mix(in lab,red,red)){:root{--score-ok-bg:color-mix(in srgb, #d97706 10%, var(--surface))}}:root{--score-bad:#dc2626;--score-bad-bg:#dc2626}@supports (color:color-mix(in lab,red,red)){:root{--score-bad-bg:color-mix(in srgb, #dc2626 10%, var(--surface))}}:root{--diff-add:#16a34a;--diff-add-bg:#16a34a}@supports (color:color-mix(in lab,red,red)){:root{--diff-add-bg:color-mix(in srgb, #16a34a 10%, var(--surface))}}:root{--diff-del:#dc2626;--diff-del-bg:#dc2626}@supports (color:color-mix(in lab,red,red)){:root{--diff-del-bg:color-mix(in srgb, #dc2626 10%, var(--surface))}}:root{--diff-mod:#2563eb;--diff-mod-bg:#2563eb}@supports (color:color-mix(in lab,red,red)){:root{--diff-mod-bg:color-mix(in srgb, #2563eb 10%, var(--surface))}}:root{--diff-rename:#d97706;--diff-rename-bg:#d97706}@supports (color:color-mix(in lab,red,red)){:root{--diff-rename-bg:color-mix(in srgb, #d97706 10%, var(--surface))}}:root{--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;--text-inverted:#ffffffe6;--surface-inverted:#ffffff14;--surface-inverted-hover:#ffffff26;--border-inverted:#ffffff2e;--border-inverted-hover:#ffffff59}.dark{--bg:#07070a;--surface:#0f0f14;--surface-elevated:#13131a;--text:#f4f4f5;--text-primary:#e4e4e7;--text-secondary:#d4d4d8;--text-muted:#a1a1aa;--text-subtle:#a1a1aa;--border:#ffffff0f;--border-strong:#ffffff1f;--ring:#ffffff1a;--overlay:#000000eb;--code-bg:#18181b;--kbd-bg:#18181b;--kbd-border:#ffffff1f;--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;--polaroid-bg:#f0ede8;--score-good:#4ade80;--score-good-bg:#4ade80}@supports (color:color-mix(in lab,red,red)){.dark{--score-good-bg:color-mix(in srgb, #4ade80 12%, var(--surface))}}.dark{--score-ok:#fbbf24;--score-ok-bg:#fbbf24}@supports (color:color-mix(in lab,red,red)){.dark{--score-ok-bg:color-mix(in srgb, #fbbf24 12%, var(--surface))}}.dark{--score-bad:#f87171;--score-bad-bg:#f87171}@supports (color:color-mix(in lab,red,red)){.dark{--score-bad-bg:color-mix(in srgb, #f87171 12%, var(--surface))}}.dark{--diff-add:#4ade80;--diff-add-bg:#4ade80}@supports (color:color-mix(in lab,red,red)){.dark{--diff-add-bg:color-mix(in srgb, #4ade80 12%, var(--surface))}}.dark{--diff-del:#f87171;--diff-del-bg:#f87171}@supports (color:color-mix(in lab,red,red)){.dark{--diff-del-bg:color-mix(in srgb, #f87171 12%, var(--surface))}}.dark{--diff-mod:#60a5fa;--diff-mod-bg:#60a5fa}@supports (color:color-mix(in lab,red,red)){.dark{--diff-mod-bg:color-mix(in srgb, #60a5fa 12%, var(--surface))}}.dark{--diff-rename:#fbbf24;--diff-rename-bg:#fbbf24}@supports (color:color-mix(in lab,red,red)){.dark{--diff-rename-bg:color-mix(in srgb, #fbbf24 12%, var(--surface))}}.dark{--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-divide-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}@keyframes pulse{50%{opacity:.5}}.blog-post__actions{display:flex;align-items:center;gap:.5rem;margin-top:1rem}.blog-post__action{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .75rem;border:1px solid var(--border);border-radius:999px;background:transparent;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:11.5px;font-weight:500;cursor:pointer;transition:color .2s cubic-bezier(.22,1,.36,1),border-color .2s cubic-bezier(.22,1,.36,1),transform .15s cubic-bezier(.34,1.56,.64,1)}.blog-post__action:hover{border-color:var(--accent);color:var(--accent)}.blog-post__action:active{transform:scale(.94)}.blog-post__action--copied{border-color:#16a34a;color:#16a34a;animation:action-pop .4s cubic-bezier(.34,1.56,.64,1)}@keyframes action-pop{0%{transform:scale(1)}40%{transform:scale(1.12)}to{transform:scale(1)}}.blog-item__tags{display:flex;gap:.35rem;flex-wrap:wrap;padding:1.25rem 1.5rem 0}.blog-item__tag{font-size:10.5px;font-weight:500;padding:2px 8px;border-radius:999px;background:color-mix(in srgb,var(--accent) 8%,transparent);color:var(--text-muted);letter-spacing:.02em;text-transform:lowercase;text-decoration:none;transition:all .2s ease}.blog-item__tag:hover{background:color-mix(in srgb,var(--accent) 18%,transparent);color:var(--accent);transform:translateY(-1px)}.blog-item__tag--active{background:color-mix(in srgb,var(--accent) 25%,transparent);color:var(--accent);font-weight:600}.blog-tags-cloud{display:flex;flex-wrap:wrap;gap:.5rem}.blog-tags-cloud__item{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .8rem;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--text-muted);font-size:12px;font-weight:500;text-decoration:none;text-transform:lowercase;letter-spacing:.01em;transition:all .2s cubic-bezier(.22,1,.36,1)}.blog-tags-cloud__item:hover{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 6%,var(--surface));transform:translateY(-1px)}.blog-tags-cloud__count{display:inline-flex;align-items:center;justify-content:center;min-width:1.25rem;padding:0 .35rem;height:1.25rem;border-radius:999px;background:var(--bg);color:var(--text-subtle);font-size:10px;font-family:JetBrains Mono,monospace}.post-tags{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.75rem}.post-tag{display:inline-flex;align-items:center;padding:.35rem .85rem;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--text-muted);font-size:12px;font-weight:500;text-decoration:none;text-transform:lowercase;letter-spacing:.01em;transition:all .2s cubic-bezier(.22,1,.36,1)}.post-tag:hover{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 6%,var(--surface));transform:translateY(-1px)}.mermaid-diagram{display:flex;justify-content:center;margin:2rem 0}.mermaid-diagram svg{max-width:100%;height:auto}.mermaid-diagram .label{color:var(--text)!important;font-family:Inter,system-ui,sans-serif!important}.mermaid-error{margin:2rem 0;padding:1.25rem;border:1px solid #ef4444;border-radius:12px;background:color-mix(in srgb,#ef4444 8%,var(--surface));color:#ef4444}.mermaid-error pre{margin-top:.75rem;font-size:12px;white-space:pre-wrap}.blog-search{position:relative;display:flex;align-items:center;gap:.5rem;padding:.6rem .85rem;border:1px solid var(--border);border-radius:12px;background:var(--surface);transition:border-color .2s ease,box-shadow .2s ease}.blog-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 8%,transparent)}.blog-search__icon{flex-shrink:0;color:var(--text-subtle);opacity:.5}.blog-search__input{flex:1;border:none;background:transparent;color:var(--text);font-size:14px;font-family:inherit;outline:none}.blog-search__input::placeholder{color:var(--text-subtle);opacity:.4}.blog-search__clear{display:flex;align-items:center;justify-content:center;padding:.2rem;border:none;background:none;color:var(--text-subtle);cursor:pointer;border-radius:50%;transition:color .2s ease;opacity:.5}.blog-search__clear:hover{opacity:1;color:var(--text)}.related-posts{border-top:1px solid var(--border);padding-top:2rem}.related-posts__title{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-subtle);margin-bottom:1rem}.related-posts__list{display:flex;flex-direction:column;gap:.75rem}.related-posts__card{display:block;padding:1rem 1.15rem;border:1px solid var(--border);border-radius:12px;background:var(--surface);text-decoration:none;transition:border-color .2s ease,transform .2s ease}.related-posts__card:hover{border-color:var(--accent);transform:translateY(-2px)}.related-posts__card-title{font-size:15px;font-weight:600;color:var(--text);letter-spacing:-.01em;margin-bottom:.3rem;transition:color .2s ease}.related-posts__card:hover .related-posts__card-title{color:var(--accent)}.related-posts__card-summary{font-size:13px;color:var(--text-muted);line-height:1.5;margin-bottom:.4rem}.related-posts__card-date{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text-subtle);opacity:.5}.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: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{position:relative;background:var(--pre-bg);color:var(--pre-text);padding:1.5rem;border-radius:14px;overflow-x:auto;margin-bottom:1.75rem;border:1px solid var(--border)}.code-language{position:absolute;top:.75rem;left:.75rem;padding:.2rem .5rem;border-radius:6px;background:color-mix(in srgb,var(--accent) 10%,var(--pre-bg));color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:10.5px;font-weight:500;text-transform:lowercase;letter-spacing:.02em;border:1px solid color-mix(in srgb,var(--accent) 15%,var(--border));pointer-events:none;user-select:none}.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}.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;inset: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 (max-width: 640px){.blog-list{gap:.75rem}.blog-item__link{padding:1rem}.prose{font-size:16px}.prose pre{padding:.75rem;font-size:13px}.post-nav{flex-direction:column}}.post-nav{display:flex;gap:1rem;margin:3rem 0;padding-top:2rem;border-top:1px solid var(--border)}.post-nav__link{flex:1;display:flex;flex-direction:column;padding:1.25rem 1.5rem;border:1px solid var(--border);border-radius:14px;background:var(--surface);text-decoration:none;transition:all .3s cubic-bezier(.16,1,.3,1);min-width:0}.post-nav__link:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px -8px color-mix(in srgb,var(--accent) 12%,transparent)}.post-nav__link--next{text-align:right;align-items:flex-end}.post-nav__label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-subtle);margin-bottom:.4rem}.post-nav__title{font-size:.95rem;font-weight:600;color:var(--text);line-height:1.4;transition:color .2s ease;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.post-nav__link:hover .post-nav__title{color:var(--accent)}.github-contributions{position:relative;display:flex;flex-direction:column;gap:.5rem}.contrib-scroll{width:100%;overflow-x:auto;padding-bottom:.5rem;-webkit-overflow-scrolling:touch}.contrib-grid{display:grid;grid-template-rows:12px repeat(7,9px);gap:2px;width:fit-content;min-width:100%}.contrib-grid--skeleton{animation:contribSkeletonPulse 1.5s cubic-bezier(.22,1,.36,1) infinite}@keyframes contribSkeletonPulse{0%,to{opacity:.2}50%{opacity:.08}}.contrib-month{font-family:JetBrains Mono,monospace;font-size:9px;color:var(--text-subtle);line-height:1;align-self:end;padding-bottom:2px}.contrib-cell{width:9px;height:9px;border-radius:2px;background:var(--code-bg);cursor:pointer;opacity:0;transform:scale(.6);transition:background-color .3s cubic-bezier(.22,1,.36,1),transform .2s cubic-bezier(.34,1.56,.64,1),opacity .3s cubic-bezier(.22,1,.36,1)}.contrib-grid--visible .contrib-cell{animation:contrib-cell-in .5s cubic-bezier(.22,1,.36,1) forwards}@keyframes contrib-cell-in{to{opacity:1;transform:scale(1)}}.contrib-cell:hover{transform:scale(1.4);z-index:2;outline:1px solid var(--border-strong);outline-offset:1px}.contrib-cell[data-level="1"]{background:color-mix(in srgb,var(--accent) 25%,var(--code-bg))}.contrib-cell[data-level="2"]{background:color-mix(in srgb,var(--accent) 50%,var(--code-bg))}.contrib-cell[data-level="3"]{background:color-mix(in srgb,var(--accent) 75%,var(--code-bg))}.contrib-cell[data-level="4"]{background:color-mix(in srgb,var(--accent) 100%,var(--code-bg))}.contrib-cell--skeleton{opacity:1;transform:scale(1);animation:none;background:var(--code-bg)}.contrib-tooltip{position:fixed;z-index:99999;padding:.4rem .6rem;background:var(--text-primary);color:var(--surface);border-radius:6px;font-family:JetBrains Mono,monospace;font-size:10.5px;line-height:1.4;white-space:nowrap;pointer-events:none;transform:translate(-50%,calc(-100% - 6px));box-shadow:0 8px 24px #0000002e;animation:contrib-tooltip-in .15s cubic-bezier(.22,1,.36,1)}@keyframes contrib-tooltip-in{0%{opacity:0;transform:translate(-50%,calc(-100% + 4px))}to{opacity:1;transform:translate(-50%,-100%)}}.contrib-footer{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:.25rem}.contrib-total{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text-subtle)}.contrib-legend{display:flex;align-items:center;gap:.4rem;font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text-subtle)}.contrib-legend__cells{display:flex;gap:2px}.contrib-legend__cells .contrib-cell{opacity:1;transform:scale(1);animation:none;cursor:default}.contrib-legend__cells .contrib-cell:hover{transform:none;outline:none}#worldcup{--wc-red: #ef4444}.wc-card{position:relative;transition:transform .2s cubic-bezier(.2,0,0,1),border-color .2s ease,background-color .2s ease}.wc-card:hover{border-color:var(--accent-alpha);background-color:var(--surface-lighter)}.wc-status-live{background:color-mix(in srgb,var(--wc-red) 10%,transparent);color:var(--wc-red);border:1px solid color-mix(in srgb,var(--wc-red) 20%,transparent)}.wc-logo-container{width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;background:var(--surface);border-radius:9999px;padding:.5rem;overflow:hidden;border:1px solid var(--border);transition:border-color .2s ease}.wc-card:hover .wc-logo-container{border-color:var(--accent-alpha)}.wc-score{font-family:var(--font-mono);font-size:1.5rem;font-weight:700;letter-spacing:-.05em}.wc-table-header{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.2em;color:var(--text-muted)}.wc-table th{text-align:left;padding:.5rem .25rem;font-weight:500;border-bottom:1px solid var(--border-subtle)}.wc-table td{padding:.625rem .25rem;border-bottom:1px solid color-mix(in srgb,var(--border) 20%,transparent)}.wc-team-logo-small{width:1rem;height:1rem;filter:grayscale(1);transition:filter .2s ease}tr:hover .wc-team-logo-small{filter:grayscale(0)}@keyframes wc-pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-wc-pulse{animation:wc-pulse 2s cubic-bezier(.4,0,.6,1) infinite}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.worldcup-sticky{position:fixed;bottom:calc(48px + 1.5rem);right:1.5rem;z-index:71;display:flex;align-items:center;height:40px;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:13px;line-height:1;overflow:hidden}.worldcup-sticky--live:not(.worldcup-sticky--collapsed){box-shadow:0 4px 24px #ef44440f,0 2px 8px #0000000f}.worldcup-sticky__toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:none;border-radius:50%;background:transparent;color:var(--text-muted);cursor:pointer;flex-shrink:0;transition:color .15s ease}.worldcup-sticky:not(.worldcup-sticky--collapsed) .worldcup-sticky__toggle{border-right:1px solid var(--border)}.worldcup-sticky__toggle:hover{color:var(--text)}.worldcup-sticky__body-wrapper{display:flex;align-items:center;overflow:hidden;white-space:nowrap;max-width:0;opacity:0;min-width:0;transition:max-width .5s cubic-bezier(.16,1,.3,1),opacity .3s cubic-bezier(.16,1,.3,1) .05s}.worldcup-sticky--collapsed .worldcup-sticky__body-wrapper{max-width:0;opacity:0}.worldcup-sticky:not(.worldcup-sticky--collapsed) .worldcup-sticky__body-wrapper{max-width:fit-content;opacity:1}.worldcup-sticky__body{display:flex;align-items:center;gap:.5rem;padding:0 .65rem 0 .5rem;background:transparent;border:none;font-family:inherit;cursor:pointer;text-decoration:none;color:inherit;height:40px}.worldcup-sticky__live-indicator{display:flex;align-items:center;gap:3px;flex-shrink:0}.worldcup-sticky__live-dot{width:6px;height:6px;border-radius:50%;background:#ef4444;flex-shrink:0}.worldcup-sticky__live-label{font-size:10px;font-weight:700;letter-spacing:.08em;color:#ef4444;text-transform:uppercase}.worldcup-sticky__teams{display:flex;align-items:center;gap:.4rem;min-width:0}.worldcup-sticky__crest{width:20px;height:20px;object-fit:contain;flex-shrink:0}.worldcup-sticky__name{max-width:60px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:500;color:var(--text)}.worldcup-sticky__name--away{text-align:right}.worldcup-sticky__vs{font-size:10px;color:var(--text-muted);text-transform:uppercase;font-weight:600}.worldcup-sticky__score{font-size:15px;font-weight:700;font-family:var(--font-mono);color:var(--text);letter-spacing:-.02em}.worldcup-sticky__meta{font-size:11px;color:var(--text-subtle);flex-shrink:0}@media (max-width: 640px){.worldcup-sticky{bottom:calc(44px + 1rem);right:1rem}.worldcup-sticky__toggle{width:36px;height:36px}.worldcup-sticky__body{padding:0 .45rem 0 .35rem;gap:.3rem}.worldcup-sticky__name{display:none}.worldcup-sticky__crest{width:18px;height:18px}.worldcup-sticky__score{font-size:13px}.worldcup-sticky__meta{font-size:10px}}@keyframes wc-skeleton-pulse{0%,to{opacity:1}50%{opacity:.5}}.worldcup-skeleton{display:flex;flex-direction:column;gap:.6rem}.worldcup-skeleton__card{padding:1rem 1.15rem;border-radius:16px;background:var(--surface);border:1px solid var(--border);display:flex;flex-direction:column;gap:.6rem;animation:wc-skeleton-pulse 1.5s cubic-bezier(.22,1,.36,1) infinite}.worldcup-skeleton__row{display:flex;align-items:center;justify-content:center;gap:2rem}.worldcup-skeleton__avatar{width:48px;height:48px;border-radius:9999px;background:var(--code-bg)}.worldcup-skeleton__line{height:12px;border-radius:6px;background:var(--code-bg)}.worldcup-skeleton__line--short{width:40%;margin:0 auto}.worldcup-skeleton__pitch{width:100%;max-width:680px;margin:0 auto;aspect-ratio:1;border-radius:12px;background:linear-gradient(135deg,var(--code-bg) 0%,color-mix(in srgb,var(--code-bg) 80%,transparent) 50%,var(--code-bg) 100%);background-size:200% 200%;animation:wc-skeleton-shimmer 2s cubic-bezier(.22,1,.36,1) infinite;position:relative;overflow:hidden}.worldcup-skeleton__pitch:after{content:"";position:absolute;inset:0;border-radius:12px;border:1px solid var(--border);opacity:.3}@keyframes wc-skeleton-shimmer{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.player-stats-overlay{position:fixed;inset:0;z-index:999;display:flex;align-items:center;justify-content:center;background:#0009;backdrop-filter:blur(4px);padding:1rem;animation:wc-fade-in .2s ease}@keyframes wc-fade-in{0%{opacity:0}to{opacity:1}}.player-stats-modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;max-width:440px;max-height:80vh;overflow-y:auto;box-shadow:0 16px 48px #00000040;animation:wc-modal-pop .25s cubic-bezier(.22,1,.36,1)}@keyframes wc-modal-pop{0%{opacity:0;transform:scale(.92) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.player-stats-header{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.25rem .85rem;border-bottom:1px solid var(--border)}.player-stats-avatar{width:56px;height:56px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--code-bg);display:flex;align-items:center;justify-content:center}.player-stats-avatar-img{width:100%;height:100%;object-fit:cover;object-position:50% 0%}.player-stats-avatar-fallback{font-size:18px;font-weight:700;color:var(--text-muted);font-family:var(--font-mono, ui-monospace, monospace)}.player-stats-header-info{flex:1;min-width:0}.player-stats-header-top{display:flex;align-items:center;gap:.5rem;margin-bottom:.15rem}.player-stats-shirt{font-size:11px;font-weight:700;color:var(--accent);font-family:var(--font-mono, ui-monospace, monospace)}.player-stats-team-logo{width:16px;height:16px;object-fit:contain}.player-stats-name{font-size:15px;font-weight:700;color:var(--text);margin:0;line-height:1.2}.player-stats-team-name{font-size:11px;color:var(--text-muted);font-family:var(--font-mono, ui-monospace, monospace)}.player-stats-close{width:28px;height:28px;border-radius:8px;border:1px solid var(--border);background:var(--navbar-bg);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;align-self:flex-start;margin-left:auto;flex-shrink:0;transition:color .2s,border-color .2s}.player-stats-close:hover{color:var(--text);border-color:var(--text-muted)}.player-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;padding:1rem 1.25rem}@media (max-width: 400px){.player-stats-grid{gap:.4rem;padding:.75rem}.player-stats-item{padding:.5rem .3rem}.player-stats-item-value{font-size:17px}}.player-stats-item{display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.65rem .5rem;border-radius:10px;background:var(--code-bg);min-width:0;overflow:hidden}.player-stats-item-value{font-size:20px;font-weight:700;color:var(--text);font-family:var(--font-mono, ui-monospace, monospace);line-height:1;white-space:nowrap}.player-stats-item-label{font-size:9px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;text-align:center;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.player-stats-empty{padding:2rem 1.25rem;text-align:center;font-size:11px;font-family:var(--font-mono, ui-monospace, monospace);color:var(--text-muted)}.insights-chart{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:16px;overflow:hidden;margin:1.5rem 0}.insights-chart__fig{position:absolute;right:1rem;bottom:.75rem;font-family:var(--font-mono);font-size:11px;color:var(--text-subtle);opacity:.4;pointer-events:none;z-index:1}.insights-mock-toggle{position:absolute;top:.85rem;right:1rem;font-family:var(--font-mono);font-size:10px;font-weight:600;color:var(--text-subtle);background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:.3rem .75rem;cursor:pointer;z-index:2;transition:color .2s ease,border-color .2s ease,background .2s ease,transform .15s ease}.insights-mock-toggle:hover{color:var(--accent);border-color:var(--accent);background:color-mix(in srgb,var(--accent) 6%,var(--surface));transform:translateY(-1px)}.insights-chart__header{display:flex;align-items:baseline;gap:.75rem;padding:1.25rem 1.25rem .75rem}.insights-chart__title{font-family:var(--font-sans);font-size:clamp(1.5rem,4vw,2rem);font-weight:700;letter-spacing:-.02em;color:var(--text);line-height:1.1}.insights-chart__range{font-size:.9rem;color:var(--text-subtle);font-weight:500}.insights-chart__divider{height:1px;background:var(--border)}.insights-chart__stats{display:grid;grid-template-columns:repeat(3,1fr)}.insights-chart__stat{display:flex;flex-direction:column;gap:.25rem;padding:1rem 1.25rem;border-right:1px solid var(--border)}.insights-chart__stat:last-child{border-right:none}.insights-chart__stat-label{font-size:.75rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.insights-chart__stat-value{font-size:1.1rem;font-weight:700;color:var(--text);display:inline-block;animation:insights-stat-value-in .25s cubic-bezier(.22,1,.36,1) forwards}@keyframes insights-stat-value-in{0%{opacity:0;transform:translateY(-4px)}50%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.insights-chart__stats--live .insights-chart__stat-label{font-style:italic}.insights-chart__chart{position:relative;width:100%;height:280px;padding:.75rem 1.25rem 2.5rem}.insights-chart__svg{width:100%;height:100%;overflow:visible}.insights-chart__gridline{stroke:var(--border-strong);stroke-width:1;stroke-dasharray:4 4;opacity:.55}.insights-chart__gridline--vertical{stroke:var(--border-strong);stroke-dasharray:3 3;opacity:.4}.dark .insights-chart__gridline{opacity:.38}.dark .insights-chart__gridline--vertical{opacity:.28}.insights-chart__line{fill:none;stroke-linecap:round;stroke-linejoin:round;transition:stroke-dashoffset 1s cubic-bezier(.22,1,.36,1)}.insights-chart__line--sessions{stroke:var(--text-subtle);stroke-width:2;transition-delay:.15s}.insights-chart__line--visitors{stroke:var(--accent);stroke-width:2.5}.insights-chart__hover{pointer-events:none;will-change:transform;transition:transform .18s cubic-bezier(.22,1,.36,1),opacity .15s ease;animation:insights-fade-in .15s ease forwards}.insights-chart__cursor-line{stroke:url(#cursor-gradient);stroke-width:1}.insights-chart__cursor-shadow{stroke:var(--accent);stroke-width:6;opacity:.06;filter:blur(4px);pointer-events:none}.insights-chart__ripple{fill:none;stroke-width:1;opacity:0;pointer-events:none;animation:insights-ripple-expand .6s cubic-bezier(.22,1,.36,1) forwards}.insights-chart__ripple--visitors{stroke:var(--accent)}.insights-chart__ripple--sessions{stroke:var(--text-subtle);animation-delay:80ms}@keyframes insights-ripple-expand{0%{r:0;opacity:1}to{r:18;opacity:0}}.insights-chart__dim{pointer-events:none;opacity:0;transition:opacity .2s ease}.insights-chart__dim--left{fill:var(--accent)}.insights-chart__dim--right{fill:#000}.insights-chart__dim--active{opacity:.02}.insights-chart__dim--right.insights-chart__dim--active{opacity:.04}.insights-chart__gridline--active{stroke:var(--accent);opacity:.8;stroke-width:1.2}.insights-chart__gridline--dimmed{opacity:.25}.insights-chart__dot-group{pointer-events:none}.insights-chart__dot-pulse{opacity:0;transform-box:fill-box;transform-origin:center;transition:opacity .3s ease}.insights-chart__dot-group--active .insights-chart__dot-pulse{opacity:1;animation:insights-dot-pulse 1s ease-out infinite both}.insights-chart__dot-pulse--visitors{fill:var(--accent)}.insights-chart__dot-pulse--sessions{fill:var(--text-subtle);animation-delay:.12s}@keyframes insights-dot-pulse{0%{r:4;opacity:.4}to{r:16;opacity:0}}.insights-chart__dot-glow{opacity:0;transform-box:fill-box;transform-origin:center;transition:opacity .3s ease}.insights-chart__dot-group--active .insights-chart__dot-glow{opacity:.15;animation:insights-dot-glow 1.5s cubic-bezier(.22,1,.36,1) infinite both}.insights-chart__dot-glow--visitors{fill:var(--accent)}.insights-chart__dot-glow--sessions{fill:var(--text-subtle)}@keyframes insights-dot-glow{0%,to{transform:scale(1)}50%{transform:scale(1.3)}}.insights-chart__dot-core{stroke:var(--surface);stroke-width:2.5;animation:insights-dot-bounce .35s cubic-bezier(.34,1.56,.64,1) both}.insights-chart__dot-core--visitors{fill:var(--accent)}.insights-chart__dot-core--sessions{fill:var(--text-subtle)}@keyframes insights-dot-bounce{0%{r:2}60%{r:5}to{r:4.5}}.insights-chart__ghost{fill:var(--accent);pointer-events:none;opacity:0;transition:opacity .3s ease,cx .06s linear}.insights-chart__ghost--visible{opacity:var(--ghost-opacity, .3)}.insights-chart__dot{stroke:var(--surface);stroke-width:2;pointer-events:none;animation:insights-dot-in .25s cubic-bezier(.34,1.56,.64,1) forwards}.insights-chart__dot--sessions{fill:var(--text-subtle)}.insights-chart__dot--visitors{fill:var(--accent);animation-delay:40ms}@keyframes insights-dot-in{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.insights-chart__pill{position:absolute;bottom:.6rem;transform:translate(-50%) translateY(10px) scale(.92);opacity:0;background:var(--surface-elevated, var(--surface));color:var(--text);border:1px solid var(--border);border-radius:999px;padding:.4rem .9rem;font-size:.8rem;font-weight:600;white-space:nowrap;pointer-events:none;will-change:left,transform;transition:left .18s cubic-bezier(.22,1,.36,1),transform .25s cubic-bezier(.34,1.56,.64,1),opacity .2s ease}.insights-chart__pill--visible{opacity:1;transform:translate(-50%) translateY(0) scale(1)}.insights-chart__tooltip{position:absolute;transform:translate(10px,calc(-100% + 8px)) scale(.96);background:var(--text-primary);color:var(--surface);border-radius:10px;padding:.5rem .75rem;font-size:12px;box-shadow:0 8px 24px #0000001f;pointer-events:none;opacity:0;min-width:120px;z-index:10;will-change:left,top,transform;transition:left .18s cubic-bezier(.22,1,.36,1),top .18s cubic-bezier(.22,1,.36,1),transform .22s cubic-bezier(.34,1.56,.64,1),opacity .18s ease}.insights-chart__tooltip--left{transform:translate(calc(-100% - 10px),calc(-100% + 8px)) scale(.96)}.insights-chart__tooltip--visible{opacity:1;transform:translate(10px,-100%) scale(1)}.insights-chart__tooltip--visible.insights-chart__tooltip--left{transform:translate(calc(-100% - 10px),-100%) scale(1)}.insights-chart__tooltip-date{font-weight:700;margin-bottom:.35rem;color:var(--surface);font-size:11px;overflow:hidden}.insights-chart__tooltip-row{display:flex;align-items:center;gap:.4rem;margin-bottom:.15rem}.insights-chart__tooltip-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.insights-chart__tooltip-dot--visitors{background:var(--accent)}.insights-chart__tooltip-dot--sessions{background:var(--text-subtle)}.insights-chart__tooltip-label{flex:1;color:color-mix(in srgb,var(--surface) 80%,transparent)}.insights-chart__tooltip-value{font-weight:700;color:var(--surface);display:inline-block;transition:opacity .12s ease}.insights-chart__tooltip-delta{font-family:var(--font-mono);font-size:10px;opacity:.85;margin-top:.25rem;padding-top:.25rem;border-top:1px solid rgba(255,255,255,.1)}.insights-chart__tooltip-delta--positive{color:var(--score-good, #4ade80)}.insights-chart__tooltip-delta--negative{color:var(--score-bad, #f87171)}.insights-chart__tooltip-sparkline{margin-top:6px;padding-top:6px;border-top:1px solid rgba(255,255,255,.1)}.insights-chart__sparkline{display:block;overflow:visible}.insights-chart__sparkline-line{fill:none;stroke-width:1.2;stroke-linecap:round;stroke-linejoin:round}.insights-chart__sparkline-line--visitors{stroke:var(--accent)}.insights-chart__sparkline-line--sessions{stroke:var(--text-subtle);opacity:.7}.insights-chart__sparkline-dot{fill:var(--accent)}@keyframes tooltip-morph-in{0%{opacity:0;transform:translate(10px,calc(-100% + 8px)) scale(.88);filter:blur(4px)}to{opacity:1;transform:translate(10px,-100%) scale(1);filter:blur(0)}}@keyframes tooltip-morph-in-left{0%{opacity:0;transform:translate(calc(-100% - 10px),calc(-100% + 8px)) scale(.88);filter:blur(4px)}to{opacity:1;transform:translate(calc(-100% - 10px),-100%) scale(1);filter:blur(0)}}.insights-chart__tooltip{animation:none}.insights-chart__tooltip--visible{animation:tooltip-morph-in .28s cubic-bezier(.34,1.56,.64,1) forwards}.insights-chart__tooltip--visible.insights-chart__tooltip--left{animation:tooltip-morph-in-left .28s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes insights-fade-in{0%{opacity:0}to{opacity:1}}.insights-chart--skeleton{pointer-events:none}.insights-chart--skeleton .insights-chart__header,.insights-chart--skeleton .insights-chart__stat,.insights-chart--skeleton .insights-chart__chart{animation:insights-pulse 1.6s ease-in-out infinite}.skeleton-line{height:.75rem;background:var(--border);border-radius:4px;width:60%;margin-bottom:.5rem}.skeleton-line--title{width:40%;height:1.75rem}.skeleton-line--value{width:70%;height:1.25rem}.skeleton-chart{width:100%;height:100%;background:linear-gradient(90deg,var(--border) 0%,color-mix(in srgb,var(--border) 70%,var(--surface)) 50%,var(--border) 100%);background-size:200% 100%;border-radius:8px;animation:insights-shimmer 1.6s ease-in-out infinite}@keyframes insights-pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes insights-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.insights-chart__pill-text{display:inline-block}.insights-chart__pill-text--right{animation:pill-roll-down .2s cubic-bezier(.34,1.56,.64,1) forwards}.insights-chart__pill-text--left{animation:pill-roll-up .2s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes pill-roll-down{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes pill-roll-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.insights-chart__tooltip-date-text{display:inline-block}.insights-chart__tooltip-date-text--right{animation:tooltip-roll-down .2s cubic-bezier(.34,1.56,.64,1) forwards}.insights-chart__tooltip-date-text--left{animation:tooltip-roll-up .2s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes tooltip-roll-down{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@keyframes tooltip-roll-up{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 600px){.insights-chart{margin:1rem 0;border-radius:14px}.insights-chart__fig{right:.75rem;bottom:.5rem}.insights-mock-toggle{top:.65rem;right:.75rem;padding:.25rem .6rem;font-size:9px}.insights-chart__header{padding:1rem .9rem .6rem}.insights-chart__range{font-size:.8rem}.insights-chart__stats{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}.insights-chart__stats::-webkit-scrollbar{display:none}.insights-chart__stat{flex:1 0 33.333%;min-width:90px;scroll-snap-align:start;padding:.75rem .7rem;border-right:1px solid var(--border)}.insights-chart__stat-label{font-size:.65rem}.insights-chart__stat-value{font-size:.95rem}.insights-chart__chart{height:180px;padding:.5rem .75rem 2rem}.insights-chart__pill{bottom:.4rem;padding:.3rem .7rem;font-size:.7rem}.insights-chart__tooltip{min-width:100px;padding:.4rem .6rem;font-size:10.5px;border-radius:8px}.insights-chart__tooltip-date{font-size:10px;margin-bottom:.25rem;overflow:hidden}.insights-chart__tooltip-dot{width:5px;height:5px}}.insights-chart--clickable{cursor:pointer}.insights-chart--clickable:hover{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent);transition:border-color .2s ease,box-shadow .2s ease}[data-cursor-crosshair=true]{cursor:crosshair!important}.lighthouse-section{margin-bottom:3.5rem}.lighthouse-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.lighthouse-card{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:1.15rem;box-shadow:0 1px 3px #00000008,0 1px 2px #00000005;opacity:0;transform:translateY(12px);transition:opacity .5s cubic-bezier(.22,1,.36,1),transform .5s cubic-bezier(.22,1,.36,1),border-color .3s ease,box-shadow .3s ease;transition-delay:var(--lighthouse-delay, 0s)}.lighthouse-section--visible .lighthouse-card{opacity:1;transform:translateY(0)}@media (hover: hover){.lighthouse-card:hover{transform:translateY(-2px);border-color:var(--border-strong);box-shadow:0 10px 24px #0000000d}}.lighthouse-card__label{font-family:var(--font-mono);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-subtle);margin-bottom:.35rem}.lighthouse-card__score{font-family:var(--font-mono);font-size:1.75rem;font-weight:700;line-height:1;margin-bottom:.75rem}.lighthouse-card__bar-track{width:100%;height:8px;border-radius:999px;background:var(--border);overflow:hidden}.lighthouse-card__bar{display:block;height:100%;width:0;border-radius:999px;transition:width 1s cubic-bezier(.22,1,.36,1);transition-delay:var(--bar-delay, .2s)}.lighthouse-section--visible .lighthouse-card__bar{width:calc(var(--score, 0) * 100%)}.lighthouse-metrics{margin-top:.75rem;display:flex;flex-direction:column;gap:.35rem}.lighthouse-metric{display:flex;align-items:center;gap:.65rem;padding:.65rem .8rem;border-radius:10px;border:1px solid transparent;background:var(--surface);opacity:0;transform:translateY(10px);transition:opacity .45s cubic-bezier(.22,1,.36,1),transform .45s cubic-bezier(.22,1,.36,1),background .2s cubic-bezier(.22,1,.36,1),border-color .2s cubic-bezier(.22,1,.36,1);transition-delay:var(--lighthouse-delay, 0s)}.lighthouse-section--visible .lighthouse-metric{opacity:1;transform:translateY(0)}@media (hover: hover){.lighthouse-metric:hover{background:var(--code-bg);border-color:var(--border)}}.lighthouse-metric__dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.lighthouse-metric__content{flex:1;min-width:0}.lighthouse-metric__top{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.35rem}.lighthouse-metric__name{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lighthouse-metric__value{font-family:var(--font-mono);font-size:11px;color:var(--text-subtle);flex-shrink:0}.lighthouse-metric__bar-track{width:100%;height:5px;border-radius:999px;background:var(--border);overflow:hidden}.lighthouse-metric__bar{display:block;height:100%;width:0;border-radius:999px;transition:width 1s cubic-bezier(.22,1,.36,1);transition-delay:var(--bar-delay, .4s)}.lighthouse-section--visible .lighthouse-metric__bar{width:calc(var(--score, 0) * 100%)}.lighthouse-metric__score{font-family:var(--font-mono);font-size:14px;font-weight:700;width:2rem;text-align:right;flex-shrink:0}.lighthouse-meta{font-family:var(--font-mono);font-size:10px;color:var(--text-subtle);margin-top:.5rem;text-align:right;opacity:.8}.lighthouse-card--skeleton,.lighthouse-metric--skeleton{opacity:1;transform:none;pointer-events:none}.lighthouse-card--skeleton .skeleton-line,.lighthouse-metric--skeleton .skeleton-line{background:var(--border);border-radius:4px;height:.75rem;width:60%;margin-bottom:.5rem}.lighthouse-card--skeleton .skeleton-line--title{width:45%;height:.85rem}.lighthouse-card--skeleton .skeleton-line--value{width:35%;height:1.5rem}@media (max-width: 640px){.lighthouse-grid{gap:.6rem}.lighthouse-card{padding:.9rem;border-radius:14px}.lighthouse-card__label{font-size:9px}.lighthouse-card__score{font-size:1.5rem;margin-bottom:.6rem}.lighthouse-card__bar-track{height:6px}.lighthouse-metric{padding:.55rem .65rem}.lighthouse-metric__name{font-size:12px}.lighthouse-metric__score{font-size:13px;width:1.75rem}}.lightbox{position:fixed;inset:0;z-index:90;display:flex;align-items:center;justify-content:center;padding:1.5rem}.lightbox__backdrop{position:absolute;inset:0;background:var(--overlay);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);animation:lightbox-fade-in .25s cubic-bezier(.22,1,.36,1)}@keyframes lightbox-fade-in{0%{opacity:0}to{opacity:1}}.lightbox__strip{position:absolute;top:0;left:0;right:0;z-index:3;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.65rem 1rem;background:#0009;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);animation:lightbox-fade-in .25s cubic-bezier(.22,1,.36,1)}.lightbox__thumbs{display:flex;align-items:center;gap:.4rem}.lightbox__thumb{position:relative;width:32px;height:24px;border-radius:2px;overflow:hidden;opacity:.5;transform:scale(1);transition:opacity .2s cubic-bezier(.22,1,.36,1),transform .2s cubic-bezier(.22,1,.36,1)}.lightbox__thumb:before,.lightbox__thumb:after{content:"";position:absolute;top:2px;width:2px;height:6px;background:#fff6;z-index:1}.lightbox__thumb:before{left:2px}.lightbox__thumb:after{right:2px}.lightbox__thumb--active{opacity:1;transform:scale(1.05)}.lightbox__thumb img{width:100%;height:100%;object-fit:cover}.lightbox__counter{font-family:var(--font-mono);font-size:12px;color:#ffffffb3;flex-shrink:0}.lightbox__close,.lightbox__nav{position:absolute;z-index:2;display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:none;border-radius:12px;background:#ffffff1a;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fffffff2;cursor:pointer;transition:background .2s cubic-bezier(.22,1,.36,1),transform .2s cubic-bezier(.34,1.56,.64,1)}.lightbox__close:hover,.lightbox__nav:hover{background:#fff3;transform:scale(1.1)}.lightbox__close{top:3.5rem;right:1rem}.lightbox__close svg{width:18px;height:18px}.lightbox__nav--prev{left:1rem;top:50%;transform:translateY(-50%)}.lightbox__nav--next{right:1rem;top:50%;transform:translateY(-50%)}.lightbox__nav--prev:hover,.lightbox__nav--next:hover{transform:translateY(-50%) scale(1.1)}.lightbox__nav svg{width:20px;height:20px}.lightbox__content{position:relative;z-index:1;max-width:min(900px,90vw);max-height:min(80vh,800px);display:flex;flex-direction:column;align-items:center;margin:0;padding-top:2.5rem;animation:lightbox-scale-in .3s cubic-bezier(.22,1,.36,1)}@keyframes lightbox-scale-in{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.lightbox__image{max-width:100%;max-height:min(62vh,620px);object-fit:contain;border-radius:12px;box-shadow:0 24px 60px #00000059,0 0 0 1px #ffffff14}.lightbox__image--slide-left{animation:lightbox-slide-left .25s cubic-bezier(.22,1,.36,1)}.lightbox__image--slide-right{animation:lightbox-slide-right .25s cubic-bezier(.22,1,.36,1)}@keyframes lightbox-slide-left{0%{opacity:0;transform:translate(24px) scale(.97)}to{opacity:1;transform:none}}@keyframes lightbox-slide-right{0%{opacity:0;transform:translate(-24px) scale(.97)}to{opacity:1;transform:none}}.lightbox__caption{position:relative;margin-top:.85rem;padding-left:1.25rem;font-family:Caveat,Kalam,cursive;font-size:1.25rem;color:var(--text-inverted, rgba(255, 255, 255, .9));text-align:center;animation:lightbox-caption-in .35s cubic-bezier(.22,1,.36,1) .1s both}.lightbox__caption:before{content:'"';position:absolute;left:0;top:-.6rem;font-family:Georgia,serif;font-size:3rem;line-height:1;opacity:.3;color:#ffffffb3}@keyframes lightbox-caption-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.lightbox__keys{position:fixed;bottom:1.25rem;left:50%;transform:translate(-50%);z-index:2;font-family:var(--font-mono);font-size:11px;color:#ffffff59;opacity:0;pointer-events:none;transition:opacity .5s cubic-bezier(.22,1,.36,1)}.lightbox__keys--visible{opacity:1}@media (max-width: 640px){.lightbox{padding:3.5rem 1rem 1rem}.lightbox__strip{padding:.5rem .75rem}.lightbox__thumb{width:28px;height:20px}.lightbox__close,.lightbox__nav{width:40px;height:40px}.lightbox__close{top:3.25rem;right:.5rem}.lightbox__nav--prev{left:.5rem}.lightbox__nav--next{right:.5rem}.lightbox__content{padding-top:2rem}.lightbox__image{max-height:min(55vh,520px)}.lightbox__caption{font-size:1.1rem}.lightbox__keys{display:none}}html{scroll-behavior:smooth}::selection{background-color:#2563eb1f}.motion-page{width:100%;min-height:100vh}.app-shell{min-height:100vh;background:var(--surface);color:var(--text-primary);opacity:0;visibility:hidden;transform:translateY(16px) scale(.98);will-change:opacity,transform,visibility}.app-shell--in{animation:app-shell-in .55s cubic-bezier(.22,1,.36,1) forwards;visibility:visible}@keyframes app-shell-in{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.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;inset: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)}@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}.math-inline{display:inline}.math-inline .katex{display:inline;font-size:1.05em}.math-block{display:block;margin:1.5rem 0;overflow-x:auto;overflow-y:hidden;text-align:center}.math-block::-webkit-scrollbar{height:0;width:0}.math-block .katex-display{margin:0;overflow:visible}.math-block .katex{display:inline-block;white-space:nowrap}.math-inline>.katex-mathml,.math-block>.katex-display>.katex-mathml{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}*:focus{outline:none}*:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}.blog-search__input:focus-visible,.guestbook-form__input:focus-visible,.command-palette__input:focus-visible{outline:none}@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){.app-shell>main{padding-left:1rem;padding-right:1rem}}.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;position:relative}.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:after{content:"";position:absolute;inset: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}}.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)}.navbar-wrapper{position:fixed;top:1rem;left:0;right:0;z-index:80;display:flex;justify-content:center;pointer-events:none}.floating-navbar{display:flex;align-items:center;padding:.65rem .8rem .65rem 1.25rem;pointer-events:auto;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;gap:0;transition:gap .5s cubic-bezier(.16,1,.3,1)}.floating-navbar--expanded{gap:.75rem}.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)}.navbar-expand-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:50%;background:transparent;color:var(--text-muted);cursor:pointer;transition:color .2s ease,background .2s ease;flex-shrink:0}.navbar-expand-btn:hover{color:var(--text-primary);background:var(--link-hover-bg)}.floating-navbar__body{display:flex;align-items:center;gap:.75rem;overflow:hidden;white-space:nowrap;max-width:0;opacity:0;transition:max-width .55s cubic-bezier(.16,1,.3,1),opacity .35s cubic-bezier(.16,1,.3,1) .05s}.floating-navbar--expanded .floating-navbar__body{max-width:800px;opacity:1}.floating-navbar__links{display:flex;align-items:center;gap:.35rem;flex-shrink:0}.floating-navbar__links a{padding:.45rem .9rem;border-radius:999px;color:var(--text-muted);text-decoration:none;transition:color .2s ease,background .2s ease;white-space:nowrap}.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}.navbar-search{display:flex;align-items:center;gap:.5rem;padding:.35rem .65rem;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--text-muted);cursor:pointer;flex-shrink:0;transition:all .15s ease;user-select:none;-webkit-user-select:none}.navbar-search:hover{border-color:var(--accent);color:var(--accent)}.navbar-search:active{transform:scale(.94)}.navbar-search span{font-size:12px;font-weight:500}.navbar-search kbd{display:inline-flex;align-items:center;gap:2px;padding:.15rem .35rem;background:var(--code-bg);border:1px solid var(--border);border-radius:5px;font-family:var(--font-mono);font-size:10px;font-weight:600}.navbar-search kbd svg{opacity:.7}.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}.sound-toggle{display:flex;align-items:center;justify-content:center;gap:.35rem;padding:.45rem .75rem;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}.sound-toggle:hover{border-color:var(--accent);color:var(--accent)}.sound-toggle:active{transform:scale(.94)}.sound-toggle--muted{opacity:.55}.sound-toggle__label{font-size:11px}.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}@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)}.navbar-expand-btn__hamburger{display:none}@media (max-width: 640px){.navbar-wrapper{top:.75rem}.floating-navbar{position:relative;gap:.4rem;padding:.45rem .55rem .45rem .9rem;max-width:calc(100vw - 1.5rem);border-radius:999px}.floating-navbar__brand a{font-size:14px;padding-right:0;border-right:none}.navbar-expand-btn{width:30px;height:30px}.navbar-expand-btn__chevron{display:none}.navbar-expand-btn__hamburger{display:block}.floating-navbar__body{position:absolute;top:calc(100% + .5rem);left:50%;width:min(280px,calc(100vw - 2rem));max-width:none;flex-direction:column;align-items:stretch;gap:.5rem;padding:.65rem;background:var(--navbar-bg);border:1px solid var(--navbar-border);border-radius:20px;box-shadow:0 20px 40px #0000001a;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);opacity:0;visibility:hidden;pointer-events:none;transform:translate(-50%) translateY(-10px) scale(.94);transform-origin:top center;transition:opacity .25s cubic-bezier(.16,1,.3,1),visibility .25s cubic-bezier(.16,1,.3,1),transform .25s cubic-bezier(.16,1,.3,1)}.floating-navbar--expanded .floating-navbar__body{max-width:none;opacity:1;visibility:visible;pointer-events:auto;transform:translate(-50%) translateY(0) scale(1)}.floating-navbar__links{flex-direction:column;align-items:stretch;gap:.15rem}.floating-navbar__links a{padding:.55rem .7rem;font-size:14px;text-align:center;border-radius:12px}.theme-toggle{padding:.4rem .65rem;margin-left:0}.navbar-search{width:100%;justify-content:center;padding:.55rem .7rem;margin-top:.25rem}.sound-toggle{width:100%;padding:.55rem .7rem;margin-top:.25rem}.inspect-toggle{padding:.35rem .55rem;margin-left:0}.inspect-toggle__label{display:none}.theme-toggle:active,.inspect-toggle:active,.sound-toggle:active{transform:scale(.96)}}@media (min-width: 641px){.inspect-toggle__label{display:inline}.floating-navbar--collapsed .theme-toggle{display:none}}.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}.nowplaying-sticky{position:fixed;bottom:1.5rem;right:1.5rem;z-index:70;display:flex;align-items:center;height:40px;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:13px;line-height:1;overflow:hidden}.nowplaying-sticky--active:not(.nowplaying-sticky--collapsed){box-shadow:0 4px 24px #1db95414,0 2px 8px #0000000f}.nowplaying-sticky__toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:none;border-radius:50%;background:transparent;color:var(--text-muted);cursor:pointer;flex-shrink:0;transition:color .15s ease}.nowplaying-sticky:not(.nowplaying-sticky--collapsed) .nowplaying-sticky__toggle{border-right:1px solid var(--border)}.nowplaying-sticky__toggle:hover{color:var(--text)}.nowplaying-sticky__body-wrapper{display:flex;align-items:center;overflow:hidden;white-space:nowrap;max-width:0;opacity:0;transition:max-width .5s cubic-bezier(.16,1,.3,1),opacity .3s cubic-bezier(.16,1,.3,1) .05s}.nowplaying-sticky--collapsed .nowplaying-sticky__body-wrapper{max-width:0;opacity:0}.nowplaying-sticky:not(.nowplaying-sticky--collapsed) .nowplaying-sticky__body-wrapper{max-width:400px;opacity:1}.nowplaying-sticky__body{display:flex;align-items:center;gap:.55rem;padding:0 .9rem 0 .65rem;text-decoration:none;cursor:pointer;height:40px}.nowplaying-sticky__body--paused{cursor:default}.nowplaying-sticky__spotify-icon{display:flex;align-items:center;gap:4px;flex-shrink:0}.nowplaying-sticky__icon{width:16px;height:16px;flex-shrink:0;color:#1db954}.nowplaying-sticky__body--paused .nowplaying-sticky__icon{color:var(--text-subtle)}.nowplaying-sticky__pulse-dot{width:6px;height:6px;border-radius:50%;background:#1db954;flex-shrink:0}.nowplaying-sticky__body--paused .nowplaying-sticky__pulse-dot{display:none}.nowplaying-sticky__info{display:flex;flex-direction:column;gap:.1rem;min-width:0}.nowplaying-sticky__track{font-weight:600;color:var(--text);max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px}.nowplaying-sticky__artist{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:11px;color:var(--text-subtle)}.nowplaying-sticky__art{width:36px;height:36px;border-radius:6px;border:1px solid var(--border);object-fit:cover;flex-shrink:0}.nowplaying-sticky__text{font-size:12.5px;color:var(--text-subtle)}.nowplaying-sticky--collapsed .nowplaying-sticky__body--paused{display:none}@media (max-width: 640px){.nowplaying-sticky{bottom:1rem;right:1rem}.nowplaying-sticky__toggle{width:36px;height:36px}.nowplaying-sticky__body{padding:0 .75rem 0 .5rem}.nowplaying-sticky__track,.nowplaying-sticky__artist{max-width:90px}}.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;display:inline-flex;align-items:center;gap:.3rem}.footer__flag-wrap{display:inline-flex;animation:flag-wave 3s ease-in-out infinite;transform-origin:center bottom}.footer__flag{width:18px;height:18px;border-radius:2px;object-fit:cover;display:block;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}@keyframes flag-wave{0%,to{transform:rotate(0) translateY(0)}25%{transform:rotate(8deg) translateY(-1px)}50%{transform:rotate(0) translateY(-2px)}75%{transform:rotate(-8deg) translateY(-1px)}}.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__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__inspired{opacity:.7}.footer__bottom .nowplaying{margin-top:0}.build-info{display:inline-flex;align-items:center;gap:.4rem;margin-top:.5rem;padding:5px 11px;font-size:11px;font-weight:500;font-family:var(--font-mono);color:var(--text-muted);text-decoration:none;background:var(--surface);border:1px solid var(--border);border-radius:999px;box-shadow:0 1px 3px #00000008,0 1px 2px #00000005;transition:color .25s ease,border-color .25s ease,background .25s ease,transform .25s cubic-bezier(.22,1,.36,1),box-shadow .25s ease}.dark .build-info{box-shadow:0 1px 3px #00000026,0 1px 2px #0000001a}.build-info:hover{color:var(--accent);border-color:var(--accent);background:var(--code-bg);transform:translateY(-1px);box-shadow:0 6px 16px #0000000d}.build-info svg{flex-shrink:0;opacity:.75}.build-info code{font-family:inherit;font-size:inherit;color:var(--text-subtle);transition:color .25s ease}.build-info:hover code{color:var(--accent)}@media (max-width: 640px){.footer__top{gap:.75rem}.footer__links{gap:.75rem;font-size:13px}.footer__bottom{gap:.4rem;font-size:12px}.footer__inspired{display:block;margin-top:.15rem}}@media (min-width: 641px){.footer__top{flex-direction:row;justify-content:space-between;align-items:flex-start}}.project-card{position:relative;background:var(--surface);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 3px #00000008,0 1px 2px #00000005}.dark .project-card{box-shadow:0 1px 3px #00000026,0 1px 2px #0000001a}@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)}}.memories__subtitle{text-align:center;font-size:.9rem;color:var(--text-subtle);margin-bottom:1.25rem;font-family:var(--font-hand)}.photo-desk{display:flex;flex-wrap:wrap;justify-content:center;gap:0;padding:1.5rem 0 2rem}.polaroid{flex:0 0 auto;width:140px;background:var(--polaroid-bg);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,filter .35s ease,z-index 0s;margin-left:-18px;position:relative;z-index:1;cursor:pointer}.polaroid:before{content:"";position:absolute;top:-8px;left:50%;transform:translate(-50%) rotate(-1deg);width:32px;height:14px;background:#ffdc788c;border-radius:2px;box-shadow:0 1px 2px #0000000f;pointer-events:none;z-index:2}.polaroid:after{content:"";position:absolute;inset:0;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.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");opacity:.04;pointer-events:none;z-index:1;border-radius:3px}.polaroid:first-child{margin-left:0}.polaroid img{display:block;position:relative;width:100%;height:112px;object-fit:cover;border-radius:2px;background:#f3f4f6;z-index:1}.polaroid figcaption{position:relative;font-family:Caveat,Kalam,cursive;font-size:.95rem;color:#2d2416;text-align:center;margin-top:8px;line-height:1.2;transform:rotate(-1deg);text-shadow:0 1px 0 rgba(255,255,255,.5);z-index:1}.memories--visible .polaroid{opacity:0;animation:polaroidDrop .6s cubic-bezier(.34,1.56,.64,1) forwards;animation-delay:calc(.08s * var(--i, 0))}@keyframes polaroidDrop{0%{opacity:0;transform:rotate(var(--rotate, 0deg)) translateY(-20px) scale(.9)}to{opacity:1;transform:rotate(var(--rotate, 0deg)) translateY(0) scale(1)}}@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;filter:brightness(1.04) contrast(1.02);z-index:20;cursor:zoom-in}}@media (max-width: 640px){.photo-desk{padding:1rem 0 1.5rem}.polaroid{width:92px;margin-left:-14px;padding:5px 5px 16px}.polaroid:after{display:none}.polaroid img{height:72px}.polaroid figcaption{font-size:.8rem;margin-top:6px}}.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))}}@media (pointer: fine){html,body,a,button,[role=button],input,textarea,select{cursor:none}[data-cursor-crosshair=true]{cursor:crosshair!important}}.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}.inspector-overlay{position:fixed;inset: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:5rem;left:1.5rem;z-index:9999;padding:.45rem .85rem;background:var(--text-primary);color:var(--bg);border-radius:999px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:500;pointer-events:none;box-shadow:0 8px 24px #0000002e;animation:inspector-hint-in .3s cubic-bezier(.22,1,.36,1)}@keyframes inspector-hint-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.inspector-hint kbd{background:var(--bg);color:var(--text-primary);padding:.1rem .35rem;border-radius:4px;font-weight:700;margin-right:.15rem;box-shadow:inset 0 0 0 1px var(--border-strong)}@media (max-width: 640px){.inspector-hint{bottom:4.5rem;left:1rem;font-size:10px}}.loader{position:fixed;inset: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}.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!important;top:4.5rem!important;right:1.5rem!important;z-index:9999!important;display:flex;flex-direction:column;align-items:flex-end;gap:.5rem;pointer-events:none}@media (max-width: 640px){.toast-container{top:4rem!important;right:1rem!important}}.toast{padding:.6rem 1rem .6rem .85rem;background:var(--text-primary);color:var(--bg);border-radius:12px;font-size:13px;font-weight:500;display:flex;align-items:center;gap:.5rem;box-shadow:0 8px 24px #00000029,0 2px 8px #0000001a;min-width:180px;max-width:320px;pointer-events:auto}.toast-icon{width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0;color:#fff;line-height:1}.wh{margin-top:.75rem;margin-bottom:1.25rem}.wh__row{display:flex;align-items:center;gap:.35rem;padding:.5rem .75rem;width:fit-content;background:var(--surface);border:1px solid var(--border);border-radius:999px;line-height:1}.wh__digits{display:flex;align-items:center;gap:0;flex-shrink:0}.wh__digit-wrap{width:.9rem;height:1.35rem;overflow:hidden;position:relative;border-radius:3px}.wh__digit-strip{display:flex;flex-direction:column;align-items:center}.wh__digit{display:flex;align-items:center;justify-content:center;height:1.35rem;font-family:var(--font-mono);font-size:1.15rem;font-weight:700;color:var(--text);line-height:1.35rem}.wh__colon{font-family:var(--font-mono);font-size:1rem;font-weight:700;color:var(--text-subtle);margin:0 .05rem;animation:wh-blink 1s step-end infinite}@keyframes wh-blink{50%{opacity:.2}}.wh__dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.wh__status{font-weight:500;font-size:12px;white-space:nowrap;flex-shrink:0}.wh__sep{width:1px;height:16px;background:var(--border);flex-shrink:0}.wh__tz,.wh__date{font-family:var(--font-mono);font-size:10.5px;color:var(--text-subtle);white-space:nowrap}@media (max-width: 640px){.wh__tz{display:none}}.floating-controls{position:fixed;bottom:1.5rem;left:1.5rem;z-index:71;display:flex;flex-direction:column;padding:10px;border-radius:14px;background:var(--navbar-bg);border:1px solid var(--navbar-border);box-shadow:0 8px 32px #00000014,0 2px 8px #0000000a;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.floating-controls--active{border-color:color-mix(in srgb,var(--accent) 35%,var(--navbar-border))}.floating-controls__row{display:flex;align-items:center;gap:.45rem;width:100%;padding:.4rem .6rem;border:none;border-radius:8px;background:transparent;color:var(--text-muted);font-size:13px;line-height:1;font-family:inherit;cursor:pointer;transition:background .2s ease,color .2s ease}.floating-controls__row:hover{background:color-mix(in srgb,var(--text) 4%,transparent);color:var(--text)}.floating-controls__row--active{background:color-mix(in srgb,var(--accent) 8%,transparent);color:var(--accent)}.floating-controls__icon{font-size:16px;line-height:1;display:inline-flex}.floating-controls__label{font-weight:500}.floating-controls__divider{width:100%;height:1px;background:var(--border);margin:6px 0}.floating-controls__dots{display:flex;align-items:center;gap:6px;padding:.15rem .6rem .25rem}.floating-controls__dots .color-dot{width:20px;height:20px;border-radius:50%;border:2px solid transparent;background:var(--dot-color);cursor:pointer;transition:transform .2s ease,border-color .2s ease;padding:0}.floating-controls__dots .color-dot:hover{transform:scale(1.25)}.floating-controls__dots .color-dot--active{border-color:var(--text-primary);transform:scale(1.15)}@media (max-width: 640px){.floating-controls{bottom:1rem;left:1rem;padding:8px}.floating-controls__row{padding:.3rem .45rem;font-size:12.5px}.floating-controls__icon{font-size:14px}.floating-controls__dots{gap:4px;padding:.1rem .45rem .2rem}.floating-controls__dots .color-dot{width:18px;height:18px}}.command-palette__overlay{position:fixed;inset:0;z-index:95;display:flex;align-items:flex-start;justify-content:center;padding-top:16vh;background:#0000002e;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.dark .command-palette__overlay{background:#00000073}.command-palette{width:min(580px,calc(100vw - 2rem));background:var(--navbar-bg);border:1px solid var(--border-strong);border-radius:16px;box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 6%,transparent),0 8px 24px #00000014,0 32px 80px #00000029;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);overflow:hidden;transform-origin:top center}.dark .command-palette{box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 8%,transparent),0 8px 24px #0003,0 32px 80px #0006}.command-palette__input-wrapper{display:flex;align-items:center;gap:.65rem;padding:.9rem 1rem;border-bottom:1px solid var(--border)}.command-palette__input-wrapper>svg{color:var(--text-muted);flex-shrink:0;width:17px;height:17px}.command-palette__input{flex:1;min-width:0;border:none;background:transparent;color:var(--text);font-size:15px;font-weight:400;letter-spacing:-.01em;font-family:var(--font-sans);outline:none}.command-palette__input::placeholder{color:var(--text-subtle);opacity:.7}.command-palette__esc{padding:.25rem .55rem;background:color-mix(in srgb,var(--accent) 6%,var(--code-bg));border:1px solid color-mix(in srgb,var(--accent) 15%,var(--border));border-radius:7px;font-family:var(--font-sans);font-size:10.5px;font-weight:500;letter-spacing:.03em;color:var(--text-muted)}.command-palette__list{max-height:360px;overflow-y:auto;padding:.4rem .5rem .5rem}.command-palette__group-label{padding:.6rem .75rem .3rem;font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-subtle);font-family:var(--font-mono);user-select:none}.command-palette__group+.command-palette__group{border-top:1px solid var(--border);margin-top:.3rem;padding-top:.3rem}.command-palette__item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.6rem .75rem;border:none;border-radius:10px;background:transparent;color:var(--text);text-align:left;cursor:pointer;transition:background .1s ease}.command-palette__item:hover,.command-palette__item--selected{background:color-mix(in srgb,var(--accent) 7%,var(--surface))}.command-palette__item--selected{position:relative}.command-palette__item--selected:before{content:"";position:absolute;left:0;top:20%;height:60%;width:3px;border-radius:0 3px 3px 0;background:var(--accent)}.command-palette__icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;flex-shrink:0;border-radius:7px;background:transparent;border:1px solid transparent;color:var(--text-muted);transition:color .12s ease,background .12s ease,border-color .12s ease}.command-palette__item:hover .command-palette__icon,.command-palette__item--selected .command-palette__icon{color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent);border-color:color-mix(in srgb,var(--accent) 20%,transparent)}.command-palette__label{display:flex;flex-direction:column;gap:.1rem;flex:1;min-width:0;font-size:13.5px;font-weight:500}.command-palette__description{font-size:11.5px;font-weight:400;color:var(--text-subtle);opacity:.8}.command-palette__match{color:var(--accent);font-weight:600;background:color-mix(in srgb,var(--accent) 10%,transparent);border-radius:2px;padding:0 1px}.command-palette__shortcut{font-family:var(--font-sans);font-size:10.5px;font-weight:500;color:var(--text-subtle);padding:.2rem .5rem;background:color-mix(in srgb,var(--accent) 5%,var(--code-bg));border:1px solid var(--border-strong);border-radius:6px}.command-palette__empty{padding:2.5rem 2rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;font-size:13.5px;color:var(--text-subtle)}.command-palette__empty-icon{font-size:28px;opacity:.3;margin-bottom:.25rem}.command-palette__footer{display:flex;align-items:center;justify-content:flex-end;gap:1.25rem;padding:.55rem 1rem;border-top:1px solid var(--border);font-size:11px;color:var(--text-subtle);font-family:var(--font-sans)}.command-palette__footer kbd{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 4px;background:color-mix(in srgb,var(--accent) 5%,var(--code-bg));border:1px solid var(--border-strong);border-radius:4px;font-family:var(--font-sans);font-size:9.5px;font-weight:500}@media (max-width: 640px){.command-palette__overlay{padding-top:12vh;align-items:flex-start}.command-palette{width:calc(100vw - 1.5rem);border-radius:14px}.command-palette__input-wrapper{padding:.75rem .85rem}.command-palette__input{font-size:16px}.command-palette__list{max-height:55vh}.command-palette__footer{display:none}}
