/*! tailwindcss v4.3.0 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-font-weight:initial;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-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-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-sans:"Geist Variable", sans-serif;--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--font-weight-medium:500;--radius-md:calc(var(--radius) * .8);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:"Geist Variable", sans-serif;--default-mono-font-family:var(--font-mono)}}@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)}html{font-family:Geist Variable,sans-serif}}@layer components;@layer utilities{.fixed{position:fixed}.static{position:static}.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}}.block{display:block}.contents{display:contents}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-flex{display:inline-flex}.table{display:table}.size-6{width:calc(var(--spacing) * 6);height:calc(var(--spacing) * 6)}.size-7{width:calc(var(--spacing) * 7);height:calc(var(--spacing) * 7)}.size-8{width:calc(var(--spacing) * 8);height:calc(var(--spacing) * 8)}.size-9{width:calc(var(--spacing) * 9);height:calc(var(--spacing) * 9)}.h-6{height:calc(var(--spacing) * 6)}.h-7{height:calc(var(--spacing) * 7)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.shrink-0{flex-shrink:0}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.items-center{align-items:center}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.rounded{border-radius:.25rem}.rounded-\[min\(var\(--radius-md\)\,10px\)\]{border-radius:min(var(--radius-md), 10px)}.rounded-\[min\(var\(--radius-md\)\,12px\)\]{border-radius:min(var(--radius-md), 12px)}.rounded-lg{border-radius:var(--radius)}.border{border-style:var(--tw-border-style);border-width:1px}.border-border{border-color:var(--border)}.border-transparent{border-color:#0000}.bg-background{background-color:var(--background)}.bg-destructive\/10{background-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.bg-destructive\/10{background-color:color-mix(in oklab, var(--destructive) 10%, transparent)}}.bg-primary{background-color:var(--primary)}.bg-secondary{background-color:var(--secondary)}.bg-clip-padding{background-clip:padding-box}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[0\.8rem\]{font-size:.8rem}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.whitespace-nowrap{white-space:nowrap}.text-destructive{color:var(--destructive)}.text-primary{color:var(--primary)}.text-primary-foreground{color:var(--primary-foreground)}.text-secondary-foreground{color:var(--secondary-foreground)}.underline-offset-4{text-underline-offset:4px}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.running{animation-play-state:running}@media (hover:hover){.hover\:bg-destructive\/20:hover{background-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.hover\:bg-destructive\/20:hover{background-color:color-mix(in oklab, var(--destructive) 20%, transparent)}}.hover\:bg-muted:hover{background-color:var(--muted)}.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-foreground:hover{color:var(--foreground)}.hover\:underline:hover{text-decoration-line:underline}}.focus-visible\:border-destructive\/40:focus-visible{border-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.focus-visible\:border-destructive\/40:focus-visible{border-color:color-mix(in oklab, var(--destructive) 40%, transparent)}}.focus-visible\:border-ring:focus-visible{border-color:var(--ring)}.focus-visible\:ring-3: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)}}.active\:not-aria-\[haspopup\]\:translate-y-px:active:not([aria-haspopup]){--tw-translate-y:1px;translate:var(--tw-translate-x) var(--tw-translate-y)}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:opacity-50:disabled{opacity:.5}:where([data-slot=button-group]) .in-data-\[slot\=button-group\]\:rounded-lg{border-radius:var(--radius)}.has-data-\[icon\=inline-end\]\:pr-1\.5:has([data-icon=inline-end]){padding-right:calc(var(--spacing) * 1.5)}.has-data-\[icon\=inline-end\]\:pr-2:has([data-icon=inline-end]){padding-right:calc(var(--spacing) * 2)}.has-data-\[icon\=inline-start\]\:pl-1\.5:has([data-icon=inline-start]){padding-left:calc(var(--spacing) * 1.5)}.has-data-\[icon\=inline-start\]\:pl-2:has([data-icon=inline-start]){padding-left:calc(var(--spacing) * 2)}.aria-expanded\:bg-muted[aria-expanded=true]{background-color:var(--muted)}.aria-expanded\:bg-secondary[aria-expanded=true]{background-color:var(--secondary)}.aria-expanded\:text-foreground[aria-expanded=true]{color:var(--foreground)}.aria-expanded\:text-secondary-foreground[aria-expanded=true]{color:var(--secondary-foreground)}.aria-invalid\:border-destructive[aria-invalid=true]{border-color:var(--destructive)}.aria-invalid\:ring-3[aria-invalid=true]{--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)}.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)}}.dark\:border-input:is(.dark *){border-color:var(--input)}.dark\:bg-destructive\/20:is(.dark *){background-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.dark\:bg-destructive\/20:is(.dark *){background-color:color-mix(in oklab, var(--destructive) 20%, transparent)}}.dark\:bg-input\/30:is(.dark *){background-color:var(--input)}@supports (color:color-mix(in lab, red, red)){.dark\:bg-input\/30:is(.dark *){background-color:color-mix(in oklab, var(--input) 30%, transparent)}}@media (hover:hover){.dark\:hover\:bg-destructive\/30:is(.dark *):hover{background-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.dark\:hover\:bg-destructive\/30:is(.dark *):hover{background-color:color-mix(in oklab, var(--destructive) 30%, transparent)}}.dark\:hover\:bg-input\/50:is(.dark *):hover{background-color:var(--input)}@supports (color:color-mix(in lab, red, red)){.dark\:hover\:bg-input\/50:is(.dark *):hover{background-color:color-mix(in oklab, var(--input) 50%, transparent)}}.dark\:hover\:bg-muted\/50:is(.dark *):hover{background-color:var(--muted)}@supports (color:color-mix(in lab, red, red)){.dark\:hover\:bg-muted\/50:is(.dark *):hover{background-color:color-mix(in oklab, var(--muted) 50%, transparent)}}}.dark\:focus-visible\:ring-destructive\/40:is(.dark *):focus-visible{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.dark\:focus-visible\:ring-destructive\/40:is(.dark *):focus-visible{--tw-ring-color:color-mix(in oklab, var(--destructive) 40%, transparent)}}.dark\:aria-invalid\:border-destructive\/50:is(.dark *)[aria-invalid=true]{border-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.dark\:aria-invalid\:border-destructive\/50:is(.dark *)[aria-invalid=true]{border-color:color-mix(in oklab, var(--destructive) 50%, transparent)}}.dark\:aria-invalid\:ring-destructive\/40:is(.dark *)[aria-invalid=true]{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.dark\:aria-invalid\:ring-destructive\/40:is(.dark *)[aria-invalid=true]{--tw-ring-color:color-mix(in oklab, var(--destructive) 40%, transparent)}}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-3 svg:not([class*=size-]){width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-3\.5 svg:not([class*=size-]){width:calc(var(--spacing) * 3.5);height:calc(var(--spacing) * 3.5)}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-4 svg:not([class*=size-]){width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}@media (hover:hover){.\[a\]\:hover\:bg-primary\/80:is(a):hover{background-color:var(--primary)}@supports (color:color-mix(in lab, red, red)){.\[a\]\:hover\:bg-primary\/80:is(a):hover{background-color:color-mix(in oklab, var(--primary) 80%, transparent)}}}}@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}@font-face{font-family:Geist Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-cyrillic-ext-wght-normal-DjL33-gN.woff2)format("woff2-variations");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Geist Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-cyrillic-wght-normal-BEAKL7Jp.woff2)format("woff2-variations");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-vietnamese-wght-normal-6IgcOCM7.woff2)format("woff2-variations");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Geist Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-latin-ext-wght-normal-DC-KSUi6.woff2)format("woff2-variations");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-latin-wght-normal-BgDaEnEv.woff2)format("woff2-variations");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Mono Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-mono-cyrillic-ext-wght-normal-I4S5GZfc.woff2)format("woff2-variations");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Geist Mono Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-mono-cyrillic-wght-normal-BmXc_FBt.woff2)format("woff2-variations");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-mono-symbols2-wght-normal-GZpp1pK2.woff2)format("woff2-variations");unicode-range:U+2000-2001,U+2004-2008,U+200A,U+23B8-23BD,U+2500-259F}@font-face{font-family:Geist Mono Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-mono-vietnamese-wght-normal-D8KDMBhC.woff2)format("woff2-variations");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Geist Mono Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-mono-latin-ext-wght-normal-DrnZ1wKl.woff2)format("woff2-variations");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Mono Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-mono-latin-wght-normal-B_7UjwxQ.woff2)format("woff2-variations");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--background:oklch(100% 0 0);--foreground:oklch(14.5% 0 0);--card:oklch(100% 0 0);--card-foreground:oklch(14.5% 0 0);--popover:oklch(100% 0 0);--popover-foreground:oklch(14.5% 0 0);--primary:oklch(20.5% 0 0);--primary-foreground:oklch(98.5% 0 0);--secondary:oklch(97% 0 0);--secondary-foreground:oklch(20.5% 0 0);--muted:oklch(97% 0 0);--muted-foreground:oklch(55.6% 0 0);--accent:oklch(97% 0 0);--accent-foreground:oklch(20.5% 0 0);--destructive:oklch(57.7% .245 27.325);--border:oklch(92.2% 0 0);--input:oklch(92.2% 0 0);--ring:oklch(70.8% 0 0);--chart-1:oklch(87% 0 0);--chart-2:oklch(55.6% 0 0);--chart-3:oklch(43.9% 0 0);--chart-4:oklch(37.1% 0 0);--chart-5:oklch(26.9% 0 0);--radius:.625rem;--sidebar:oklch(98.5% 0 0);--sidebar-foreground:oklch(14.5% 0 0);--sidebar-primary:oklch(20.5% 0 0);--sidebar-primary-foreground:oklch(98.5% 0 0);--sidebar-accent:oklch(97% 0 0);--sidebar-accent-foreground:oklch(20.5% 0 0);--sidebar-border:oklch(92.2% 0 0);--sidebar-ring:oklch(70.8% 0 0)}.dark{--background:oklch(14.5% 0 0);--foreground:oklch(98.5% 0 0);--card:oklch(20.5% 0 0);--card-foreground:oklch(98.5% 0 0);--popover:oklch(20.5% 0 0);--popover-foreground:oklch(98.5% 0 0);--primary:oklch(92.2% 0 0);--primary-foreground:oklch(20.5% 0 0);--secondary:oklch(26.9% 0 0);--secondary-foreground:oklch(98.5% 0 0);--muted:oklch(26.9% 0 0);--muted-foreground:oklch(70.8% 0 0);--accent:oklch(26.9% 0 0);--accent-foreground:oklch(98.5% 0 0);--destructive:oklch(70.4% .191 22.216);--border:oklch(100% 0 0/.1);--input:oklch(100% 0 0/.15);--ring:oklch(55.6% 0 0);--chart-1:oklch(87% 0 0);--chart-2:oklch(55.6% 0 0);--chart-3:oklch(43.9% 0 0);--chart-4:oklch(37.1% 0 0);--chart-5:oklch(26.9% 0 0);--sidebar:oklch(20.5% 0 0);--sidebar-foreground:oklch(98.5% 0 0);--sidebar-primary:oklch(48.8% .243 264.376);--sidebar-primary-foreground:oklch(98.5% 0 0);--sidebar-accent:oklch(26.9% 0 0);--sidebar-accent-foreground:oklch(98.5% 0 0);--sidebar-border:oklch(100% 0 0/.1);--sidebar-ring:oklch(55.6% 0 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-font-weight{syntax:"*";inherits:false}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-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-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}:root{--bg:#000;--fg:#f3efe6;--fg-soft:#f3efe69e;--fg-faint:#f3efe657;--fg-line:#f3efe61a;--accent:#5b8bff;--serif:"Geist Variable", ui-sans-serif, system-ui, sans-serif;--sans:"Geist Variable", ui-sans-serif, -apple-system, system-ui, sans-serif;--mono:"Geist Mono Variable", ui-monospace, "SF Mono", Menlo, monospace;--col:720px;--gutter:clamp(20px, 5vw, 56px);--y-section:clamp(120px, 18vh, 200px)}*{box-sizing:border-box}html,body{background:var(--bg);color:var(--fg);font-family:var(--sans);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0;padding:0;font-size:16px;font-weight:300;line-height:1.55}body{min-height:100vh;overflow-x:hidden}#landmarks{pointer-events:none;z-index:0;opacity:.85;height:100vh;position:absolute;top:0;left:0;right:0}#landmarks canvas{display:block;width:100%!important;height:100%!important}.nav{z-index:50;padding:22px var(--gutter);font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--fg-soft);justify-content:space-between;align-items:center;font-size:11px;display:flex;position:fixed;top:0;left:0;right:0}.nav:before{content:"";z-index:-1;pointer-events:none;-webkit-backdrop-filter:blur(11px);backdrop-filter:blur(11px);background:linear-gradient(#000c,#00000073 45%,#0000);height:112px;position:absolute;inset:0 0 auto;-webkit-mask-image:linear-gradient(#000 46%,#0000);mask-image:linear-gradient(#000 46%,#0000)}.nav a{color:inherit;padding:6px 0;text-decoration:none;position:relative}.nav a:hover{color:var(--fg)}.nav .links{gap:28px;display:flex}.nav .mark{color:var(--fg);align-items:center;gap:10px;transition:opacity .3s;display:flex}.nav .mark.is-hidden{opacity:0;pointer-events:none}.nav .mark .dot{background:var(--accent);width:7px;height:7px;box-shadow:0 0 18px var(--accent);border-radius:50%}.nav-toggle{appearance:none;color:inherit;font:inherit;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;background:0 0;border:0;padding:6px 0;display:none}.nav-toggle:hover{color:var(--fg)}.mobile-menu{z-index:60;background:var(--bg);padding:22px var(--gutter);opacity:0;pointer-events:none;flex-direction:column;transition:opacity .3s;display:flex;position:fixed;inset:0}.mobile-menu.open{opacity:1;pointer-events:auto}.mobile-close{appearance:none;color:var(--fg-soft);font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;cursor:pointer;background:0 0;border:0;align-self:flex-end;padding:6px 0;font-size:11px}.mobile-close:hover{color:var(--fg)}.mobile-links{flex-direction:column;flex:1;justify-content:center;gap:4px;display:flex}.mobile-links a{font-family:var(--serif);letter-spacing:-.02em;color:var(--fg);padding:8px 0;font-size:clamp(40px,12vw,64px);font-weight:400;line-height:1.1;text-decoration:none;transition:color .2s}.mobile-links a:hover{color:var(--accent)}@media (width>=881px){.mobile-menu{display:none}}.scroll-cue{z-index:40;pointer-events:none;opacity:1;flex-direction:column;align-items:center;gap:8px;transition:opacity .5s;display:flex;position:fixed;bottom:22px;left:50%;transform:translate(-50%)}.scroll-cue.is-hidden{opacity:0}.scroll-cue__label{font-family:var(--mono);letter-spacing:.24em;text-transform:uppercase;color:var(--fg-faint);font-size:9px}.scroll-cue__rail{background:var(--fg-line);width:1px;height:38px;position:relative;overflow:hidden}.scroll-cue__rail:after{content:"";background:linear-gradient(to bottom, transparent, var(--fg-soft));width:100%;height:45%;animation:1.9s cubic-bezier(.4,0,.2,1) infinite scrollCue;position:absolute;top:0;left:0}@keyframes scrollCue{0%{opacity:0;transform:translateY(-100%)}35%{opacity:1}to{opacity:0;transform:translateY(230%)}}main{z-index:1;position:relative}section{padding:var(--y-section) var(--gutter);position:relative}.wrap{max-width:1280px;margin:0 auto}.col{max-width:var(--col);margin:0 auto}.hero{flex-direction:column;justify-content:space-between;min-height:100vh;padding-top:18vh;padding-bottom:15vh;display:flex;position:relative;overflow:hidden}.hero .wrap{width:100%;max-width:1400px;margin:0 auto}.pose-slot{top:29vh;right:max(var(--gutter), calc((100% - 1400px) / 2));pointer-events:none;z-index:0;width:min(34vw,380px);height:44vh;position:absolute}.eyebrow{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--fg-faint);align-items:center;gap:14px;font-size:11px;display:flex}.eyebrow .line{background:var(--fg-line);flex:0 0 36px;height:1px}h1.display{font-family:var(--serif);letter-spacing:-.02em;color:var(--fg);margin:28px 0 0;font-size:clamp(64px,13vw,220px);font-style:normal;font-weight:400;line-height:.92}h1.display .it{color:var(--fg);font-style:normal}.hero-foot{grid-template-columns:1fr 1fr;align-items:end;gap:48px;margin-top:80px;display:grid}.hero-foot .lede{font-family:var(--serif);color:var(--fg);max-width:560px;font-size:clamp(22px,2.2vw,30px);font-weight:400;line-height:1.35}.hero-foot .lede em{color:var(--accent);font-style:normal}.hero-meta{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-soft);text-align:center;top:calc(73vh + 16px);right:max(var(--gutter), calc((100% - 1400px) / 2));z-index:1;flex-direction:column;align-items:center;gap:6px;width:min(34vw,380px);font-size:11px;display:flex;position:absolute}.hero-meta b{color:var(--fg);font-weight:500}.section-h{border-bottom:1px solid var(--fg-line);justify-content:space-between;align-items:baseline;margin-bottom:64px;padding-bottom:48px;display:flex}.section-h .idx{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--fg-faint);font-size:11px}.section-h h2{font-family:var(--serif);letter-spacing:-.02em;color:var(--fg);margin:0;font-size:clamp(40px,5vw,64px);font-style:normal;font-weight:400}.section-h .meta{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--fg-soft);font-size:11px}.about-grid{grid-template-columns:1.1fr .9fr;align-items:start;gap:80px;display:grid}.about-grid p{font-family:var(--serif);color:var(--fg);max-width:620px;margin:0 0 24px;font-size:clamp(22px,1.9vw,28px);font-weight:400;line-height:1.45}.about-grid p em{color:var(--accent);font-style:normal}.kx-link{color:var(--accent);border-bottom:1px solid #0000;font-style:normal;text-decoration:none;transition:border-color .25s}.kx-link:hover{border-bottom-color:currentColor}.portrait{aspect-ratio:4/5;border:1px solid var(--fg-line);background:#0a0a0a;position:relative;overflow:hidden}.portrait img{object-fit:cover;z-index:1;width:100%;height:100%;position:absolute;inset:0}.portrait:after{content:"";background-image:repeating-linear-gradient(135deg,#0000 0 14px,#f3efe60a 14px 15px);position:absolute;inset:0}.portrait .ph-label{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--fg-faint);font-size:10px;position:absolute;bottom:12px;left:14px}.portrait .ph-corner{font-family:var(--mono);color:var(--fg-faint);letter-spacing:.12em;font-size:10px;position:absolute;top:14px;right:14px}.fact-list{border-top:1px solid var(--fg-line);grid-template-columns:1fr 1fr;gap:0;margin-top:24px;display:grid}.fact-list .row{border-bottom:1px solid var(--fg-line);font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--fg-soft);grid-column:1/-1;justify-content:space-between;padding:14px 0;font-size:11px;display:flex}.fact-list .row b{color:var(--fg);font-weight:500}.work-list{flex-direction:column;display:flex}.work{border-bottom:1px solid var(--fg-line);color:inherit;grid-template-columns:1.2fr 1.6fr 120px;align-items:start;gap:32px;padding:40px 24px;text-decoration:none;transition:background .35s,padding-left .35s cubic-bezier(.2,.7,.2,1);display:grid;position:relative}.work *{text-decoration:none}.work .idx{font-family:var(--mono);color:var(--fg-faint);letter-spacing:.08em;padding-top:8px;font-size:11px;transition:color .25s}.work h3{font-family:var(--serif);letter-spacing:-.02em;color:var(--fg);margin:0;font-size:clamp(34px,4vw,56px);font-style:normal;font-weight:400;line-height:1.02;transition:color .25s}.work h3 em{font-style:normal}.work .meta-col{flex-direction:column;gap:14px;display:flex}.work .summary{font-family:var(--serif);color:var(--fg-soft);max-width:420px;margin:0;font-size:20px;line-height:1.4}.work .tags{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-faint);flex-wrap:wrap;gap:6px;font-size:10px;display:flex}.work .tags span{border:1px solid var(--fg-line);border-radius:99px;padding:3px 8px;transition:border-color .25s,color .25s}.work .subprojects{border-top:1px solid var(--fg-line);flex-direction:column;gap:12px;max-width:420px;margin:6px 0 0;padding:16px 0 0;list-style:none;display:flex}.work .subprojects li{flex-direction:column;gap:3px;display:flex}.work .subprojects .sp-name{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--fg-soft);font-size:10px;transition:color .25s}.work .subprojects .sp-blurb{font-family:var(--serif);color:var(--fg-faint);font-size:15px;line-height:1.35}.work:hover .subprojects .sp-name{color:var(--accent)}.work .year{font-family:var(--mono);letter-spacing:.08em;color:var(--fg-soft);text-align:right;flex-direction:column;align-items:flex-end;gap:8px;padding-top:10px;font-size:11px;display:flex}.work .year b{color:var(--fg);font-weight:500}.work .year .status{color:var(--accent);letter-spacing:.12em;align-items:center;gap:6px;font-size:10px;display:inline-flex}.work .year .status .dot{background:var(--accent);border-radius:50%;width:5px;height:5px}.work .arrow{opacity:0;font-family:var(--serif);color:var(--accent);pointer-events:none;font-size:36px;font-style:normal;transition:opacity .3s,transform .45s cubic-bezier(.2,.7,.2,1);position:absolute;top:50%;right:24px;transform:translateY(-50%)translate(-14px)}.work:hover{background:#f3efe606;padding-left:40px}.work:hover .idx,.work:hover h3{color:var(--accent)}.work:hover .tags span{border-color:var(--fg-soft);color:var(--fg-soft)}.work:hover .arrow{opacity:1;transform:translateY(-50%)translate(0)}.writing-list{flex-direction:column;gap:0;display:flex}.entry{border-bottom:1px solid var(--fg-line);color:var(--fg);grid-template-columns:120px 1fr 240px 100px;align-items:baseline;gap:32px;padding:24px 0;text-decoration:none;display:grid;position:relative}.entry .date{font-family:var(--mono);color:var(--fg-faint);letter-spacing:.08em;text-transform:uppercase;font-size:11px}.entry .title{font-family:var(--serif);letter-spacing:-.01em;color:var(--fg);font-size:clamp(22px,2.4vw,32px);font-weight:400;line-height:1.15;transition:transform .35s cubic-bezier(.2,.7,.2,1),color .25s}.entry .title em{font-style:normal}.entry .sub{font-family:var(--serif);color:var(--fg-soft);font-size:17px;line-height:1.4}.entry .kind{font-family:var(--mono);color:var(--fg-faint);letter-spacing:.12em;text-transform:uppercase;text-align:right;font-size:10px}.entry .kind.note,.entry:hover .title{color:var(--accent)}.entry:hover{background:#f3efe606;padding-left:8px}.contact{padding-bottom:160px}.contact h2.display-xl{font-family:var(--serif);letter-spacing:-.02em;color:var(--fg);margin:0;font-size:clamp(56px,10vw,160px);font-style:normal;font-weight:400;line-height:.95}.contact .links{border-top:1px solid var(--fg-line);grid-template-columns:repeat(2,1fr);gap:0;margin-top:24px;display:grid}.contact .links a{border-bottom:1px solid var(--fg-line);color:var(--fg);font-family:var(--sans);letter-spacing:-.01em;justify-content:space-between;padding:22px 0;font-size:18px;text-decoration:none;transition:color .25s,padding .25s;display:flex}.contact .links a .arrow{font-family:var(--mono);color:var(--fg-faint);font-size:14px;transition:transform .35s cubic-bezier(.2,.7,.2,1),color .25s}.contact .links a:hover{color:var(--accent);padding-left:14px}.contact .links a:hover .arrow{color:var(--accent);transform:translate(6px)}.contact-lede{font-family:var(--serif);color:var(--fg);max-width:620px;margin:28px 0 0;font-size:clamp(20px,2vw,28px);font-weight:400;line-height:1.4}.spam-note{font-family:var(--mono);letter-spacing:.02em;color:var(--fg-faint);max-width:540px;margin:18px 0 0;font-size:12px;line-height:1.6}.email-gate{min-height:52px;margin-top:30px}.gate-btn{appearance:none;border:1px solid var(--fg-line);color:var(--fg);font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;cursor:pointer;background:0 0;padding:13px 20px;font-size:12px;transition:border-color .25s,color .25s}.gate-btn:hover{border-color:var(--accent);color:var(--accent)}.gate-challenge{flex-direction:column;align-items:flex-start;gap:16px;display:flex}.gate-q{flex-direction:column;gap:8px;display:flex}.gate-q-label{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-soft);font-size:11px}.gate-q-eq{font-family:var(--serif);letter-spacing:-.01em;color:var(--fg);font-size:clamp(28px,4vw,44px)}.gate-hint{width:100%;max-width:560px}.gate-hint summary{cursor:pointer;font-family:var(--mono);letter-spacing:.04em;color:var(--fg-soft);align-items:center;gap:8px;font-size:12px;list-style:none;transition:color .25s;display:inline-flex}.gate-hint summary:hover{color:var(--fg)}.gate-hint summary::-webkit-details-marker{display:none}.gate-hint summary:after{content:"+";font-family:var(--mono);color:var(--fg-faint);font-size:14px}.gate-hint[open] summary:after{content:"−"}.hint-demo-wrap{flex-direction:column;align-items:flex-start;gap:10px;margin-top:14px;display:flex}.hint-demo{border:1px solid var(--fg-line);max-width:380px;font-family:var(--mono);color:var(--fg-soft);background:#f3efe605;border-radius:8px;flex-direction:column;gap:10px;padding:16px 18px;font-size:14px;display:flex}.hd-row{opacity:0;animation:.5s cubic-bezier(.2,.7,.2,1) forwards hdReveal;transform:translateY(6px)}.hd-eq{letter-spacing:.02em;color:var(--fg);font-size:16px;animation-delay:.2s}.hd-expand{letter-spacing:.02em;color:var(--fg);font-size:16px;animation-delay:1.2s}.hd-facts{flex-wrap:wrap;gap:8px 18px;font-size:13px;animation-delay:2.2s;display:flex}.hd-ans{color:var(--fg);font-size:15px;animation-delay:3.2s}.hd-key{color:var(--accent)}.hd-glow{font-weight:600;animation:1.2s ease-in-out 2.6s 2 hdGlow}.hd-ans b{color:var(--accent);font-weight:600}.hd-replay{appearance:none;border:1px solid var(--fg-line);color:var(--fg-soft);font-family:var(--mono);letter-spacing:.04em;cursor:pointer;background:0 0;border-radius:6px;padding:7px 12px;font-size:11px;transition:border-color .25s,color .25s}.hd-replay:hover{border-color:var(--accent);color:var(--accent)}.gate-hint-note{max-width:380px;font-family:var(--mono);color:var(--fg-faint);margin:12px 0 0;font-size:12px;line-height:1.5}.gate-hint-note b{color:var(--fg);font-weight:600}@keyframes hdReveal{to{opacity:1;transform:none}}@keyframes hdGlow{0%,to{text-shadow:0 0 #5b8bff00}50%{text-shadow:0 0 10px #5b8bffb3}}.gate-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.gate-field{align-items:center;gap:8px;display:flex}.gate-field-label{font-family:var(--mono);color:var(--fg-soft);font-size:14px}.gate-input{appearance:none;border:1px solid var(--fg-line);color:var(--fg);font-family:var(--mono);letter-spacing:.04em;text-align:center;background:0 0;width:84px;padding:12px 14px;font-size:14px;transition:border-color .25s}.gate-input::placeholder{color:var(--fg-faint)}.gate-input:focus{border-color:var(--accent);outline:none}.gate-input.is-error{border-color:#e0705f}.gate-error{font-family:var(--mono);letter-spacing:.04em;color:#e0705f;margin:0;font-size:11px}.gate-learn{border-top:1px solid var(--fg-line);border-bottom:1px solid var(--fg-line);width:100%;max-width:620px}.gate-learn summary{cursor:pointer;font-family:var(--mono);letter-spacing:.04em;color:var(--fg-soft);justify-content:space-between;align-items:center;gap:12px;padding:15px 0;font-size:12px;list-style:none;transition:color .25s;display:flex}.gate-learn summary:hover{color:var(--fg)}.gate-learn summary::-webkit-details-marker{display:none}.gate-learn summary:after{content:"+";font-family:var(--mono);color:var(--fg-faint);font-size:15px}.gate-learn[open] summary:after{content:"−"}.gate-learn-body{flex-direction:column;gap:12px;padding:2px 0 20px;display:flex}.gate-learn-body p{max-width:580px;font-family:var(--sans);color:var(--fg-soft);margin:0;font-size:14px;line-height:1.6}.gate-learn-body b{color:var(--fg);font-weight:600}.gate-learn-body i{color:var(--fg)}.gate-learn-body code{font-family:var(--mono);letter-spacing:.02em;color:var(--fg);font-size:.92em}.parabola-fig,.garden-fig{flex-direction:column;gap:8px;margin:2px 0;display:flex}.parabola{width:100%;max-width:340px;height:auto;display:block;overflow:visible}.parabola-fig figcaption,.garden-fig figcaption{max-width:340px;font-family:var(--mono);color:var(--fg-faint);font-size:11px;line-height:1.5}.garden{width:100%;max-width:240px;height:auto;display:block}.gd-cell{fill:var(--accent);fill-opacity:.07;stroke:var(--fg-line);stroke-width:1px}.gd-frame{fill:none;stroke:var(--accent);stroke-width:2px}.gd-area-bg{fill:var(--bg);opacity:.82}.gd-area{fill:var(--accent);font-family:var(--mono);letter-spacing:.02em;font-size:13px}.gd-side{fill:var(--fg-soft);font-family:var(--mono);letter-spacing:.04em;font-size:11px}.pb-axis{stroke:var(--fg-line);stroke-width:1px;stroke-dasharray:3 4}.pb-curve{fill:none;stroke:var(--accent);stroke-width:2px;stroke-linejoin:round;stroke-linecap:round}.pb-root{fill:var(--fg)}.pb-vertex{fill:var(--bg);stroke:var(--accent);stroke-width:1.5px}.pb-label{fill:var(--fg-soft);font-family:var(--mono);letter-spacing:.02em;font-size:10px}.pb-vertex-label{fill:var(--fg-faint);font-family:var(--mono);letter-spacing:.03em;font-size:9.5px}.pb-zero{fill:var(--fg-faint);font-family:var(--mono);letter-spacing:.06em;font-size:9px}.gate-email{color:var(--accent);font-family:var(--sans);letter-spacing:-.01em;align-items:center;gap:14px;font-size:clamp(20px,2.4vw,30px);text-decoration:none;display:inline-flex}.gate-email .arrow{font-family:var(--mono);font-size:16px;transition:transform .35s cubic-bezier(.2,.7,.2,1)}.gate-email:hover .arrow{transform:translate(6px)}.reveal{opacity:0;transform:translateY(14px)}.reveal.in{opacity:1;animation:.8s cubic-bezier(.2,.7,.2,1) both __revIn;transform:none}@keyframes __revIn{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}.reveal.d1.in{animation-delay:80ms}.reveal.d2.in{animation-delay:.16s}.reveal.d3.in{animation-delay:.24s}.reveal.d4.in{animation-delay:.32s}.reveal.d5.in{animation-delay:.4s}@media (width<=1024px){.hero{justify-content:flex-start;padding-top:13vh;padding-bottom:12vh}.hero .wrap{text-align:center}.pose-slot{width:100%;height:clamp(200px,34vh,400px);position:relative;top:auto;right:auto}.hero-foot{text-align:center;grid-template-columns:1fr;justify-items:center;gap:18px;margin-top:32px}.hero-foot .lede{margin:0 auto}.hero-meta{text-align:center;align-items:center;width:100%;position:relative;top:auto;right:auto}}@media (width<=880px){.about-grid{grid-template-columns:1fr;gap:40px}.work{grid-template-columns:1fr;gap:16px}.work .meta-col,.work .year{grid-column:1/-1}.entry{grid-template-columns:80px 1fr;gap:14px}.entry .sub,.entry .kind{grid-column:2}.contact .links{grid-template-columns:1fr}.nav .links{display:none}.nav-toggle{display:inline-flex}}@media (prefers-reduced-motion:reduce){.reveal,.reveal.in{opacity:1!important;animation:none!important;transform:none!important}.scroll-cue__rail:after{animation:none!important}.hd-row,.hd-glow{opacity:1!important;animation:none!important;transform:none!important}*{scroll-behavior:auto!important}}.writing-page main{z-index:1;padding:18vh var(--gutter) 12vh;position:relative}.writing-page .eyebrow{margin-bottom:18px}.writing-page .head{border-bottom:1px solid var(--fg-line);justify-content:space-between;align-items:baseline;margin-bottom:24px;padding-bottom:48px;display:flex}.writing-page .head h1{font-family:var(--serif);letter-spacing:-.02em;margin:0;font-size:clamp(72px,12vw,200px);font-style:normal;font-weight:400;line-height:.95}.writing-page .head .meta{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-soft);text-align:right;flex-direction:column;gap:6px;font-size:11px;display:flex}.writing-page .head .meta b{color:var(--fg);font-weight:500}.filters{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-faint);align-items:center;gap:8px;padding:28px 0 36px;font-size:11px;display:flex}.filters .lbl{margin-right:8px}.chip{appearance:none;border:1px solid var(--fg-line);color:var(--fg-soft);letter-spacing:.06em;text-transform:uppercase;cursor:pointer;background:0 0;border-radius:99px;padding:6px 12px;font-family:inherit;font-size:11px;transition:color .2s,border-color .2s,background .2s}.chip:hover{color:var(--fg);border-color:var(--fg-soft)}.chip.on{color:#000;background:var(--accent);border-color:var(--accent)}.count{color:var(--fg-faint);margin-left:auto}.writing-page .entries{flex-direction:column;display:flex}.writing-page .entry{border-bottom:1px solid var(--fg-line);color:var(--fg);grid-template-columns:110px 1fr 240px 100px;align-items:baseline;gap:32px;padding:28px 0;text-decoration:none;transition:padding .35s cubic-bezier(.2,.7,.2,1),background .25s;display:grid;position:relative}.writing-page .entry .date{font-family:var(--mono);color:var(--fg-faint);letter-spacing:.08em;text-transform:uppercase;font-size:11px}.writing-page .entry .title{font-family:var(--serif);letter-spacing:-.01em;color:var(--fg);font-size:clamp(26px,2.8vw,38px);font-weight:400;line-height:1.1;transition:color .25s,transform .35s cubic-bezier(.2,.7,.2,1)}.writing-page .entry .title em{font-style:normal}.writing-page .entry .sub{font-family:var(--serif);color:var(--fg-soft);margin-top:8px;font-size:18px;line-height:1.4}.writing-page .entry .e-meta{font-family:var(--mono);color:var(--fg-faint);letter-spacing:.12em;text-transform:uppercase;font-size:10px}.writing-page .entry .kind{font-family:var(--mono);color:var(--fg-faint);letter-spacing:.12em;text-transform:uppercase;text-align:right;font-size:10px}.writing-page .entry .kind.note{color:var(--accent)}.writing-page .entry:hover{background:linear-gradient(#0000,#f3efe606,#0000);padding-left:8px}.writing-page .entry:hover .title{color:var(--accent);transform:translate(4px)}.writing-page .entry.hidden{display:none}@media (width<=880px){.writing-page .entry{grid-template-columns:90px 1fr;gap:14px}.writing-page .entry .e-meta,.writing-page .entry .kind{grid-column:2}.writing-page .head{flex-direction:column;align-items:flex-start;gap:24px}.writing-page .head .meta{text-align:left;align-items:flex-start}}.post-page{--measure:640px}.post-page main,.note-page main{z-index:1;position:relative}.progress{z-index:60;background:0 0;height:2px;position:fixed;top:0;left:0;right:0}.progress .bar{background:var(--accent);width:0%;height:100%;box-shadow:0 0 18px var(--accent);transition:width .1s linear}.post-page .article-head{padding:22vh var(--gutter) 8vh;max-width:1280px;margin:0 auto}.post-page .article-head .eyebrow{margin-bottom:24px}.post-page .eyebrow .accent{color:var(--accent)}.post-page h1.title{font-family:var(--serif);letter-spacing:-.02em;max-width:14ch;margin:0;font-size:clamp(48px,7vw,104px);font-style:normal;font-weight:400;line-height:1}.post-page h1.title em{font-style:normal}.meta-line{border-top:1px solid var(--fg-line);font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-soft);flex-wrap:wrap;gap:36px;margin-top:48px;padding-top:24px;font-size:11px;display:flex}.meta-line .item{flex-direction:column;gap:4px;display:flex}.meta-line .item b{color:var(--fg);letter-spacing:.06em;font-weight:500}.hero-img{aspect-ratio:21/9;border:1px solid var(--fg-line);background:#0a0a0a;max-width:1280px;margin:0 auto 80px;position:relative;overflow:hidden}.hero-img:after{content:"";background-image:repeating-linear-gradient(135deg,#0000 0 18px,#f3efe60a 18px 19px);position:absolute;inset:0}.hero-img .ph-label{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--fg-faint);font-size:10px;position:absolute;bottom:16px;left:18px}.hero-img .ph-corner{font-family:var(--mono);color:var(--fg-faint);letter-spacing:.12em;font-size:10px;position:absolute;top:18px;right:18px}.post-page article{padding:0 var(--gutter) 12vh;grid-template-columns:200px var(--measure) 1fr;align-items:start;gap:64px;max-width:1280px;margin:0 auto;display:grid}.gutter-l{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--fg-faint);flex-direction:column;gap:8px;font-size:10px;display:flex;position:sticky;top:120px}.gutter-l .lbl{color:var(--fg-soft)}.gutter-l a{color:var(--fg-faint);padding:4px 0;text-decoration:none;transition:color .2s;display:block}.gutter-l a.active,.gutter-l a:hover{color:var(--accent)}.gutter-r{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--fg-faint);font-size:10px;position:sticky;top:120px}.prose{font-family:var(--serif);color:var(--fg);max-width:var(--measure);font-size:22px;font-weight:400;line-height:1.55}.prose .dropcap:first-letter{font-family:var(--serif);float:left;color:var(--accent);padding:8px 14px 0 0;font-size:5em;font-style:normal;line-height:.85}.prose p{margin:0 0 1.2em}.prose h2{font-family:var(--serif);letter-spacing:-.01em;color:var(--fg);margin:2.4em 0 .6em;scroll-margin-top:120px;font-size:36px;font-style:normal;font-weight:400;line-height:1.1}.prose h2 .n{font-family:var(--mono);color:var(--fg-faint);letter-spacing:.18em;text-transform:uppercase;margin-bottom:10px;font-size:12px;font-style:normal;display:block}.prose blockquote{border-left:1px solid var(--accent);color:var(--fg);margin:1.6em 0;padding:4px 0 4px 24px;font-size:26px;font-style:normal;line-height:1.4}.prose em{font-style:normal}.prose strong{color:var(--fg);font-weight:500}.prose a{color:var(--accent);border-bottom:1px solid #5b8bff4d;text-decoration:none;transition:border-color .2s}.prose a:hover{border-color:var(--accent)}.prose hr{border:0;border-top:1px solid var(--fg-line);margin:3em 0}.prose code{font-family:var(--mono);color:var(--accent);background:#5b8bff14;border-radius:4px;padding:2px 6px;font-size:.78em}.prose ul{margin:1em 0 1.4em;padding:0;list-style:none}.prose ul li{font-family:var(--serif);margin:.4em 0;padding-left:28px;font-size:22px;line-height:1.5;position:relative}.prose ul li:before{content:"—";color:var(--accent);font-family:var(--mono);font-size:14px;position:absolute;top:8px;left:0}.prose .filed{font-family:var(--mono);color:var(--fg-faint);letter-spacing:.06em;text-transform:uppercase;font-size:12px}.pull{font-family:var(--serif);color:var(--fg);border-top:1px solid var(--fg-line);border-bottom:1px solid var(--fg-line);text-align:center;margin:1.6em 0;padding:24px 0;font-size:36px;font-style:normal;line-height:1.2}.fig{aspect-ratio:16/10;border:1px solid var(--fg-line);background:#0a0a0a;margin:2.4em 0;position:relative}.fig:after{content:"";background-image:repeating-linear-gradient(135deg,#0000 0 14px,#f3efe60a 14px 15px);position:absolute;inset:0}.fig .cap{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--fg-faint);font-size:10px;position:absolute;bottom:12px;left:14px}.end{max-width:1280px;padding:40px var(--gutter) 0;border-top:1px solid var(--fg-line);margin:0 auto}.end .sig{font-family:var(--serif);color:var(--fg-soft);margin:0 0 16px;font-size:32px;font-style:normal}.next{max-width:1280px;padding:80px var(--gutter) 120px;margin:0 auto}.next .label{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--fg-faint);margin-bottom:20px;font-size:10px}.next a{border-top:1px solid var(--fg-line);border-bottom:1px solid var(--fg-line);color:var(--fg);grid-template-columns:120px 1fr 60px;align-items:center;gap:32px;padding:32px 0;text-decoration:none;transition:padding .35s cubic-bezier(.2,.7,.2,1),color .25s;display:grid}.next a .date{font-family:var(--mono);letter-spacing:.08em;color:var(--fg-faint);text-transform:uppercase;font-size:11px}.next a .t{font-family:var(--serif);letter-spacing:-.01em;font-size:clamp(28px,4vw,48px);font-weight:400;line-height:1.05}.next a .t em{font-style:normal}.next a .arr{font-family:var(--mono);color:var(--fg-faint);text-align:right;font-size:14px;transition:transform .35s,color .2s}.next a:hover{color:var(--accent);padding-left:8px}.next a:hover .arr{color:var(--accent);transform:translate(8px)}@media (width<=1100px){.post-page article{grid-template-columns:1fr;gap:32px}.gutter-l,.gutter-r{position:static}}@media (width<=880px){.post-page h1.title{font-size:48px}.prose,.prose ul li{font-size:19px}.prose blockquote{font-size:22px}.meta-line{gap:20px}}.note-page main{min-height:100vh;padding:18vh var(--gutter) 12vh;flex-direction:column;justify-content:center;display:flex}.note{max-width:760px;margin:0 auto;position:relative}.note-page .eyebrow{color:var(--accent);margin-bottom:32px}.note-page .eyebrow .line{background:#5b8bff66}.note-page .eyebrow .e-meta{color:var(--fg-faint);margin-left:auto}.note-page h1.title{font-family:var(--serif);letter-spacing:-.02em;max-width:14ch;margin:0 0 56px;font-size:clamp(40px,5.5vw,80px);font-style:normal;font-weight:400;line-height:1.05}.note-page h1.title em{font-style:normal}.note .body{font-family:var(--serif);color:var(--fg);max-width:620px;font-size:clamp(24px,2.2vw,32px);font-weight:400;line-height:1.5}.note .body p{margin:0 0 1em}.note .body em{color:var(--accent);font-style:normal}.note .body strong{font-weight:500}.note .body .small{font-family:var(--sans);color:var(--fg-soft);max-width:520px;margin-top:48px;font-size:16px;font-weight:300;line-height:1.6}.note .sig{border-top:1px solid var(--fg-line);font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-soft);justify-content:space-between;align-items:center;margin-top:80px;padding-top:24px;font-size:11px;display:flex}.note .sig .name{font-family:var(--serif);color:var(--fg);text-transform:none;letter-spacing:0;font-size:24px;font-style:normal}.between{border-top:1px solid var(--fg-line);grid-template-columns:1fr 1fr;gap:24px;max-width:760px;margin:80px auto 0;padding-top:24px;display:grid}.between a{color:var(--fg);flex-direction:column;gap:6px;text-decoration:none;transition:color .2s,transform .35s cubic-bezier(.2,.7,.2,1);display:flex}.between a .lbl{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--fg-faint);font-size:10px}.between a .t{font-family:var(--serif);letter-spacing:-.01em;font-size:22px;line-height:1.2}.between a .t em{font-style:normal}.between a.r{text-align:right;align-items:flex-end}.between a:hover{color:var(--accent)}.between a:hover.l{transform:translate(-6px)}.between a:hover.r{transform:translate(6px)}@media (width<=880px){.between{grid-template-columns:1fr;gap:32px}.between a.r{text-align:left;align-items:flex-start}}.project-page main{z-index:1;max-width:980px;padding:22vh var(--gutter) 12vh;margin:0 auto;position:relative}.project-head{margin-bottom:56px}.project-head .eyebrow{margin-bottom:24px}.project-head .eyebrow .accent{color:var(--accent)}.project-page h1.title{font-family:var(--serif);letter-spacing:-.02em;margin:0;font-size:clamp(56px,9vw,132px);font-style:normal;font-weight:400;line-height:.98}.project-page h1.title em{color:var(--accent);font-style:normal}.project-lede{font-family:var(--serif);color:var(--fg-soft);max-width:620px;margin:28px 0 0;font-size:clamp(22px,2.4vw,30px);font-weight:400;line-height:1.4}.project-credit{font-family:var(--mono);letter-spacing:.04em;color:var(--fg-faint);margin:22px 0 0;font-size:12px}.project-credit b{color:var(--fg-soft);font-weight:500}.project-body.prose{max-width:720px;margin:0}.project-back{border-top:1px solid var(--fg-line);margin-top:72px;padding-top:28px}.project-back a{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--fg-soft);font-size:11px;text-decoration:none;transition:color .2s}.project-back a:hover{color:var(--accent)}.shot{border:1px solid var(--fg-line);background:#0a0a0a;margin:48px 0;position:relative;overflow:hidden}.shot.hero-shot{margin:0 0 64px}.shot:after{content:"";background-image:repeating-linear-gradient(135deg,#0000 0 16px,#f3efe60a 16px 17px);position:absolute;inset:0}.shot img{object-fit:cover;z-index:1;width:100%;height:100%;position:absolute;inset:0}.shot figcaption{z-index:2;font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--fg-faint);text-shadow:0 1px 10px #000000b3;font-size:10px;position:absolute;bottom:14px;left:16px}.watch-video{aspect-ratio:720/938;border:1px solid var(--fg-line);background:#000;border-radius:12px;max-width:380px;margin:8px auto 56px;overflow:hidden}.watch-video video{object-fit:cover;width:100%;height:100%;display:block}@media (width<=880px){.project-page main{padding:18vh var(--gutter) 10vh}.project-lede{font-size:20px}}.doc-page main{z-index:1;max-width:880px;padding:22vh var(--gutter) 12vh;margin:0 auto;position:relative}.doc-end{margin-top:7vh}.copy-md{appearance:none;border:1px solid var(--fg-line);color:var(--fg-soft);font-family:var(--mono);letter-spacing:.04em;cursor:pointer;background:0 0;border-radius:6px;padding:6px 11px;font-size:11px;transition:border-color .25s,color .25s;position:relative}.copy-md:hover{border-color:var(--accent);color:var(--accent)}.copy-md:after{content:attr(data-hint);border:1px solid var(--fg-line);background:var(--bg);width:max-content;max-width:230px;color:var(--fg-soft);letter-spacing:0;text-transform:none;opacity:0;pointer-events:none;border-radius:6px;padding:6px 9px;font-size:11px;line-height:1.35;transition:opacity .2s;position:absolute;bottom:calc(100% + 8px);left:0}.copy-md:hover:after{opacity:1}.doc-head{margin-bottom:9vh}.doc-page h1.title{font-family:var(--serif);letter-spacing:-.02em;margin:0;font-size:clamp(48px,7vw,96px);font-style:normal;font-weight:400;line-height:1}.doc-page h1.title em{color:var(--accent);font-style:normal}.doc-lede{font-family:var(--serif);color:var(--fg-soft);margin:28px 0 0;font-size:clamp(20px,2.2vw,26px);font-weight:400;line-height:1.45}.doc-page .prose{max-width:100%}.prose pre.code{border:1px solid var(--fg-line);background:#0b0b0c;border-radius:8px;margin:1.8em 0;padding:18px 20px;overflow-x:auto}.prose pre.code code{color:var(--fg-soft);font-family:var(--mono);letter-spacing:0;white-space:pre;tab-size:2;background:0 0;border:0;border-radius:0;padding:0;font-size:12.5px;line-height:1.6;display:block}.prose .callout{color:var(--fg);background:#5b8bff0d;border:1px solid #5b8bff47;border-radius:8px;margin:1.8em 0;padding:16px 20px;font-size:18px;line-height:1.55}.prose .callout .lbl{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:8px;font-size:10px;display:block}.cicd-examples{grid-template-columns:repeat(3,1fr);gap:12px;margin:9vh 0 2vh;display:grid}.cicd-shot{appearance:none;border:1px solid var(--fg-line);cursor:zoom-in;background:#0b0b0c;border-radius:8px;flex-direction:column;padding:0;transition:border-color .2s,transform .2s;display:flex;overflow:hidden}.cicd-shot:hover{border-color:var(--fg-soft);transform:translateY(-2px)}.cicd-shot img{aspect-ratio:4/3;object-fit:cover;object-position:top;width:100%;display:block}.cicd-shot .cap{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-faint);text-align:left;border-top:1px solid var(--fg-line);padding:9px 12px;font-size:10px}.lightbox{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:zoom-out;background:#000000e6;justify-content:center;align-items:center;padding:4vh 4vw;animation:.2s lbIn;display:flex;position:fixed;inset:0}@keyframes lbIn{0%{opacity:0}to{opacity:1}}.lightbox img{object-fit:contain;border-radius:6px;max-width:100%;max-height:100%;box-shadow:0 24px 70px #0009}.lightbox-close{appearance:none;color:var(--fg-soft);cursor:pointer;background:0 0;border:0;font-size:30px;line-height:1;position:fixed;top:18px;right:24px}.lightbox-close:hover{color:var(--fg)}@media (width<=720px){.cicd-examples{grid-template-columns:1fr;margin:7vh 0 2vh}.cicd-shot img{aspect-ratio:auto}}.prose .workflow{border:1px solid var(--fg-line);background:#f3efe604;border-radius:8px;margin:1.4em 0;overflow:hidden}.prose .workflow>summary{cursor:pointer;font-family:var(--mono);letter-spacing:.04em;color:var(--fg-soft);align-items:center;gap:12px;padding:15px 18px;font-size:12px;list-style:none;transition:color .2s;display:flex}.prose .workflow>summary::-webkit-details-marker{display:none}.prose .workflow>summary:before{content:"+";color:var(--accent);width:12px;font-size:15px;line-height:1}.prose .workflow[open]>summary:before{content:"–"}.prose .workflow>summary:hover{color:var(--fg)}.prose .workflow .wf-title{text-transform:uppercase;letter-spacing:.08em}.prose .workflow .wf-file{color:var(--fg-faint);margin-left:auto}.prose .workflow pre.code{border:0;border-top:1px solid var(--fg-line);border-radius:0;max-height:60vh;margin:0;overflow:auto}@media (width<=880px){.doc-page main{padding:16vh var(--gutter) 10vh}.prose pre.code code{font-size:11.5px}}
