/*! tailwindcss v4.2.2 | 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-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction: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-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-outline-style:solid}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-indigo-50:#efeff5;--color-indigo-100:#dfdfec;--color-indigo-200:#c0c0d8;--color-indigo-300:#a0a0c5;--color-indigo-400:#8181b1;--color-indigo-500:#61619e;--color-indigo-600:#4e4e7e;--color-indigo-700:#3a3a5f;--color-indigo-800:#27273f;--color-indigo-900:#131320;--color-indigo-950:#0e0e16;--color-white:#fff;--spacing:.25rem;--container-xs:20rem;--container-lg:32rem;--container-2xl:42rem;--container-7xl:80rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height:calc(1.5 / 1);--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--text-3xl:1.875rem;--text-3xl--line-height:calc(2.25 / 1.875);--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5 / 2.25);--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--font-weight-extrabold:800;--tracking-tight:-.025em;--tracking-wide:.025em;--tracking-widest:.1em;--leading-tight:1.25;--leading-snug:1.375;--leading-relaxed:1.625;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--animate-spin:spin 1s linear infinite;--blur-md:12px;--aspect-video:16 / 9;--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-brandy-200:#ecbdac;--color-brandy-300:#e29c83;--color-brandy-400:#d87b5a;--color-brandy-600:#a54827;--color-brandy-700:#7c361d;--color-brandy-800:#532413;--color-spruce-300:#b3c99c;--color-spruce-400:#99b77b;--color-spruce-700:#4d6336;--color-spruce-800:#334224;--color-error:var(--error);--color-surface:var(--surface);--color-raised:var(--raised);--color-foreground:var(--foreground);--color-muted:var(--muted);--color-faint:var(--faint);--color-accent:var(--accent);--color-accent-hover:var(--accent-hover);--color-highlight:var(--highlight);--color-divider:var(--divider);--color-code-string:var(--code-string);--color-code-function:var(--code-function);--color-sponsor:#bf3584;--color-sponsor-hover:#a52d72}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}:root{--surface:var(--color-indigo-50);--raised:#fff;--foreground:var(--color-indigo-950);--muted:var(--color-indigo-600);--faint:var(--color-indigo-400);--accent:var(--color-spruce-700);--accent-hover:var(--color-spruce-800);--highlight:var(--color-brandy-600);--divider:var(--color-indigo-200);--code-string:var(--color-brandy-700);--code-function:#2656a8;--error:#b91c1c;--color-shadow:#4f46e514;--color-text-on-primary:#fff;--color-text-light:#fff;--color-disabled:#9ca3af;--color-btn-github:#24292e;--color-btn-github-hover:#1a1e22;--color-btn-npm:#cb3837;--color-btn-npm-hover:#ab2e2d;--color-btn-gpt:#10a37f;--color-btn-gpt-hover:#0d8c6d;--color-btn-app:#1d4ed8;--color-btn-app-hover:#1e40af;--space-2xs:.25rem;--space-xs:.5rem;--space-sm:1rem;--space-md:1.5rem;--space-lg:2rem;--space-xl:3rem;--space-2xl:4rem;--font-size-2xs:.625rem;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-base:1rem;--font-size-md:1.125rem;--font-size-lg:1.25rem;--font-size-xl:1.5rem;--font-size-2xl:2rem;--font-size-3xl:2.5rem;--radius-sm:.25rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-full:9999px;--transition-fast:.2s ease;--transition-base:.3s ease;--card-bg:var(--raised);--card-radius:var(--radius-lg);--card-shadow:none;--card-border:1px solid var(--divider);--card-border-hover:1px solid var(--accent);--card-transition:border-color var(--transition-fast), background-color var(--transition-fast);--card-transform-hover:none;--card-shadow-hover:none;--color-cta-text:#fff;--color-cta-text-secondary:#ffffffe6;--color-cta-border:transparent;--color-cta-btn-border:white}@media (prefers-color-scheme:dark){:root{--surface:var(--color-indigo-950);--raised:var(--color-indigo-900);--foreground:var(--color-indigo-50);--muted:var(--color-indigo-300);--faint:var(--color-indigo-500);--accent:var(--color-spruce-400);--accent-hover:var(--color-spruce-300);--highlight:var(--color-brandy-400);--divider:var(--color-indigo-800);--code-string:var(--color-brandy-300);--code-function:#7cb3e0;--error:#f87171;--card-border:1px solid var(--color-indigo-700);--card-border-hover:1px solid var(--accent);--color-shadow:#0000;--color-text-on-primary:#000;--color-btn-app-hover:#3b82f6;--color-btn-gpt-hover:#34d399;--cta-bg-color:var(--color-spruce-700);--color-cta-text-secondary:#fffffff2;--color-cta-border:#fff3;--color-cta-btn-border:#fffc}}html{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark}@media (prefers-color-scheme:dark){html{--lightningcss-light: ;--lightningcss-dark:initial}}body{background-color:var(--color-surface);color:var(--color-foreground);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-width:320px;min-height:100vh;margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}::selection{background-color:var(--color-brandy-200);color:var(--color-indigo-900)}@media (prefers-color-scheme:dark){::selection{background-color:var(--color-brandy-800);color:var(--color-indigo-50)}}@keyframes bounce{0%,80%,to{opacity:.5;transform:scale(0)}40%{opacity:1;transform:scale(1)}}@keyframes fadeInOut{0%{opacity:.6}to{opacity:1}}a{color:var(--color-accent);transition:color var(--transition-fast);text-decoration:none}a:hover,a:focus{color:var(--color-accent-hover)}a:focus{outline:2px solid var(--color-accent);outline-offset:2px}}@layer components;@layer utilities{.pointer-events-auto{pointer-events:auto}.pointer-events-none{pointer-events:none}.invisible{visibility:hidden}.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.inset-0{inset:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.top-0{top:calc(var(--spacing) * 0)}.bottom-\[-2px\]{bottom:-2px}.left-0{left:calc(var(--spacing) * 0)}.z-\[100\]{z-index:100}.z-\[105\]{z-index:105}.z-\[110\]{z-index:110}.m-0{margin:calc(var(--spacing) * 0)}.mx-auto{margin-inline:auto}.my-4{margin-block:calc(var(--spacing) * 4)}.my-6{margin-block:calc(var(--spacing) * 6)}.my-8{margin-block:calc(var(--spacing) * 8)}.my-12{margin-block:calc(var(--spacing) * 12)}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mt-16{margin-top:calc(var(--spacing) * 16)}.mt-auto{margin-top:auto}.mr-1{margin-right:calc(var(--spacing) * 1)}.mb-0{margin-bottom:calc(var(--spacing) * 0)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.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)}.ml-1{margin-left:calc(var(--spacing) * 1)}.ml-2{margin-left:calc(var(--spacing) * 2)}.ml-8{margin-left:calc(var(--spacing) * 8)}.ml-16{margin-left:calc(var(--spacing) * 16)}.line-clamp-1{-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.aspect-\[2\/1\]{aspect-ratio:2}.aspect-video{aspect-ratio:var(--aspect-video)}.h-0\.5{height:calc(var(--spacing) * .5)}.h-1{height:calc(var(--spacing) * 1)}.h-2\.5{height:calc(var(--spacing) * 2.5)}.h-3{height:calc(var(--spacing) * 3)}.h-4{height:calc(var(--spacing) * 4)}.h-5{height:calc(var(--spacing) * 5)}.h-8{height:calc(var(--spacing) * 8)}.h-10{height:calc(var(--spacing) * 10)}.h-11{height:calc(var(--spacing) * 11)}.h-12{height:calc(var(--spacing) * 12)}.h-\[100px\]{height:100px}.h-auto{height:auto}.h-full{height:100%}.min-h-\[70vh\]{min-height:70vh}.min-h-svh{min-height:100svh}.w-0{width:calc(var(--spacing) * 0)}.w-2\.5{width:calc(var(--spacing) * 2.5)}.w-3{width:calc(var(--spacing) * 3)}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.w-7{width:calc(var(--spacing) * 7)}.w-8{width:calc(var(--spacing) * 8)}.w-10{width:calc(var(--spacing) * 10)}.w-11{width:calc(var(--spacing) * 11)}.w-12{width:calc(var(--spacing) * 12)}.w-\[60px\]{width:60px}.w-\[100px\]{width:100px}.w-full{width:100%}.max-w-2xl{max-width:var(--container-2xl)}.max-w-7xl{max-width:var(--container-7xl)}.max-w-\[500px\]{max-width:500px}.max-w-\[520px\]{max-width:520px}.max-w-\[550px\]{max-width:550px}.max-w-\[740px\]{max-width:740px}.max-w-\[800px\]{max-width:800px}.max-w-full{max-width:100%}.max-w-lg{max-width:var(--container-lg)}.max-w-xs{max-width:var(--container-xs)}.flex-1{flex:1}.shrink-0{flex-shrink:0}.grow{flex-grow:1}.origin-center{transform-origin:50%}.-translate-y-\[9px\]{--tw-translate-y:calc(9px * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.-translate-y-full{--tw-translate-y:-100%;translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-y-0{--tw-translate-y:calc(var(--spacing) * 0);translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-y-\[9px\]{--tw-translate-y:9px;translate:var(--tw-translate-x) var(--tw-translate-y)}.-rotate-45{rotate:-45deg}.rotate-45{rotate:45deg}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-spin{animation:var(--animate-spin)}.cursor-pointer{cursor:pointer}.list-none{list-style-type:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-\[1\.2fr_1fr\]{grid-template-columns:1.2fr 1fr}.grid-cols-\[repeat\(auto-fill\,minmax\(280px\,1fr\)\)\]{grid-template-columns:repeat(auto-fill,minmax(280px,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}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-1{gap:calc(var(--spacing) * 1)}.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-5{gap:calc(var(--spacing) * 5)}.gap-6{gap:calc(var(--spacing) * 6)}.gap-8{gap:calc(var(--spacing) * 8)}.gap-10{gap:calc(var(--spacing) * 10)}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.rounded-\[2rem\]{border-radius:2rem}.rounded-\[calc\(0\.75rem-1px\)\]{border-radius:calc(.75rem - 1px)}.rounded-\[var\(--card-radius\)\]{border-radius:var(--card-radius)}.rounded-\[var\(--radius-md\)\]{border-radius:var(--radius-md)}.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)}.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-none{--tw-border-style:none;border-style:none}.border-divider{border-color:var(--color-divider)}.border-error\/25{border-color:var(--color-error)}@supports (color:color-mix(in lab, red, red)){.border-error\/25{border-color:color-mix(in oklab, var(--color-error) 25%, transparent)}}.bg-accent,.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-error\/10{background-color:var(--color-error)}@supports (color:color-mix(in lab, red, red)){.bg-error\/10{background-color:color-mix(in oklab, var(--color-error) 10%, transparent)}}.bg-foreground{background-color:var(--color-foreground)}.bg-raised{background-color:var(--color-raised)}.bg-sponsor{background-color:var(--color-sponsor)}.bg-surface,.bg-surface\/85{background-color:var(--color-surface)}@supports (color:color-mix(in lab, red, red)){.bg-surface\/85{background-color:color-mix(in oklab, var(--color-surface) 85%, transparent)}}.bg-transparent{background-color:#0000}.bg-gradient-to-br{--tw-gradient-position:to bottom right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.from-accent{--tw-gradient-from:var(--color-accent);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-accent\/10{--tw-gradient-from:var(--color-accent)}@supports (color:color-mix(in lab, red, red)){.from-accent\/10{--tw-gradient-from:color-mix(in oklab, var(--color-accent) 10%, transparent)}}.from-accent\/10{--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-foreground{--tw-gradient-from:var(--color-foreground);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-accent{--tw-gradient-to:var(--color-accent);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-highlight{--tw-gradient-to:var(--color-highlight);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-transparent{--tw-gradient-to:transparent;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.bg-clip-text{-webkit-background-clip:text;background-clip:text}.object-cover{object-fit:cover}.p-0{padding:calc(var(--spacing) * 0)}.p-4{padding:calc(var(--spacing) * 4)}.p-6{padding:calc(var(--spacing) * 6)}.p-10{padding:calc(var(--spacing) * 10)}.p-px{padding:1px}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.px-3\.5{padding-inline:calc(var(--spacing) * 3.5)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-6{padding-inline:calc(var(--spacing) * 6)}.px-8{padding-inline:calc(var(--spacing) * 8)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2\.5{padding-block:calc(var(--spacing) * 2.5)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-3\.5{padding-block:calc(var(--spacing) * 3.5)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-10{padding-block:calc(var(--spacing) * 10)}.py-12{padding-block:calc(var(--spacing) * 12)}.py-16{padding-block:calc(var(--spacing) * 16)}.pt-1{padding-top:calc(var(--spacing) * 1)}.pt-4{padding-top:calc(var(--spacing) * 4)}.pt-8{padding-top:calc(var(--spacing) * 8)}.pb-2{padding-bottom:calc(var(--spacing) * 2)}.pb-4{padding-bottom:calc(var(--spacing) * 4)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.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-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-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-\[0\.95rem\]{font-size:.95rem}.text-\[3rem\]{font-size:3rem}.text-\[clamp\(1\.75rem\,4\.5vw\,3rem\)\]{font-size:clamp(1.75rem,4.5vw,3rem)}.leading-none{--tw-leading:1;line-height:1}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.leading-snug{--tw-leading:var(--leading-snug);line-height:var(--leading-snug)}.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-extrabold{--tw-font-weight:var(--font-weight-extrabold);font-weight:var(--font-weight-extrabold)}.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-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.tracking-wide{--tw-tracking:var(--tracking-wide);letter-spacing:var(--tracking-wide)}.tracking-widest{--tw-tracking:var(--tracking-widest);letter-spacing:var(--tracking-widest)}.text-\[var\(--detail-accent-color\)\]{color:var(--detail-accent-color)}.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-code-function{color:var(--color-code-function)}.text-code-string{color:var(--color-code-string)}.text-error{color:var(--color-error)}.text-foreground{color:var(--color-foreground)}.text-highlight{color:var(--color-highlight)}.text-muted,.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-transparent{color:#0000}.text-white{color:var(--color-white)}.uppercase{text-transform:uppercase}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.no-underline{text-decoration-line:none}.opacity-0{opacity:0}.opacity-25{opacity:.25}.opacity-75{opacity:.75}.opacity-100{opacity:1}.shadow-md{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring-4{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(4px + 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)}.ring-accent\/25{--tw-ring-color:var(--color-accent)}@supports (color:color-mix(in lab, red, red)){.ring-accent\/25{--tw-ring-color:color-mix(in oklab, var(--color-accent) 25%, transparent)}}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.backdrop-blur-md{--tw-backdrop-blur:blur(var(--blur-md));-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition-\[gap\]{transition-property:gap;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-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-150{--tw-duration:.15s;transition-duration:.15s}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.\[image-rendering\:pixelated\]{image-rendering:pixelated}@media (hover:hover){.group-hover\:w-full:is(:where(.group):hover *){width:100%}.group-hover\:gap-2:is(:where(.group):hover *){gap:calc(var(--spacing) * 2)}.group-hover\:text-accent:is(:where(.group):hover *){color:var(--color-accent)}.hover\:-translate-x-1:hover{--tw-translate-x:calc(var(--spacing) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.hover\:-translate-y-0\.5:hover{--tw-translate-y:calc(var(--spacing) * -.5);translate:var(--tw-translate-x) var(--tw-translate-y)}.hover\:translate-y-\[-1px\]:hover{--tw-translate-y:-1px;translate:var(--tw-translate-x) var(--tw-translate-y)}.hover\:scale-105:hover{--tw-scale-x:105%;--tw-scale-y:105%;--tw-scale-z:105%;scale:var(--tw-scale-x) var(--tw-scale-y)}.hover\:border-accent:hover{border-color:var(--color-accent)}.hover\:bg-accent\/25:hover{background-color:var(--color-accent)}@supports (color:color-mix(in lab, red, red)){.hover\:bg-accent\/25:hover{background-color:color-mix(in oklab, var(--color-accent) 25%, transparent)}}.hover\:bg-sponsor-hover:hover{background-color:var(--color-sponsor-hover)}.hover\:text-accent:hover{color:var(--color-accent)}.hover\:text-accent-hover:hover{color:var(--color-accent-hover)}.hover\:underline:hover{text-decoration-line:underline}.hover\:shadow-md: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)}}.focus\:not-sr-only:focus{clip-path:none;white-space:normal;width:auto;height:auto;margin:0;padding:0;position:static;overflow:visible}.focus\:fixed:focus{position:fixed}.focus\:top-2:focus{top:calc(var(--spacing) * 2)}.focus\:left-2:focus{left:calc(var(--spacing) * 2)}.focus\:z-\[200\]:focus{z-index:200}.focus\:rounded-md:focus{border-radius:var(--radius-md)}.focus\:bg-surface:focus{background-color:var(--color-surface)}.focus\:px-4:focus{padding-inline:calc(var(--spacing) * 4)}.focus\:py-2:focus{padding-block:calc(var(--spacing) * 2)}.focus\:text-accent:focus{color:var(--color-accent)}.focus\:text-accent-hover:focus{color:var(--color-accent-hover)}.focus\:underline:focus{text-decoration-line:underline}.focus\:outline:focus{outline-style:var(--tw-outline-style);outline-width:1px}.focus\:outline-2:focus{outline-style:var(--tw-outline-style);outline-width:2px}.focus\:outline-accent:focus{outline-color:var(--color-accent)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.focus-visible\:outline-2:focus-visible{outline-style:var(--tw-outline-style);outline-width:2px}.focus-visible\:outline-offset-2:focus-visible{outline-offset:2px}.focus-visible\:outline-accent:focus-visible{outline-color:var(--color-accent)}@media not all and (width>=680px){.max-\[680px\]\:block{display:block}.max-\[680px\]\:hidden{display:none}}@media not all and (width>=48rem){.max-md\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}}@media (width>=40rem){.sm\:aspect-\[3\/1\]{aspect-ratio:3}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:flex-wrap{flex-wrap:wrap}.sm\:px-4{padding-inline:calc(var(--spacing) * 4)}.sm\:text-\[4rem\]{font-size:4rem}}@media (width>=48rem){.md\:block{display:block}.md\:hidden{display:none}.md\:flex-col{flex-direction:column}.md\:gap-2{gap:calc(var(--spacing) * 2)}.md\:text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.md\:text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.md\:text-\[6rem\]{font-size:6rem}}@media (width>=64rem){.lg\:h-\[125px\]{height:125px}.lg\:w-\[125px\]{width:125px}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.lg\:text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}}.\[\&\>svg\]\:h-full>svg{height:100%}.\[\&\>svg\]\:w-full>svg{width:100%}}.heading-underline{padding-bottom:var(--space-xs);position:relative}@media (forced-colors:active){.bg-clip-text{-webkit-background-clip:unset;background-clip:unset;color:canvastext}}.heading-underline:after{content:"";background-color:var(--heading-underline-color,var(--color-accent));width:60px;height:3px;position:absolute;bottom:0;left:0}.heading-underline-centered:after{left:50%;transform:translate(-50%)}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"<length-percentage>";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"<length-percentage>";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"<length-percentage>";inherits:false;initial-value:100%}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{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-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@keyframes spin{to{transform:rotate(360deg)}}.btn{border-radius:var(--radius-md);font-family:inherit;font-weight:500;font-size:inherit;transition:all var(--transition-fast);cursor:pointer;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;line-height:1.2;text-decoration:none;display:inline-flex;position:relative}.btn:focus{box-shadow:0 0 0 3px color-mix(in srgb, var(--color-accent) 40%, transparent);outline:none}.btn:disabled,.btn[aria-disabled=true]{cursor:not-allowed;opacity:.65;box-shadow:none;transform:none}.btn-primary{background-color:var(--color-accent);color:var(--color-text-on-primary,white);border:none;font-weight:600}.btn-primary:hover{background-color:var(--color-accent-hover);box-shadow:0 3px 8px var(--color-shadow);color:var(--color-text-on-primary);transform:translateY(-1px)}.btn-secondary{border:2px solid var(--color-accent);color:var(--color-accent);background-color:#0000;font-weight:600}.btn-secondary:hover{background-color:color-mix(in srgb, var(--color-accent) 8%, transparent);transform:translateY(-2px)}.btn-sponsor{border:2px solid var(--color-sponsor);color:var(--color-sponsor);background-color:#0000;font-weight:600}.btn-sponsor:hover{background-color:color-mix(in srgb, var(--color-sponsor) 10%, transparent);transform:translateY(-2px)}.btn-github{background-color:var(--color-btn-github);color:var(--color-text-light);border:none}.btn-github:hover{background-color:var(--color-btn-github-hover);color:var(--color-text-light);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.btn-live{background-color:var(--color-accent);color:#fff;border:none}.btn-live:hover{background-color:var(--color-accent-hover);color:#fff;box-shadow:0 4px 12px var(--color-shadow);transform:translateY(-2px)}.btn-npm{background-color:var(--color-btn-npm);color:var(--color-text-light);border:none}.btn-npm:hover{background-color:var(--color-btn-npm-hover);transform:translateY(-2px);box-shadow:0 4px 12px #cb383740}.btn-gpt{background-color:var(--color-btn-gpt);color:var(--color-text-light);border:none}.btn-gpt:hover{background-color:var(--color-btn-gpt-hover);transform:translateY(-2px);box-shadow:0 4px 12px #10a37f40}.btn-mobile,.btn-desktop{background-color:var(--color-btn-app);color:var(--color-text-light);border:none;box-shadow:0 2px 4px #0000001a}.btn-mobile:hover,.btn-desktop:hover{background-color:var(--color-btn-app-hover);transform:translateY(-2px);box-shadow:0 4px 12px #0003}.section-title{font-size:var(--font-size-2xl);margin-bottom:var(--space-lg);color:var(--color-foreground);text-align:center}@media (width<=768px){.section-title{font-size:var(--font-size-xl);margin-bottom:var(--space-md)}}@media (width<=480px){.btn{min-height:2.75rem;font-size:var(--font-size-sm);padding:.6rem 1.2rem}}.tech-tag,.tech-badge{background-color:color-mix(in srgb, var(--color-accent) 10%, transparent);border:1px solid color-mix(in srgb, var(--color-accent) 25%, transparent);border-radius:var(--radius-full);font-size:var(--font-size-sm);color:var(--color-accent);padding:.25rem .75rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-block}.tech-tag:hover,.tech-badge:hover{background-color:color-mix(in srgb, var(--color-accent) 20%, transparent);border-color:var(--color-accent);text-decoration:underline}.skill-tag{background-color:var(--color-raised);border:1px solid var(--color-divider);border-radius:var(--radius-full);font-size:var(--font-size-sm);color:var(--color-foreground);padding:.25rem .75rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-block}.skill-tag:hover{background-color:var(--color-accent-hover);color:var(--color-surface);border-color:#0000;transform:translateY(-1px);box-shadow:0 2px 6px #0000001a}@media (prefers-color-scheme:dark){.tech-tag,.tech-badge{background-color:color-mix(in srgb, var(--color-accent) 20%, transparent);color:var(--color-indigo-100)}.tech-tag:hover,.tech-badge:hover{background-color:color-mix(in srgb, var(--color-accent) 30%, transparent)}}.error-boundary{flex:1;justify-content:center;align-items:center;padding:4rem 1.5rem;display:flex}.error-boundary-card{background:var(--color-raised);border:1px solid var(--color-divider);border-radius:.75rem;width:100%;max-width:36rem;padding:2.5rem}.error-boundary-eyebrow{letter-spacing:.2em;text-transform:uppercase;color:var(--color-error);margin:0 0 .5rem;font-size:.75rem;font-weight:700}.error-boundary-title{color:var(--color-foreground);margin:0 0 .75rem;font-size:1.75rem;font-weight:700;line-height:1.2}.error-boundary-message{color:var(--color-muted);margin:0 0 1.5rem;font-size:1rem;line-height:1.55}.error-boundary-actions{flex-wrap:wrap;gap:.75rem;display:flex}.error-boundary-btn{color:var(--color-foreground);border:1px solid var(--color-divider);cursor:pointer;background:0 0;border-radius:.5rem;padding:.625rem 1.25rem;font-size:.9375rem;font-weight:600;transition:background-color .15s,border-color .15s,color .15s}.error-boundary-btn:hover{border-color:var(--color-accent);color:var(--color-accent)}.error-boundary-btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.error-boundary-btn--primary{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.error-boundary-btn--primary:hover{background:var(--color-accent-hover);border-color:var(--color-accent-hover);color:#fff}.error-boundary-details{border-top:1px solid var(--color-divider);color:var(--color-muted);margin-top:1.75rem;padding-top:1.25rem;font-size:.875rem}.error-boundary-details summary{cursor:pointer;color:var(--color-foreground);font-weight:600}.error-boundary-stack{background:var(--color-surface);border:1px solid var(--color-divider);max-height:16rem;color:var(--color-foreground);white-space:pre-wrap;word-break:break-word;border-radius:.375rem;margin:.75rem 0 0;padding:.875rem 1rem;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.8125rem;line-height:1.5;overflow:auto}.route-fallback{flex:1;justify-content:center;align-items:center;min-height:40vh;padding:4rem 1.5rem;display:flex}.route-fallback-spinner{border:3px solid color-mix(in srgb, var(--color-accent) 20%, transparent);border-top-color:var(--color-accent);border-radius:9999px;width:2rem;height:2rem;animation:.8s linear infinite route-fallback-spin}@keyframes route-fallback-spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion:reduce){.route-fallback-spinner{border-top-color:var(--color-accent);border-right-color:var(--color-accent);animation:none}}.project-card{border-radius:var(--card-radius);background-color:var(--card-bg);border:var(--card-border);transition:var(--card-transition);flex-direction:column;height:100%;display:flex;overflow:hidden}.project-card-link{color:inherit;text-decoration:none}.project-card-link:hover{text-decoration:underline}.project-card:hover{border:var(--card-border-hover)}.project-card-minimal .project-info{padding:var(--space-md)}.project-card-featured{flex-direction:row;height:auto}.project-card-featured .project-image-container{aspect-ratio:4/3;flex-shrink:0;width:45%;position:relative;overflow:hidden}.project-card-featured .project-info{padding:var(--space-lg);border-top:none;flex-direction:column;justify-content:center;display:flex}.project-card-featured .project-title{font-size:var(--font-size-xl);margin-bottom:var(--space-xs)}.project-card-featured .project-subtitle{margin-bottom:var(--space-sm)}.project-card-featured .project-description{font-size:var(--font-size-sm);color:var(--color-muted);margin-bottom:var(--space-md);-webkit-line-clamp:3;-webkit-box-orient:vertical;line-height:1.6;display:-webkit-box;overflow:hidden}@media (width<=540px){.project-card-featured{flex-direction:column}.project-card-featured .project-image-container{aspect-ratio:16/9;width:100%}.project-card-featured .project-info{padding:var(--space-md)}}.project-card-regular{flex-direction:column;position:relative}.project-card-regular:hover{border-color:var(--project-accent,var(--color-accent))}.pc-thumbnail-container{z-index:2;flex-shrink:0;display:none;position:relative;overflow:hidden}.pc-thumbnail{object-fit:cover;width:100%;height:100%;transition:transform .4s cubic-bezier(.165,.84,.44,1);display:block}.project-card-regular:hover .pc-thumbnail{transform:scale(1.04)}@media (width>=540px){.pc-thumbnail-container{aspect-ratio:16/9;display:block}.pc-thumbnail-container+.pc-accent-bar{border-radius:0}}.pc-accent-bar{background:var(--project-accent,var(--color-accent));border-radius:var(--card-radius) var(--card-radius) 0 0;flex-shrink:0;height:3px}.pc-body{padding:var(--space-md) var(--space-lg);gap:var(--space-sm);flex-direction:column;flex:1;display:flex}.pc-meta-line{text-transform:uppercase;letter-spacing:.06em;color:var(--color-muted);align-items:center;gap:.5rem;min-height:1.2em;font-size:.7rem;font-weight:600;display:flex}.pc-meta-category{color:var(--project-accent,var(--color-accent))}.pc-meta-category+.pc-meta-date:before{content:"•";color:var(--color-divider);margin-right:.5rem}.pc-meta-date{color:var(--color-muted)}.pc-icon-overlay{z-index:3;border-radius:var(--radius-md);background:var(--project-accent,var(--color-accent));color:#fff;width:2.25rem;height:2.25rem;box-shadow:0 4px 12px color-mix(in srgb, var(--project-accent,var(--color-accent)) 40%, #000 40%);justify-content:center;align-items:center;font-size:1rem;transition:transform .25s,box-shadow .25s;display:flex;position:absolute;bottom:.625rem;left:.625rem}.project-card-regular:hover .pc-icon-overlay{transform:scale(1.06)}.pc-inline-strip{align-items:center;gap:.5rem;margin-bottom:.25rem;display:flex}.pc-icon-inline{border-radius:var(--radius-md);background:var(--project-accent,var(--color-accent));color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:.9rem;display:inline-flex}.pc-inline-badge{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:1.5rem;height:1.5rem;font-size:.7rem;display:inline-flex}.pc-inline-badge--featured{background:var(--color-accent);color:var(--color-text-on-primary,white)}.pc-inline-badge--archived{background:var(--color-raised);border:1px solid var(--color-divider);color:var(--color-muted)}@media (width>=540px){.pc-inline-strip:not(.pc-inline-strip--always){display:none}}.pc-archived-badge{z-index:3;background:var(--color-raised);border:1px solid var(--color-divider);width:1.75rem;height:1.75rem;color:var(--color-muted);border-radius:50%;justify-content:center;align-items:center;font-size:.8rem;display:flex;position:absolute;top:.5rem;right:.5rem;box-shadow:0 2px 6px #0003}.pc-thumbnail-container--archived .pc-thumbnail{filter:grayscale(55%);transition:transform .4s cubic-bezier(.165,.84,.44,1),filter .3s}.pc-thumbnail-container--archived:hover .pc-thumbnail{filter:grayscale(20%)}.project-card-regular .project-card-link:after{content:"";z-index:1;position:absolute;inset:0}.project-card-regular .project-tech a{z-index:2;position:relative}.project-card-regular .project-subtitle{color:var(--color-muted);font-size:var(--font-size-sm);line-height:1.5}@media (width<=680px){.project-card-regular .pc-body{padding:var(--space-sm) var(--space-md)}}.project-icon-badge{z-index:3;border-radius:var(--radius-md);background:var(--color-surface);border:1px solid var(--color-divider);width:2rem;height:2rem;color:var(--color-accent);justify-content:center;align-items:center;font-size:.9rem;display:flex;position:absolute;bottom:.5rem;right:.5rem;box-shadow:0 2px 6px #00000026}.featured-star{z-index:3;background:var(--color-accent);width:1.75rem;height:1.75rem;color:var(--color-text-on-primary,white);border-radius:50%;justify-content:center;align-items:center;font-size:.8rem;display:flex;position:absolute;top:.5rem;left:.5rem;box-shadow:0 2px 6px #0003}.project-image{object-fit:cover;width:100%;height:100%;transition:transform .5s cubic-bezier(.165,.84,.44,1)}.project-card:hover .project-image{transform:scale(1.03)}.project-image-container:after,.pc-thumbnail-container:after{content:"View Project →";color:#fff;font-size:var(--font-size-sm);letter-spacing:.025em;opacity:0;pointer-events:none;z-index:2;background:#00000080;justify-content:center;align-items:center;font-weight:600;transition:opacity .2s;display:flex;position:absolute;inset:0}.project-image-container:hover:after,.pc-thumbnail-container:hover:after{opacity:1}.project-view-link{font-size:var(--font-size-sm);color:var(--color-accent);border:1px solid var(--color-accent);border-radius:var(--radius-full,9999px);align-items:center;gap:.375rem;width:fit-content;margin-top:auto;padding:.375rem .75rem;font-weight:600;text-decoration:none;transition:gap .2s,background-color .2s,color .2s;display:inline-flex}.project-view-link:hover{background-color:var(--color-accent);color:var(--color-surface,#fff);gap:.625rem}.project-info{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-divider);flex-direction:column;flex:1;display:flex}.project-title{font-size:var(--font-size-lg);margin-bottom:var(--space-xs);color:var(--color-foreground);font-weight:600;line-height:1.3}.project-subtitle{font-size:var(--font-size-base);color:var(--color-muted);margin-bottom:var(--space-md);line-height:1.5}.project-tech{gap:var(--space-xs);flex-wrap:wrap;display:flex}.project-tech+.project-view-link{margin-top:var(--space-md)}.tech-row+.tech-row{margin-top:6px}.skill-tag-more{background-color:color-mix(in srgb, var(--color-accent) 4%, transparent);color:var(--color-muted);border:1px solid var(--color-divider)}.project-tech a.tech-tag{z-index:5;text-decoration:none;position:relative}.featured-grid{grid-template-columns:1fr;gap:1rem;display:grid}@media (width>=1024px){.featured-grid{grid-template-columns:1fr 1fr}.featured-grid>:first-child{grid-column:1/-1}}.project-grid{grid-template-columns:repeat(auto-fill,minmax(max(280px,33.3333% - .833333rem),1fr));align-content:start;gap:1.25rem;display:grid}@media (width<=680px){.project-grid{grid-template-columns:1fr}}.filter-btn{background-color:var(--color-raised);border:1px solid var(--color-divider);border-radius:var(--radius-full);font-size:var(--font-size-sm);color:var(--color-foreground);cursor:pointer;padding:.5rem 1.25rem;font-weight:600;transition:all .2s}.filter-btn:hover:not(:disabled):not(.active){border-color:var(--color-accent);color:var(--color-accent);transform:translateY(-1px);box-shadow:0 2px 6px #00000014}.filter-btn:disabled{opacity:.7;cursor:not-allowed;color:var(--color-disabled,#9ca3af)}.filter-btn.active{background-color:var(--color-accent);border-color:var(--color-accent);color:var(--color-text-on-primary,white);box-shadow:0 3px 8px color-mix(in srgb, var(--color-accent) 25%, transparent)}.filter-select{appearance:none;background-color:var(--color-raised);width:100%;max-width:720px;color:var(--color-foreground);border:1px solid var(--color-divider);border-radius:var(--radius-md);font-size:var(--font-size-sm);background-image:linear-gradient(45deg, transparent 50%, var(--color-foreground) 50%), linear-gradient(135deg, var(--color-foreground) 50%, transparent 50%);background-position:calc(100% - 18px),calc(100% - 12px);background-repeat:no-repeat;background-size:6px 6px,6px 6px;padding:.6rem 2.25rem .6rem .9rem;line-height:1.2}.filter-select:focus{outline:2px solid var(--color-accent);outline-offset:2px;box-shadow:0 0 0 3px color-mix(in oklab, var(--color-accent) 20%, transparent)}.archived-section{margin-top:var(--space-2xl);padding-top:var(--space-xl);border-top:1px solid var(--color-divider)}.archived-toggle{cursor:pointer;font-size:var(--font-size-sm);color:var(--color-muted);background:0 0;border:none;align-items:center;gap:.5rem;padding:.25rem 0;font-weight:600;transition:color .2s;display:inline-flex}.archived-toggle:hover{color:var(--color-foreground)}.archived-count{border-radius:var(--radius-full);background:var(--color-divider);min-width:1.25rem;height:1.25rem;color:var(--color-muted);font-size:var(--font-size-xs);justify-content:center;align-items:center;padding:0 .375rem;font-weight:600;line-height:1;display:inline-flex}.archived-chevron{font-size:.7em;transition:transform .2s}.archived-chevron.open{transform:rotate(180deg)}.archived-grid{margin-top:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(max(280px,33.3333% - .833333rem),1fr));gap:1.25rem;display:grid}@media (width<=680px){.archived-grid{grid-template-columns:1fr}}
