/*! tailwindcss v4.2.4 | 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-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-animation-delay:0s;--tw-animation-direction:normal;--tw-animation-duration:initial;--tw-animation-fill-mode:none;--tw-animation-iteration-count:1;--tw-enter-blur:0;--tw-enter-opacity:1;--tw-enter-rotate:0;--tw-enter-scale:1;--tw-enter-translate-x:0;--tw-enter-translate-y:0;--tw-exit-blur:0;--tw-exit-opacity:1;--tw-exit-rotate:0;--tw-exit-scale:1;--tw-exit-translate-x:0;--tw-exit-translate-y:0}}}@layer theme{:root,:host{--font-mono:Fira Code, monospace;--color-red-500:oklch(63.7% .237 25.331);--color-indigo-600:oklch(51.1% .262 276.966);--color-indigo-800:oklch(39.8% .195 277.366);--color-gray-950:oklch(13% .028 261.692);--color-white:#fff;--spacing:var(--spacing);--container-md:28rem;--container-2xl:42rem;--container-4xl:56rem;--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;--tracking-normal:var(--tracking-normal);--leading-relaxed:1.625;--shadow-2xs:var(--shadow-2xs);--shadow-xs:var(--shadow-xs);--shadow-sm:var(--shadow-sm);--shadow-md:var(--shadow-md);--shadow-lg:var(--shadow-lg);--shadow-xl:var(--shadow-xl);--shadow-2xl:var(--shadow-2xl);--animate-spin:spin 1s linear infinite;--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:Outfit, sans-serif;--default-mono-font-family:Fira Code, monospace;--shadow:var(--shadow);--radius:.5rem;--letter-spacing:var(--letter-spacing);--shadow-offset-y:var(--shadow-offset-y);--shadow-offset-x:var(--shadow-offset-x);--shadow-spread:var(--shadow-spread);--shadow-blur:var(--shadow-blur);--shadow-opacity:var(--shadow-opacity)}}@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}*{border-color:var(--border);outline-color:var(--ring)}@supports (color:color-mix(in lab, red, red)){*{outline-color:color-mix(in oklab, var(--ring) 50%, transparent)}}body{background-color:var(--background);color:var(--foreground);letter-spacing:var(--tracking-normal)}}@layer components;@layer utilities{.\@container\/card-header{container:card-header/inline-size}.pointer-events-none{pointer-events:none}.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}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.left-2{left:calc(var(--spacing) * 2)}.z-50{z-index:50}.col-start-2{grid-column-start:2}.row-span-2{grid-row:span 2/span 2}.row-start-1{grid-row-start:1}.container{width:100%}@media (width>=40rem){.container{max-width:40rem}}@media (width>=48rem){.container{max-width:48rem}}@media (width>=64rem){.container{max-width:64rem}}@media (width>=80rem){.container{max-width:80rem}}@media (width>=96rem){.container{max-width:96rem}}.-mx-1{margin-inline:calc(var(--spacing) * -1)}.mx-auto{margin-inline:auto}.my-1{margin-block:calc(var(--spacing) * 1)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-8{margin-top:calc(var(--spacing) * 8)}.mt-10{margin-top:calc(var(--spacing) * 10)}.mr-1{margin-right:calc(var(--spacing) * 1)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.mb-8{margin-bottom:calc(var(--spacing) * 8)}.ml-auto{margin-left:auto}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.table-caption{display:table-caption}.table-cell{display:table-cell}.table-row{display:table-row}.size-2{width:calc(var(--spacing) * 2);height:calc(var(--spacing) * 2)}.size-3\.5{width:calc(var(--spacing) * 3.5);height:calc(var(--spacing) * 3.5)}.size-4{width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.size-9{width:calc(var(--spacing) * 9);height:calc(var(--spacing) * 9)}.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-9{height:calc(var(--spacing) * 9)}.h-10{height:calc(var(--spacing) * 10)}.h-\[1\.2rem\]{height:1.2rem}.h-full{height:100%}.h-px{height:1px}.max-h-\(--radix-dropdown-menu-content-available-height\){max-height:var(--radix-dropdown-menu-content-available-height)}.w-3{width:calc(var(--spacing) * 3)}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.w-24{width:calc(var(--spacing) * 24)}.w-\[1\.2rem\]{width:1.2rem}.w-fit{width:fit-content}.w-full{width:100%}.max-w-2xl{max-width:var(--container-2xl)}.max-w-4xl{max-width:var(--container-4xl)}.max-w-md{max-width:var(--container-md)}.min-w-0{min-width:calc(var(--spacing) * 0)}.min-w-\[8rem\]{min-width:8rem}.shrink-0{flex-shrink:0}.caption-bottom{caption-side:bottom}.origin-\(--radix-dropdown-menu-content-transform-origin\){transform-origin:var(--radix-dropdown-menu-content-transform-origin)}.scale-0{--tw-scale-x:0%;--tw-scale-y:0%;--tw-scale-z:0%;scale:var(--tw-scale-x) var(--tw-scale-y)}.scale-100{--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x) var(--tw-scale-y)}.rotate-0{rotate:0deg}.rotate-90{rotate:90deg}.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)}.animate-spin{animation:var(--animate-spin)}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.auto-rows-min{grid-auto-rows:min-content}.grid-rows-\[auto_auto\]{grid-template-rows:auto auto}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2) * 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)))}.self-start{align-self:flex-start}.justify-self-end{justify-self:flex-end}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-x-hidden{overflow-x:hidden}.overflow-y-auto{overflow-y:auto}.rounded-\[4px\]{border-radius:4px}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-xl{border-radius:calc(var(--radius) + 4px)}.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-input{border-color:var(--input)}.border-primary\/20{border-color:var(--primary)}@supports (color:color-mix(in lab, red, red)){.border-primary\/20{border-color:color-mix(in oklab, var(--primary) 20%, transparent)}}.border-transparent{border-color:#0000}.bg-accent{background-color:var(--accent)}.bg-background{background-color:var(--background)}.bg-border{background-color:var(--border)}.bg-card{background-color:var(--card)}.bg-destructive{background-color:var(--destructive)}.bg-muted\/50{background-color:var(--muted)}@supports (color:color-mix(in lab, red, red)){.bg-muted\/50{background-color:color-mix(in oklab, var(--muted) 50%, transparent)}}.bg-popover{background-color:var(--popover)}.bg-primary{background-color:var(--primary)}.bg-secondary{background-color:var(--secondary)}.bg-transparent{background-color:#0000}.fill-current{fill:currentColor}.p-1{padding:calc(var(--spacing) * 1)}.p-2{padding:calc(var(--spacing) * 2)}.p-6{padding:calc(var(--spacing) * 6)}.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:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-8{padding-block:calc(var(--spacing) * 8)}.pt-8{padding-top:calc(var(--spacing) * 8)}.pr-2{padding-right:calc(var(--spacing) * 2)}.pl-8{padding-left:calc(var(--spacing) * 8)}.text-center{text-align:center}.text-left{text-align:left}.align-middle{vertical-align:middle}.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-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))}.leading-none{--tw-leading:1;line-height:1}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-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:calc(var(--tracking-normal) - .025em);letter-spacing:calc(var(--tracking-normal) - .025em)}.tracking-widest{--tw-tracking:calc(var(--tracking-normal) + .1em);letter-spacing:calc(var(--tracking-normal) + .1em)}.whitespace-nowrap{white-space:nowrap}.text-card-foreground{color:var(--card-foreground)}.text-current{color:currentColor}.text-destructive{color:var(--destructive)}.text-foreground{color:var(--foreground)}.text-indigo-600{color:var(--color-indigo-600)}.text-muted-foreground{color:var(--muted-foreground)}.text-popover-foreground{color:var(--popover-foreground)}.text-primary{color:var(--primary)}.text-primary-foreground{color:var(--primary-foreground)}.text-red-500{color:var(--color-red-500)}.text-secondary-foreground{color:var(--secondary-foreground)}.text-white{color:var(--color-white)}.italic{font-style:italic}.underline-offset-4{text-underline-offset:4px}.shadow-lg{--tw-shadow:var(--shadow-lg);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-md{--tw-shadow:var(--shadow-md);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:var(--shadow-sm);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-xs{--tw-shadow:var(--shadow-xs);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.outline-hidden{--tw-outline-style:none;outline-style:none}@media (forced-colors:active){.outline-hidden{outline-offset:2px;outline:2px solid #0000}}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.transition-\[color\,box-shadow\]{transition-property:color,box-shadow;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))}.transition-none{transition-property:none}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.group-data-\[disabled\=true\]\:pointer-events-none:is(:where(.group)[data-disabled=true] *){pointer-events:none}.group-data-\[disabled\=true\]\:opacity-50:is(:where(.group)[data-disabled=true] *){opacity:.5}.peer-disabled\:cursor-not-allowed:is(:where(.peer):disabled~*){cursor:not-allowed}.peer-disabled\:opacity-50:is(:where(.peer):disabled~*){opacity:.5}.selection\:bg-primary ::selection{background-color:var(--primary)}.selection\:bg-primary::selection{background-color:var(--primary)}.selection\:text-primary-foreground ::selection{color:var(--primary-foreground)}.selection\:text-primary-foreground::selection{color:var(--primary-foreground)}.file\:inline-flex::file-selector-button{display:inline-flex}.file\:h-7::file-selector-button{height:calc(var(--spacing) * 7)}.file\:border-0::file-selector-button{border-style:var(--tw-border-style);border-width:0}.file\:bg-transparent::file-selector-button{background-color:#0000}.file\:text-sm::file-selector-button{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.file\:font-medium::file-selector-button{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.file\:text-foreground::file-selector-button{color:var(--foreground)}.placeholder\:text-muted-foreground::placeholder{color:var(--muted-foreground)}@media (hover:hover){.hover\:bg-accent:hover{background-color:var(--accent)}.hover\:bg-destructive\/90:hover{background-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.hover\:bg-destructive\/90:hover{background-color:color-mix(in oklab, var(--destructive) 90%, transparent)}}.hover\:bg-muted\/50:hover{background-color:var(--muted)}@supports (color:color-mix(in lab, red, red)){.hover\:bg-muted\/50:hover{background-color:color-mix(in oklab, var(--muted) 50%, transparent)}}.hover\:bg-primary\/90:hover{background-color:var(--primary)}@supports (color:color-mix(in lab, red, red)){.hover\:bg-primary\/90:hover{background-color:color-mix(in oklab, var(--primary) 90%, transparent)}}.hover\:bg-secondary\/80:hover{background-color:var(--secondary)}@supports (color:color-mix(in lab, red, red)){.hover\:bg-secondary\/80:hover{background-color:color-mix(in oklab, var(--secondary) 80%, transparent)}}.hover\:text-accent-foreground:hover{color:var(--accent-foreground)}.hover\:text-foreground:hover{color:var(--foreground)}.hover\:text-indigo-800:hover{color:var(--color-indigo-800)}.hover\:text-primary:hover{color:var(--primary)}.hover\:underline:hover{text-decoration-line:underline}.hover\:shadow-lg:hover{--tw-shadow:var(--shadow-lg);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}}.focus\:bg-accent:focus{background-color:var(--accent)}.focus\:text-accent-foreground:focus{color:var(--accent-foreground)}.focus-visible\:border-ring:focus-visible{border-color:var(--ring)}.focus-visible\:ring-\[3px\]:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(3px + 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)}.focus-visible\:ring-destructive\/20:focus-visible{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.focus-visible\:ring-destructive\/20:focus-visible{--tw-ring-color:color-mix(in oklab, var(--destructive) 20%, transparent)}}.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color:var(--ring)}@supports (color:color-mix(in lab, red, red)){.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color:color-mix(in oklab, var(--ring) 50%, transparent)}}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.has-data-\[slot\=card-action\]\:grid-cols-\[1fr_auto\]:has([data-slot=card-action]){grid-template-columns:1fr auto}.has-\[\>svg\]\:px-2\.5:has(>svg){padding-inline:calc(var(--spacing) * 2.5)}.has-\[\>svg\]\:px-3:has(>svg){padding-inline:calc(var(--spacing) * 3)}.has-\[\>svg\]\:px-4:has(>svg){padding-inline:calc(var(--spacing) * 4)}.aria-invalid\:border-destructive[aria-invalid=true]{border-color:var(--destructive)}.aria-invalid\:ring-destructive\/20[aria-invalid=true]{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.aria-invalid\:ring-destructive\/20[aria-invalid=true]{--tw-ring-color:color-mix(in oklab, var(--destructive) 20%, transparent)}}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[inset\]\:pl-8[data-inset]{padding-left:calc(var(--spacing) * 8)}.data-\[orientation\=horizontal\]\:h-px[data-orientation=horizontal]{height:1px}.data-\[orientation\=horizontal\]\:w-full[data-orientation=horizontal]{width:100%}.data-\[orientation\=vertical\]\:h-full[data-orientation=vertical]{height:100%}.data-\[orientation\=vertical\]\:w-px[data-orientation=vertical]{width:1px}.data-\[side\=bottom\]\:slide-in-from-top-2[data-side=bottom]{--tw-enter-translate-y:calc(2*var(--spacing)*-1)}.data-\[side\=left\]\:slide-in-from-right-2[data-side=left]{--tw-enter-translate-x:calc(2*var(--spacing))}.data-\[side\=right\]\:slide-in-from-left-2[data-side=right]{--tw-enter-translate-x:calc(2*var(--spacing)*-1)}.data-\[side\=top\]\:slide-in-from-bottom-2[data-side=top]{--tw-enter-translate-y:calc(2*var(--spacing))}.data-\[state\=checked\]\:border-primary[data-state=checked]{border-color:var(--primary)}.data-\[state\=checked\]\:bg-primary[data-state=checked]{background-color:var(--primary)}.data-\[state\=checked\]\:text-primary-foreground[data-state=checked]{color:var(--primary-foreground)}.data-\[state\=closed\]\:animate-out[data-state=closed]{animation:exit var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none)}.data-\[state\=closed\]\:fade-out-0[data-state=closed]{--tw-exit-opacity:0}.data-\[state\=closed\]\:zoom-out-95[data-state=closed]{--tw-exit-scale:.95}.data-\[state\=open\]\:animate-in[data-state=open]{animation:enter var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none)}.data-\[state\=open\]\:bg-accent[data-state=open]{background-color:var(--accent)}.data-\[state\=open\]\:text-accent-foreground[data-state=open]{color:var(--accent-foreground)}.data-\[state\=open\]\:fade-in-0[data-state=open]{--tw-enter-opacity:0}.data-\[state\=open\]\:zoom-in-95[data-state=open]{--tw-enter-scale:.95}.data-\[state\=selected\]\:bg-muted[data-state=selected]{background-color:var(--muted)}.data-\[variant\=destructive\]\:text-destructive[data-variant=destructive]{color:var(--destructive)}.data-\[variant\=destructive\]\:focus\:bg-destructive\/10[data-variant=destructive]:focus{background-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.data-\[variant\=destructive\]\:focus\:bg-destructive\/10[data-variant=destructive]:focus{background-color:color-mix(in oklab, var(--destructive) 10%, transparent)}}.data-\[variant\=destructive\]\:focus\:text-destructive[data-variant=destructive]:focus{color:var(--destructive)}@media (width>=40rem){.sm\:block{display:block}.sm\:pr-2\.5{padding-right:calc(var(--spacing) * 2.5)}.sm\:pl-2\.5{padding-left:calc(var(--spacing) * 2.5)}}@media (width>=48rem){.md\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}}.dark\:scale-0:where(.dark,.dark *){--tw-scale-x:0%;--tw-scale-y:0%;--tw-scale-z:0%;scale:var(--tw-scale-x) var(--tw-scale-y)}.dark\:scale-100:where(.dark,.dark *){--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x) var(--tw-scale-y)}.dark\:-rotate-90:where(.dark,.dark *){rotate:-90deg}.dark\:rotate-0:where(.dark,.dark *){rotate:0deg}.dark\:border-input:where(.dark,.dark *){border-color:var(--input)}.dark\:bg-destructive\/60:where(.dark,.dark *){background-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.dark\:bg-destructive\/60:where(.dark,.dark *){background-color:color-mix(in oklab, var(--destructive) 60%, transparent)}}.dark\:bg-input\/30:where(.dark,.dark *){background-color:var(--input)}@supports (color:color-mix(in lab, red, red)){.dark\:bg-input\/30:where(.dark,.dark *){background-color:color-mix(in oklab, var(--input) 30%, transparent)}}@media (hover:hover){.dark\:hover\:bg-accent\/50:where(.dark,.dark *):hover{background-color:var(--accent)}@supports (color:color-mix(in lab, red, red)){.dark\:hover\:bg-accent\/50:where(.dark,.dark *):hover{background-color:color-mix(in oklab, var(--accent) 50%, transparent)}}.dark\:hover\:bg-input\/50:where(.dark,.dark *):hover{background-color:var(--input)}@supports (color:color-mix(in lab, red, red)){.dark\:hover\:bg-input\/50:where(.dark,.dark *):hover{background-color:color-mix(in oklab, var(--input) 50%, transparent)}}}.dark\:focus-visible\:ring-destructive\/40:where(.dark,.dark *):focus-visible{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.dark\:focus-visible\:ring-destructive\/40:where(.dark,.dark *):focus-visible{--tw-ring-color:color-mix(in oklab, var(--destructive) 40%, transparent)}}.dark\:aria-invalid\:ring-destructive\/40:where(.dark,.dark *)[aria-invalid=true]{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.dark\:aria-invalid\:ring-destructive\/40:where(.dark,.dark *)[aria-invalid=true]{--tw-ring-color:color-mix(in oklab, var(--destructive) 40%, transparent)}}.dark\:data-\[state\=checked\]\:bg-primary:where(.dark,.dark *)[data-state=checked]{background-color:var(--primary)}.dark\:data-\[variant\=destructive\]\:focus\:bg-destructive\/20:where(.dark,.dark *)[data-variant=destructive]:focus{background-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.dark\:data-\[variant\=destructive\]\:focus\:bg-destructive\/20:where(.dark,.dark *)[data-variant=destructive]:focus{background-color:color-mix(in oklab, var(--destructive) 20%, transparent)}}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-4 svg:not([class*=size-]){width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.\[\&_svg\:not\(\[class\*\=\'text-\'\]\)\]\:text-muted-foreground svg:not([class*=text-]){color:var(--muted-foreground)}.\[\&_tr\]\:border-b tr{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.\[\&_tr\:last-child\]\:border-0 tr:last-child{border-style:var(--tw-border-style);border-width:0}.\[\&\:has\(\[role\=checkbox\]\)\]\:pr-0:has([role=checkbox]){padding-right:calc(var(--spacing) * 0)}.\[\.border-b\]\:pb-6.border-b{padding-bottom:calc(var(--spacing) * 6)}.\[\.border-t\]\:pt-6.border-t{padding-top:calc(var(--spacing) * 6)}:is(.data-\[variant\=destructive\]\:\*\:\[svg\]\:\!text-destructive[data-variant=destructive]>*):is(svg){color:var(--destructive)!important}.\[\&\>\[role\=checkbox\]\]\:translate-y-\[2px\]>[role=checkbox]{--tw-translate-y:2px;translate:var(--tw-translate-x) var(--tw-translate-y)}.\[\&\>svg\]\:pointer-events-none>svg{pointer-events:none}.\[\&\>svg\]\:size-3>svg{width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.\[\&\>tr\]\:last\:border-b-0>tr:last-child{border-bottom-style:var(--tw-border-style);border-bottom-width:0}@media (hover:hover){a.\[a\&\]\:hover\:bg-accent:hover{background-color:var(--accent)}a.\[a\&\]\:hover\:bg-destructive\/90:hover{background-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){a.\[a\&\]\:hover\:bg-destructive\/90:hover{background-color:color-mix(in oklab, var(--destructive) 90%, transparent)}}a.\[a\&\]\:hover\:bg-primary\/90:hover{background-color:var(--primary)}@supports (color:color-mix(in lab, red, red)){a.\[a\&\]\:hover\:bg-primary\/90:hover{background-color:color-mix(in oklab, var(--primary) 90%, transparent)}}a.\[a\&\]\:hover\:bg-secondary\/90:hover{background-color:var(--secondary)}@supports (color:color-mix(in lab, red, red)){a.\[a\&\]\:hover\:bg-secondary\/90:hover{background-color:color-mix(in oklab, var(--secondary) 90%, transparent)}}a.\[a\&\]\:hover\:text-accent-foreground:hover{color:var(--accent-foreground)}}}@property --tw-animation-delay{syntax:"*";inherits:false;initial-value:0s}@property --tw-animation-direction{syntax:"*";inherits:false;initial-value:normal}@property --tw-animation-duration{syntax:"*";inherits:false}@property --tw-animation-fill-mode{syntax:"*";inherits:false;initial-value:none}@property --tw-animation-iteration-count{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-translate-y{syntax:"*";inherits:false;initial-value:0}html,body{background-color:var(--color-white)}:is(html,body):where(.dark,.dark *){background-color:var(--color-gray-950)}@media (prefers-color-scheme:dark){html,body{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}}:root{--background:oklch(98.16% .0017 247.839);--foreground:oklch(16.49% .0352 281.829);--card:oklch(100% 0 0);--card-foreground:oklch(16.49% .0352 281.829);--popover:oklch(100% 0 0);--popover-foreground:oklch(16.49% .0352 281.829);--primary:oklch(67.26% .2904 341.408);--primary-foreground:oklch(100% 0 0);--secondary:oklch(95.95% .02 286.016);--secondary-foreground:oklch(16.49% .0352 281.829);--muted:oklch(95.95% .02 286.016);--muted-foreground:oklch(16.49% .0352 281.829);--accent:oklch(89.03% .1739 171.269);--accent-foreground:oklch(16.49% .0352 281.829);--destructive:oklch(65.35% .2348 34.037);--destructive-foreground:oklch(100% 0 0);--border:oklch(92.05% .0086 225.088);--input:oklch(92.05% .0086 225.088);--ring:oklch(67.26% .2904 341.408);--chart-1:oklch(67.26% .2904 341.408);--chart-2:oklch(54.88% .2944 299.095);--chart-3:oklch(84.42% .1457 209.285);--chart-4:oklch(89.03% .1739 171.269);--chart-5:oklch(91.68% .1915 101.407);--sidebar:oklch(95.95% .02 286.016);--sidebar-foreground:oklch(16.49% .0352 281.829);--sidebar-primary:oklch(67.26% .2904 341.408);--sidebar-primary-foreground:oklch(100% 0 0);--sidebar-accent:oklch(89.03% .1739 171.269);--sidebar-accent-foreground:oklch(16.49% .0352 281.829);--sidebar-border:oklch(92.05% .0086 225.088);--sidebar-ring:oklch(67.26% .2904 341.408);--font-sans:Outfit, sans-serif;--font-serif:Amiri Quran, ui-serif, serif;--font-mono:Fira Code, monospace;--radius:.5rem;--shadow-2xs:0px 4px 8px -2px #0000000d;--shadow-xs:0px 4px 8px -2px #0000000d;--shadow-sm:0px 4px 8px -2px #0000001a, 0px 1px 2px -3px #0000001a;--shadow:0px 4px 8px -2px #0000001a, 0px 1px 2px -3px #0000001a;--shadow-md:0px 4px 8px -2px #0000001a, 0px 2px 4px -3px #0000001a;--shadow-lg:0px 4px 8px -2px #0000001a, 0px 4px 6px -3px #0000001a;--shadow-xl:0px 4px 8px -2px #0000001a, 0px 8px 10px -3px #0000001a;--shadow-2xl:0px 4px 8px -2px #00000040;--tracking-normal:0em;--spacing:.25rem}.dark{--background:oklch(16.49% .0352 281.829);--foreground:oklch(95.13% .0074 260.732);--card:oklch(25.42% .0611 281.142);--card-foreground:oklch(95.13% .0074 260.732);--popover:oklch(25.42% .0611 281.142);--popover-foreground:oklch(95.13% .0074 260.732);--primary:oklch(67.26% .2904 341.408);--primary-foreground:oklch(100% 0 0);--secondary:oklch(25.42% .0611 281.142);--secondary-foreground:oklch(95.13% .0074 260.732);--muted:oklch(25.42% .0611 281.142);--muted-foreground:oklch(62.45% .05 278.105);--accent:oklch(89.03% .1739 171.269);--accent-foreground:oklch(16.49% .0352 281.829);--destructive:oklch(65.35% .2348 34.037);--destructive-foreground:oklch(100% 0 0);--border:oklch(32.79% .0832 280.789);--input:oklch(32.79% .0832 280.789);--ring:oklch(67.26% .2904 341.408);--chart-1:oklch(67.26% .2904 341.408);--chart-2:oklch(54.88% .2944 299.095);--chart-3:oklch(84.42% .1457 209.285);--chart-4:oklch(89.03% .1739 171.269);--chart-5:oklch(91.68% .1915 101.407);--sidebar:oklch(16.49% .0352 281.829);--sidebar-foreground:oklch(95.13% .0074 260.732);--sidebar-primary:oklch(67.26% .2904 341.408);--sidebar-primary-foreground:oklch(100% 0 0);--sidebar-accent:oklch(89.03% .1739 171.269);--sidebar-accent-foreground:oklch(16.49% .0352 281.829);--sidebar-border:oklch(32.79% .0832 280.789);--sidebar-ring:oklch(67.26% .2904 341.408);--font-sans:Outfit, sans-serif;--font-serif:Amiri Quran, ui-serif, serif;--font-mono:Fira Code, monospace;--radius:.5rem;--shadow-2xs:0px 4px 8px -2px #0000000d;--shadow-xs:0px 4px 8px -2px #0000000d;--shadow-sm:0px 4px 8px -2px #0000001a, 0px 1px 2px -3px #0000001a;--shadow:0px 4px 8px -2px #0000001a, 0px 1px 2px -3px #0000001a;--shadow-md:0px 4px 8px -2px #0000001a, 0px 2px 4px -3px #0000001a;--shadow-lg:0px 4px 8px -2px #0000001a, 0px 4px 6px -3px #0000001a;--shadow-xl:0px 4px 8px -2px #0000001a, 0px 8px 10px -3px #0000001a;--shadow-2xl:0px 4px 8px -2px #00000040}@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-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-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}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{50%{opacity:.5}}@keyframes enter{0%{opacity:var(--tw-enter-opacity,1);transform:translate3d(var(--tw-enter-translate-x,0),var(--tw-enter-translate-y,0),0)scale3d(var(--tw-enter-scale,1),var(--tw-enter-scale,1),var(--tw-enter-scale,1))rotate(var(--tw-enter-rotate,0));filter:blur(var(--tw-enter-blur,0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity,1);transform:translate3d(var(--tw-exit-translate-x,0),var(--tw-exit-translate-y,0),0)scale3d(var(--tw-exit-scale,1),var(--tw-exit-scale,1),var(--tw-exit-scale,1))rotate(var(--tw-exit-rotate,0));filter:blur(var(--tw-exit-blur,0))}}.portfolio-app{--bg0:#0b1e34;--bg1:#174b5d;--bg2:#2a7a7f;--ink:#f6f8d5;--ink-dim:#f6f8d5ad;--accent:#98d2c0;--accent-2:#4f959d;--glass-bg:#f6f8d50f;--glass-border:#f6f8d529;--glass-hover:#f6f8d517;--glass-blur:18px;--font-display:"Fraunces", "Instrument Serif", Georgia, serif;--font-body:"Inter", ui-sans-serif, system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace;--display-weight:400;--display-style:italic;--maxw:1120px;--pad-x:clamp(20px, 4vw, 56px);--radius:18px;--radius-sm:10px;isolation:isolate;min-height:100vh;font-family:var(--font-body);color:var(--ink);background:var(--bg0);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;position:relative;overflow-x:hidden}.portfolio-app ::selection{background:var(--accent);color:var(--bg0)}.portfolio-app a{color:inherit}.portfolio-app .bg-grad{background:radial-gradient(ellipse 80% 60% at 20% 10%, color-mix(in oklab, var(--accent-2) 60%, transparent) 0%, transparent 55%), radial-gradient(ellipse 70% 60% at 85% 30%, color-mix(in oklab, var(--accent) 35%, transparent) 0%, transparent 60%), radial-gradient(ellipse 90% 70% at 50% 100%, color-mix(in oklab, var(--bg1) 80%, transparent) 0%, transparent 65%), linear-gradient(180deg, var(--bg0) 0%, color-mix(in oklab, var(--bg0) 85%, var(--bg1)) 40%, color-mix(in oklab, var(--bg0) 70%, var(--bg1)) 100%);z-index:-2;animation:40s ease-in-out infinite alternate pf-grad-drift;position:fixed;inset:-10%}@keyframes pf-grad-drift{0%{transform:translate(0,0)scale(1)}to{transform:translate(2%,-1%)scale(1.04)}}.portfolio-app .bg-vignette{z-index:-1;pointer-events:none;background:radial-gradient(100% 60% at 50% 100%,#00000059,#0000 70%),radial-gradient(100% 40% at 50% 0,#00000040,#0000 70%);position:fixed;inset:0}.portfolio-app.grain-on:after{content:"";pointer-events:none;opacity:.07;mix-blend-mode:overlay;z-index:1;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.6 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");position:fixed;inset:0}.portfolio-app .glass{background:var(--glass-bg);border:.5px solid var(--glass-border);border-radius:var(--radius);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(130%);backdrop-filter:blur(var(--glass-blur)) saturate(130%);transition:background .2s,border-color .2s,transform .3s;position:relative;box-shadow:inset 0 1px #ffffff14,0 30px 60px -20px #00000080,0 8px 24px -8px #00000059}.portfolio-app .glass:before{content:"";border-radius:inherit;pointer-events:none;mix-blend-mode:overlay;background:linear-gradient(#ffffff17,#fff0 35%);position:absolute;inset:0}.portfolio-app .pf-nav{z-index:40;border:.5px solid var(--glass-border);-webkit-backdrop-filter:blur(20px)saturate(140%);backdrop-filter:blur(20px)saturate(140%);background:#0b1e3459;border-radius:999px;align-items:center;gap:28px;max-width:calc(100vw - 24px);padding:10px 14px 10px 18px;transition:background .3s,padding .3s,top .3s;display:flex;position:fixed;top:16px;left:50%;transform:translate(-50%)}.portfolio-app .pf-nav-scrolled{background:#0b1e348c;top:12px}.portfolio-app .pf-nav-brand{color:var(--ink);align-items:center;gap:10px;text-decoration:none;display:flex}.portfolio-app .pf-nav-brand-glyph{color:var(--accent);display:inline-flex}.portfolio-app .pf-nav-brand-name{font-family:var(--font-display);font-style:var(--display-style);letter-spacing:.01em;white-space:nowrap;font-size:15px;font-weight:500}.portfolio-app .pf-nav-links{gap:4px;display:flex}.portfolio-app .pf-nav-link{color:var(--ink-dim);white-space:nowrap;cursor:pointer;background:0 0;border:0;border-radius:999px;padding:6px 10px;font-family:inherit;font-size:13px;font-weight:500;text-decoration:none;transition:color .15s,background .15s}.portfolio-app .pf-nav-link:hover{color:var(--ink);background:#ffffff0f}.portfolio-app .pf-nav-link-active{color:var(--ink);background:#ffffff14}.portfolio-app .pf-nav-cta{background:var(--accent);color:var(--bg0);white-space:nowrap;border-radius:999px;padding:8px 14px;font-size:12.5px;font-weight:500;text-decoration:none;transition:transform .12s,background .15s}.portfolio-app .pf-nav-cta:hover{background:color-mix(in oklab, var(--accent) 85%, white);transform:translateY(-1px)}@media (width<=960px){.portfolio-app .pf-nav{gap:14px;padding:8px 10px 8px 14px}.portfolio-app .pf-nav-links{display:none}}.portfolio-app .pf-main{z-index:2;max-width:var(--maxw);padding:0 var(--pad-x);scroll-behavior:smooth;margin:0 auto;position:relative}.portfolio-app .pf-section{padding:clamp(60px,9vw,120px) 0 0;scroll-margin-top:80px}.portfolio-app .pf-hero{padding:clamp(120px,16vw,200px) 0 clamp(40px,6vw,80px);scroll-margin-top:80px;position:relative}.portfolio-app .pf-hero-meta{color:var(--ink-dim);letter-spacing:.04em;background:var(--glass-bg);border:.5px solid var(--glass-border);font-size:12px;font-family:var(--font-mono);white-space:nowrap;text-overflow:ellipsis;border-radius:999px;align-items:center;gap:8px;max-width:100%;margin-bottom:36px;padding:6px 12px;display:inline-flex;overflow:hidden}.portfolio-app .pf-dot-live{background:var(--accent);width:7px;height:7px;box-shadow:0 0 0 0 var(--accent);border-radius:50%;animation:2s ease-out infinite pf-pulse}@keyframes pf-pulse{0%{box-shadow:0 0 0 0 color-mix(in oklab, var(--accent) 60%, transparent)}70%{box-shadow:0 0 0 10px #0000}to{box-shadow:0 0 #0000}}.portfolio-app .pf-hero-h1{font-family:var(--font-display);font-weight:var(--display-weight);font-style:var(--display-style);letter-spacing:-.025em;margin:0 0 32px;font-size:clamp(48px,8.6vw,128px);line-height:.96;transition:transform .2s ease-out}.portfolio-app .pf-hero-line{display:block}.portfolio-app .pf-hero-line-dim{color:var(--ink-dim)}.portfolio-app .pf-hero-sub{max-width:620px;color:var(--ink-dim);text-wrap:pretty;margin:0 0 40px;font-size:clamp(16px,1.6vw,19px);line-height:1.55}.portfolio-app .pf-hero-strip{border-top:.5px solid var(--glass-border);border-bottom:.5px solid var(--glass-border);grid-template-columns:repeat(4,1fr);gap:0;margin:0 0 40px;padding:22px 0;display:grid}.portfolio-app .pf-hero-strip-item{border-right:.5px solid var(--glass-border);padding:0 8px}.portfolio-app .pf-hero-strip-item:last-child{border-right:0}.portfolio-app .pf-hero-strip-k{font-family:var(--font-display);letter-spacing:-.02em;font-size:clamp(22px,3vw,32px);font-weight:500;line-height:1}.portfolio-app .pf-hero-strip-l{font-family:var(--font-mono);color:var(--ink-dim);text-transform:uppercase;letter-spacing:.08em;margin-top:8px;font-size:11px}@media (width<=720px){.portfolio-app .pf-hero-strip{grid-template-columns:repeat(2,1fr);gap:16px 0}.portfolio-app .pf-hero-strip-item:nth-child(2){border-right:0}}.portfolio-app .pf-hero-cta{flex-wrap:wrap;gap:12px;display:flex}.portfolio-app .pf-btn{cursor:pointer;font-size:14px;font-weight:500;font-family:var(--font-body);border:.5px solid #0000;border-radius:999px;align-items:center;gap:8px;padding:12px 20px;text-decoration:none;transition:transform .15s,background .15s,border-color .15s;display:inline-flex}.portfolio-app .pf-btn-primary{background:var(--accent);color:var(--bg0)}.portfolio-app .pf-btn-primary:hover{background:color-mix(in oklab, var(--accent) 85%, white);transform:translateY(-1px)}.portfolio-app .pf-btn-ghost{color:var(--ink);border-color:var(--glass-border);background:0 0}.portfolio-app .pf-btn-ghost:hover{background:var(--glass-hover)}.portfolio-app .pf-sect-hd{margin-bottom:32px}.portfolio-app .pf-sect-hd-idx{font-family:var(--font-mono);color:var(--accent);letter-spacing:.12em;text-transform:uppercase;margin-bottom:10px;font-size:11px}.portfolio-app .pf-sect-hd-title{font-family:var(--font-display);font-weight:var(--display-weight);font-style:var(--display-style);letter-spacing:-.02em;margin:0 0 10px;font-size:clamp(32px,4.2vw,52px);line-height:1}.portfolio-app .pf-sect-hd-sub{color:var(--ink-dim);max-width:520px;margin:0;font-size:15px}.portfolio-app .pf-about-grid{grid-template-columns:1.6fr 1fr;gap:18px;display:grid}@media (width<=820px){.portfolio-app .pf-about-grid{grid-template-columns:1fr}}.portfolio-app .pf-about-card{padding:30px}.portfolio-app .pf-about-card-lead p{font-family:var(--font-display);color:var(--ink);text-wrap:pretty;margin:0 0 16px;font-size:clamp(18px,2vw,22px);font-weight:300;line-height:1.5}.portfolio-app .pf-about-card-lead p:last-child{color:var(--ink-dim);margin-bottom:0}.portfolio-app .pf-about-card-lead em{color:var(--accent);font-style:italic}.portfolio-app .pf-kv{border-bottom:.5px solid var(--glass-border);grid-template-columns:70px 1fr;gap:12px;padding:12px 0;font-size:14px;display:grid}.portfolio-app .pf-kv:last-child{border-bottom:0}.portfolio-app .pf-kv-k{font-family:var(--font-mono);color:var(--ink-dim);text-transform:uppercase;letter-spacing:.08em;padding-top:3px;font-size:11px}.portfolio-app .pf-kv-v{color:var(--ink)}.portfolio-app .pf-xp-list{flex-direction:column;gap:12px;display:flex}.portfolio-app .pf-xp-card{overflow:hidden}.portfolio-app .pf-xp-card:hover{background:var(--glass-hover)}.portfolio-app .pf-xp-head{all:unset;cursor:pointer;box-sizing:border-box;grid-template-columns:1fr auto;align-items:center;gap:24px;width:100%;padding:22px 26px;display:grid}.portfolio-app .pf-xp-head-main{min-width:0}.portfolio-app .pf-xp-company{flex-wrap:wrap;align-items:baseline;gap:12px;margin-bottom:4px;display:flex}.portfolio-app .pf-xp-company-name{font-family:var(--font-display);letter-spacing:-.01em;font-size:clamp(20px,2.4vw,26px);font-weight:500}.portfolio-app .pf-xp-kind{font-family:var(--font-mono);color:var(--ink-dim);text-transform:uppercase;letter-spacing:.1em;border:.5px solid var(--glass-border);border-radius:999px;padding:2px 8px;font-size:10px}.portfolio-app .pf-xp-role{color:var(--ink-dim);font-size:14px}.portfolio-app .pf-xp-head-right{align-items:center;gap:16px;display:flex}.portfolio-app .pf-xp-period{font-family:var(--font-mono);color:var(--ink-dim);white-space:nowrap;font-size:12px}.portfolio-app .pf-xp-chev{color:var(--ink-dim);transition:transform .25s,color .15s;display:inline-flex}.portfolio-app .pf-xp-chev-open{color:var(--accent);transform:rotate(180deg)}.portfolio-app .pf-xp-body{transition:max-height .35s cubic-bezier(.2,.8,.2,1);overflow:hidden}.portfolio-app .pf-xp-body-inner{border-top:.5px solid var(--glass-border);padding:20px 26px 26px}.portfolio-app .pf-xp-blurb{color:var(--ink);text-wrap:pretty;max-width:680px;margin:0 0 18px;font-size:15px;line-height:1.6}.portfolio-app .pf-xp-metrics{flex-wrap:wrap;gap:18px;margin-bottom:18px;display:flex}.portfolio-app .pf-xp-metric{border-right:.5px solid var(--glass-border);padding:10px 16px 10px 0}.portfolio-app .pf-xp-metric:last-child{border-right:0}.portfolio-app .pf-xp-metric-k{font-family:var(--font-display);color:var(--accent);letter-spacing:-.02em;font-size:22px;font-weight:500;line-height:1}.portfolio-app .pf-xp-metric-l{font-family:var(--font-mono);color:var(--ink-dim);text-transform:uppercase;letter-spacing:.08em;margin-top:6px;font-size:10px}@media (width<=620px){.portfolio-app .pf-xp-head{grid-template-columns:1fr;gap:8px}.portfolio-app .pf-xp-head-right{justify-content:space-between}}.portfolio-app .pf-chips{flex-wrap:wrap;gap:6px;display:flex}.portfolio-app .pf-chip{font-family:var(--font-mono);color:var(--ink-dim);border:.5px solid var(--glass-border);background:#ffffff0a;border-radius:6px;padding:5px 10px;font-size:11px;transition:color .12s,border-color .12s;display:inline-block}.portfolio-app .pf-chip:hover{color:var(--ink);border-color:color-mix(in oklab, var(--accent) 50%, var(--glass-border))}.portfolio-app .pf-proj-grid{grid-template-columns:1fr;gap:16px;display:grid}.portfolio-app .pf-proj-card{padding:28px}.portfolio-app .pf-proj-top{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:16px;margin-bottom:14px;display:flex}.portfolio-app .pf-proj-name{font-family:var(--font-display);letter-spacing:-.02em;margin:0;font-size:clamp(24px,3vw,32px);font-weight:500}.portfolio-app .pf-proj-link{font-family:var(--font-mono);color:var(--accent);border-bottom:.5px solid color-mix(in oklab, var(--accent) 40%, transparent);padding-bottom:1px;font-size:12px;text-decoration:none}.portfolio-app .pf-proj-link:hover{border-bottom-color:var(--accent)}.portfolio-app .pf-proj-blurb{color:var(--ink-dim);max-width:640px;margin:0 0 20px;font-size:15px;line-height:1.6}.portfolio-app .pf-proj-metrics{flex-wrap:wrap;gap:22px;margin-bottom:20px;display:flex}.portfolio-app .pf-proj-metric{border-right:.5px solid var(--glass-border);padding-right:22px}.portfolio-app .pf-proj-metric:last-child{border-right:0;padding-right:0}.portfolio-app .pf-proj-metric-k{font-family:var(--font-display);color:var(--accent);letter-spacing:-.02em;font-size:26px;font-weight:500}.portfolio-app .pf-proj-metric-l{font-family:var(--font-mono);color:var(--ink-dim);text-transform:uppercase;letter-spacing:.08em;margin-top:4px;font-size:10px}.portfolio-app .pf-skills-card{padding:30px}.portfolio-app .pf-skills-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:26px;display:grid}.portfolio-app .pf-skills-head{font-family:var(--font-mono);color:var(--accent);text-transform:uppercase;letter-spacing:.1em;align-items:center;gap:8px;margin-bottom:12px;font-size:11px;display:flex}.portfolio-app .pf-edu-card{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;padding:24px 28px;display:flex}.portfolio-app .pf-edu-school{font-family:var(--font-display);letter-spacing:-.01em;margin:0 0 4px;font-size:22px;font-weight:500}.portfolio-app .pf-edu-degree{color:var(--ink-dim);margin:0;font-size:14px}.portfolio-app .pf-edu-period{font-family:var(--font-mono);color:var(--ink-dim);font-size:12px}.portfolio-app .pf-ref-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=820px){.portfolio-app .pf-ref-grid{grid-template-columns:1fr}}.portfolio-app .pf-ref-card{flex-direction:column;gap:18px;padding:28px;display:flex}.portfolio-app .pf-ref-quote{font-family:var(--font-display);color:var(--ink);text-wrap:pretty;margin:0;font-size:18px;font-style:italic;font-weight:300;line-height:1.55}.portfolio-app .pf-ref-meta{border-top:.5px solid var(--glass-border);padding-top:14px}.portfolio-app .pf-ref-name{font-size:14px;font-weight:500}.portfolio-app .pf-ref-title{font-family:var(--font-mono);color:var(--ink-dim);text-transform:uppercase;letter-spacing:.08em;margin-top:3px;font-size:11px}.portfolio-app .pf-news-band{width:100vw;padding:clamp(40px, 6vw, 72px) var(--pad-x);border-top:.5px solid var(--glass-border);border-bottom:.5px solid var(--glass-border);background:radial-gradient(ellipse 60% 120% at 100% 0%, color-mix(in oklab, var(--accent) 16%, transparent) 0%, transparent 60%), radial-gradient(ellipse 70% 120% at 0% 100%, color-mix(in oklab, var(--accent-2) 22%, transparent) 0%, transparent 60%), color-mix(in oklab, var(--bg1) 30%, transparent);margin-top:clamp(32px,6vw,72px);margin-left:calc(50% - 50vw);scroll-margin-top:80px}.portfolio-app .pf-news-inner{max-width:var(--maxw);grid-template-columns:1.2fr .8fr;align-items:center;gap:clamp(28px,5vw,64px);margin:0 auto;display:grid}.portfolio-app .pf-news-eyebrow{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--accent);align-items:center;gap:8px;margin-bottom:16px;font-size:12px;display:inline-flex}.portfolio-app .pf-news-eyebrow-glyph{display:inline-flex}.portfolio-app .pf-news-title{font-family:var(--font-display);font-weight:var(--display-weight);font-style:var(--display-style);letter-spacing:-.02em;margin:0 0 16px;font-size:clamp(30px,4.4vw,52px);line-height:1.04}.portfolio-app .pf-news-pitch{color:var(--ink-dim);text-wrap:pretty;max-width:560px;margin:0 0 22px;font-size:clamp(15px,1.5vw,17px);line-height:1.6}.portfolio-app .pf-news-points{flex-wrap:wrap;gap:10px 22px;margin:0;padding:0;list-style:none;display:flex}.portfolio-app .pf-news-point{color:var(--ink);align-items:center;gap:8px;font-size:13px;display:inline-flex}.portfolio-app .pf-news-point-glyph{color:var(--accent);display:inline-flex}.portfolio-app .pf-news-form{background:var(--glass-bg);border:.5px solid var(--glass-border);border-radius:var(--radius);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(130%);backdrop-filter:blur(var(--glass-blur)) saturate(130%);flex-direction:column;gap:12px;padding:clamp(20px,2.4vw,28px);display:flex}.portfolio-app .pf-news-form-label{font-family:var(--font-display);font-style:var(--display-style);font-size:18px}.portfolio-app .pf-news-input-row{flex-direction:column;gap:10px;display:flex}.portfolio-app .pf-input{background:var(--bg0);border:.5px solid var(--glass-border);width:100%;min-width:0;color:var(--ink);font-family:var(--font-body);border-radius:999px;outline:none;padding:13px 16px;font-size:15px;transition:border-color .15s,background .15s}.portfolio-app .pf-input::placeholder{color:var(--ink-dim)}.portfolio-app .pf-input:focus{border-color:var(--accent)}.portfolio-app .pf-news-form .pf-btn{white-space:nowrap;justify-content:center}.portfolio-app .pf-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.portfolio-app .pf-news-meta{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.portfolio-app .pf-news-fine{font-family:var(--font-mono);color:var(--ink-dim);letter-spacing:.02em;font-size:11px}.portfolio-app .pf-news-archive{font-family:var(--font-mono);color:var(--accent);letter-spacing:.02em;font-size:12px;text-decoration:none;transition:opacity .15s}.portfolio-app .pf-news-archive:hover{opacity:.75}.portfolio-app .pf-sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (width<=820px){.portfolio-app .pf-news-inner{grid-template-columns:1fr}}.portfolio-app .pf-section-contact{padding-bottom:80px}.portfolio-app .pf-contact-card{text-align:center;padding:clamp(40px,6vw,72px) clamp(30px,5vw,60px);position:relative;overflow:hidden}.portfolio-app .pf-contact-snow{color:var(--accent);opacity:.5;margin-bottom:18px}.portfolio-app .pf-contact-h{font-family:var(--font-display);font-weight:var(--display-weight);font-style:var(--display-style);letter-spacing:-.02em;margin:0 0 16px;font-size:clamp(32px,5vw,56px);line-height:1.05}.portfolio-app .pf-contact-sub{color:var(--ink-dim);max-width:440px;margin:0 auto 32px;font-size:16px;line-height:1.55}.portfolio-app .pf-contact-row{flex-wrap:wrap;justify-content:center;gap:12px;display:inline-flex}.portfolio-app .pf-contact-footnote{border-top:.5px solid var(--glass-border);font-family:var(--font-mono);color:var(--ink-dim);letter-spacing:.05em;margin-top:40px;padding-top:24px;font-size:11px}@media (prefers-reduced-motion:reduce){.portfolio-app *,.portfolio-app :before,.portfolio-app :after{transition:none!important;animation:none!important}}
