/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-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-ease: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}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-black:#000;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--font-weight-normal:400;--tracking-wide:.025em;--tracking-widest:.1em;--leading-tight:1.25;--leading-snug:1.375;--leading-relaxed:1.625;--ease-in:cubic-bezier(.4, 0, 1, 1);--ease-out:cubic-bezier(0, 0, .2, 1);--ease-in-out:cubic-bezier(.4, 0, .2, 1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@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}*,:before,:after{box-sizing:border-box;margin:0;padding:0;cursor:none!important}}@layer components;@layer utilities{.pointer-events-auto{pointer-events:auto}.pointer-events-none{pointer-events:none}.invisible{visibility:hidden}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.inset-0{inset:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.top-3{top:calc(var(--spacing) * 3)}.right-3{right:calc(var(--spacing) * 3)}.z-10{z-index:10}.z-\[10001\]{z-index:10001}.z-\[10002\]{z-index:10002}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.line-clamp-4{-webkit-line-clamp:4;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.h-7{height:calc(var(--spacing) * 7)}.h-52{height:calc(var(--spacing) * 52)}.h-64{height:calc(var(--spacing) * 64)}.h-full{height:100%}.max-h-\[85vh\]{max-height:85vh}.w-7{width:calc(var(--spacing) * 7)}.w-\[360px\]{width:360px}.w-full{width:100%}.max-w-\[480px\]{max-width:480px}.flex-1{flex:1}.flex-none{flex:none}.flex-shrink{flex-shrink:1}.flex-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,)}.cursor-pointer{cursor:pointer}.resize{resize:both}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.place-items-center{place-items:center}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-0{gap:calc(var(--spacing) * 0)}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-x-2{column-gap:calc(var(--spacing) * 2)}.gap-x-3{column-gap:calc(var(--spacing) * 3)}.gap-y-1{row-gap:calc(var(--spacing) * 1)}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.border{border-style:var(--tw-border-style);border-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-dotted{--tw-border-style:dotted;border-style:dotted}.border-\[var\(--glass-border\)\]{border-color:var(--glass-border)}.border-\[var\(--text-secondary\)\]{border-color:var(--text-secondary)}.bg-\[var\(--bg\)\]{background-color:var(--bg)}.bg-black\/50{background-color:#00000080}@supports (color:color-mix(in lab, red, red)){.bg-black\/50{background-color:color-mix(in oklab, var(--color-black) 50%, transparent)}}.bg-gradient-to-br{--tw-gradient-position:to bottom right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.from-\[var\(--glass-bg\)\]{--tw-gradient-from:var(--glass-bg);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-transparent{--tw-gradient-to:transparent;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.p-6{padding:calc(var(--spacing) * 6)}.px-1\.5{padding-inline:calc(var(--spacing) * 1.5)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.pb-px{padding-bottom:1px}.font-\[\'IBM_Plex_Mono\'\]{font-family:IBM Plex Mono}.font-\[\'Instrument_Serif\'\]{font-family:Instrument Serif}.font-\[\'Inter\'\]{font-family:Inter}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[0\.5rem\]{font-size:.5rem}.text-\[0\.6rem\]{font-size:.6rem}.text-\[0\.45rem\]{font-size:.45rem}.text-\[0\.72rem\]{font-size:.72rem}.text-\[2rem\]{font-size:2rem}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.leading-snug{--tw-leading:var(--leading-snug);line-height:var(--leading-snug)}.leading-tight{--tw-leading:var(--leading-tight);line-height:var(--leading-tight)}.font-normal{--tw-font-weight:var(--font-weight-normal);font-weight:var(--font-weight-normal)}.tracking-wide{--tw-tracking:var(--tracking-wide);letter-spacing:var(--tracking-wide)}.tracking-widest{--tw-tracking:var(--tracking-widest);letter-spacing:var(--tracking-widest)}.text-\[var\(--text\)\]{color:var(--text)}.text-\[var\(--text-secondary\)\]{color:var(--text-secondary)}.italic{font-style:italic}.opacity-0{opacity:0}.opacity-10{opacity:.1}.opacity-55{opacity:.55}.opacity-60{opacity:.6}.blur{--tw-blur:blur(8px);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,)}.drop-shadow{--tw-drop-shadow-size:drop-shadow(0 1px 2px var(--tw-drop-shadow-color,#0000001a)) drop-shadow(0 1px 1px var(--tw-drop-shadow-color,#0000000f));--tw-drop-shadow:drop-shadow(0 1px 2px #0000001a) drop-shadow(0 1px 1px #0000000f);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,)}.grayscale{--tw-grayscale:grayscale(100%);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,)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in{--tw-ease:var(--ease-in);transition-timing-function:var(--ease-in)}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.select-none{-webkit-user-select:none;user-select:none}.\[scrollbar-width\:none\]{scrollbar-width:none}@media (hover:hover){.group-hover\:opacity-50:is(:where(.group):hover *){opacity:.5}.hover\:border-\[var\(--text-secondary\)\]:hover{border-color:var(--text-secondary)}.hover\:text-\[var\(--text\)\]:hover{color:var(--text)}.hover\:shadow-\[0_0_24px_rgba\(var\(--text-secondary-rgb\)\,0\.15\)\]:hover{--tw-shadow:0 0 24px var(--tw-shadow-color,rgba(var(--text-secondary-rgb),.15));box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}}}:root{--frame-v:40px;--bg:#f5f2ed;--text:#1a1a1a;--text-secondary:#555;--text-secondary-rgb:85, 85, 85;--accent:#1a1a1a;--glass-bg:#ffffff40;--glass-border:#ffffff73;--glass-shadow:#00000014;--quote-color:#888;--name-color:#1a1a1a}[data-theme=dark]{--bg:#0e0e0e;--text:#e8e8e8;--text-secondary:#aaa;--text-secondary-rgb:170, 170, 170;--accent:#e8e8e8;--glass-bg:#ffffff14;--glass-border:#ffffff26;--glass-shadow:#0000004d;--quote-color:#777;--name-color:#e8e8e8}html,body{height:100%}body{background-color:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,sans-serif;transition:background-color .6s,color .6s;overflow:hidden}#root{height:100%}body:before{content:"";top:var(--frame-v);bottom:var(--frame-v);border:1px solid var(--text);opacity:.18;pointer-events:none;z-index:9999;transition:top .42s cubic-bezier(.22,.7,.2,1),bottom .42s cubic-bezier(.22,.7,.2,1);position:fixed;left:40px;right:40px}@media (width<=640px){:root{--frame-v:16px}body:before{left:16px;right:16px}}.theme-toggle{transform-origin:50%;z-index:10000;background:var(--bg);letter-spacing:.12em;text-transform:lowercase;color:var(--text-secondary);border:none;padding:.2rem .6rem;font-family:IBM Plex Mono,monospace;font-size:.6rem;font-weight:400;transition:color .3s;position:fixed;bottom:40px;left:40px;transform:translateY(50%)rotate(-90deg)}.theme-toggle:hover{color:var(--text)}@media (width<=640px){.theme-toggle{bottom:16px;left:16px}}.custom-cursor{pointer-events:none;z-index:99999;mix-blend-mode:difference;will-change:left, top;background:#fff;border-radius:50%;width:14px;height:14px;transition:width .2s,height .2s,border-radius .2s;position:fixed;transform:translate(-50%,-50%)}.custom-cursor.cursor-expanded{width:44px;height:44px}@media (hover:none) and (pointer:coarse){.custom-cursor{display:none}*,:before,:after{cursor:auto!important}}::selection{background:var(--text);color:var(--bg)}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"<length-percentage>";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"<length-percentage>";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"<length-percentage>";inherits:false;initial-value:100%}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-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-ease{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}.nav-burger{z-index:10001;-webkit-backdrop-filter:blur(12px);background:#ffffff14;border:1px solid #ffffff24;border-radius:999px;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;padding:12px;transition:background .25s,border-color .25s;display:flex;position:fixed;top:4rem;right:4rem}.nav-burger:hover{background:#ffffff24;border-color:#ffffff40}.nav-burger span{background:var(--text);transform-origin:50%;width:100%;height:1.5px;transition:transform .32s cubic-bezier(.4,0,.2,1),opacity .2s;display:block}.nav-burger--open span:first-child{transform:translateY(6.5px)rotate(45deg)}.nav-burger--open span:nth-child(2){opacity:0;transform:scaleX(0)}.nav-burger--open span:nth-child(3){transform:translateY(-6.5px)rotate(-45deg)}.menu-overlay{z-index:500;background:0 0;position:fixed;overflow:hidden}.menu-overlay--closing{pointer-events:none}.menu-scrim{z-index:499;-webkit-backdrop-filter:blur(24px)saturate(.75)brightness(.4);background:#000000b8;animation:.35s cubic-bezier(.4,0,.2,1) forwards overlay-bg-in;position:fixed;inset:0}.menu-scrim--closing{pointer-events:none;animation:.42s forwards overlay-bg-out}@keyframes overlay-bg-in{0%{opacity:0}to{opacity:1}}@keyframes overlay-bg-out{0%{opacity:1}to{opacity:0}}.menu-grid{grid-template-columns:repeat(6,1fr);grid-auto-rows:calc(16.6667vw - 13.3333px);grid-auto-flow:dense;gap:1px;width:100%;display:grid}.menu-cell--imp3{grid-area:span 2/span 2}.menu-cell--imp3 .menu-cell__label{font-size:clamp(2rem,5.5vw,6rem)}.menu-cell--imp2{grid-area:span 1/span 2}.menu-cell--imp2 .menu-cell__label{font-size:clamp(1.2rem,2.8vw,3rem)}.menu-cell--imp1 .menu-cell__label{color:#ffffff59;font-size:clamp(.85rem,1.6vw,1.8rem)}.menu-cell--imp1:hover .menu-cell__label{color:#ffffffd9}.menu-cell{-webkit-backdrop-filter:blur(28px)saturate(1.35)brightness(.7);text-align:left;background:linear-gradient(135deg,#ffffff0f 0%,#fff0 55%),#0e0e0ed1;border:none;flex-direction:column;justify-content:flex-end;align-items:flex-start;padding:clamp(.5rem,1.5vw,1.25rem);transition:background .25s;display:flex;position:relative;overflow:hidden;box-shadow:inset 1px 1px #ffffff12,inset -1px -1px #00000038}.menu-cell:not(.menu-cell--deco):hover{background:linear-gradient(135deg,#ffffff1f 0%,#fff0 55%),#1c1c1ce0}.menu-cell--active{background:linear-gradient(135deg,#ffffff1a 0%,#fff0 55%),#1c1c1cd9}.menu-cell--deco{pointer-events:none;background:linear-gradient(135deg,#ffffff0a 0%,#fff0 55%),#0e0e0ec7}.menu-cell__num{letter-spacing:.15em;color:#ffffff2e;text-transform:uppercase;font-family:IBM Plex Mono,monospace;font-size:clamp(.45rem,.6vw,.6rem);transition:color .2s;position:absolute;top:clamp(.4rem,1vw,.85rem);left:clamp(.4rem,1vw,.85rem)}.menu-cell:hover .menu-cell__num,.menu-cell--active .menu-cell__num{color:#fff6}.menu-cell__label{color:#ffffff8c;letter-spacing:-.02em;-webkit-user-select:none;user-select:none;font-family:Instrument Serif,serif;font-size:clamp(1.2rem,3vw,3rem);font-weight:400;line-height:1;transition:color .2s}.menu-cell:hover .menu-cell__label{color:#fffffffa}.menu-cell--active .menu-cell__label{color:#ffffffe6}@keyframes cell-from-edge{0%{transform:translate(var(--from-x,0), var(--from-y,0))}to{transform:translate(0)}}@keyframes cell-to-edge{0%{transform:translate(0)}to{transform:translate(var(--from-x,0), var(--from-y,0))}}.menu-cell{animation:cell-from-edge .52s cubic-bezier(.22, .7, .2, 1) var(--delay,0s) both;will-change:transform, opacity}.menu-cell--out{animation:cell-to-edge .4s cubic-bezier(.55, .05, .75, .4) var(--out-delay,0s) both}@media (prefers-reduced-motion:reduce){.menu-cell,.menu-cell--out{animation-duration:1ms}}@media (width<=1024px) and (width>=641px){.menu-grid{grid-template-columns:repeat(4,1fr);grid-auto-rows:calc(25vw - 20px)}.menu-cell--imp3 .menu-cell__label{font-size:clamp(2rem,8vw,5rem)}.menu-cell--imp2 .menu-cell__label{font-size:clamp(1.2rem,4vw,2.5rem)}.menu-cell--imp1 .menu-cell__label{font-size:clamp(.85rem,3vw,1.8rem)}}@media (width<=640px){.nav-burger{top:3rem;right:3rem}.menu-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:calc(50vw - 16px)}.menu-cell--imp3,.menu-cell--imp2{grid-area:span 1/span 1}.menu-cell--imp3 .menu-cell__label{font-size:clamp(1.5rem,9vw,2.8rem)}.menu-cell--imp2 .menu-cell__label{font-size:clamp(1.1rem,7vw,2rem)}.menu-cell--imp1 .menu-cell__label{font-size:clamp(.85rem,5vw,1.5rem)}}.skills-page{justify-content:center;align-items:center;width:100%;max-height:100%;padding:1rem 0;display:flex;overflow-y:auto}.skills-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;width:100%;display:grid}.skill-item{aspect-ratio:1;border:1px solid var(--glass-border,#ffffff14);background-color:#0000;outline:none;place-items:center;padding:1.5rem;transition:border-color .3s,background-color .3s,transform .3s;display:grid;position:relative;overflow:hidden}.skill-item:before{content:"";opacity:0;pointer-events:none;background:radial-gradient(circle at 50% 60%,#ffffff0a,#0000 70%);transition:opacity .35s;position:absolute;inset:0}[data-theme=light] .skill-item:before{background:radial-gradient(circle at 50% 60%,#0000000a,#0000 70%)}.skill-item:hover,.skill-item:focus-visible{border-color:var(--text-secondary);transform:translateY(-2px)}.skill-item:hover:before,.skill-item:focus-visible:before{opacity:1}.skill-icon{filter:grayscale(.35);will-change:transform;font-size:3.5rem;transition:filter .4s,transform .4s,opacity .3s}.skill-item--mono .skill-icon{color:var(--text);opacity:.85}.skill-icon--logo{width:3.5rem;height:3.5rem;color:var(--text);opacity:.85;filter:none;background-color:currentColor;-webkit-mask-position:50%;mask-position:50%;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.skill-item:hover .skill-icon--logo,.skill-item:focus-visible .skill-icon--logo{filter:none;opacity:1}@media (width<=1024px) and (width>=641px){.skill-icon--logo{width:2.8rem;height:2.8rem}}@media (width<=640px){.skill-icon--logo{width:2.2rem;height:2.2rem}}.skill-item:hover .skill-icon,.skill-item:focus-visible .skill-icon{filter:grayscale(0);opacity:1;transform:translateY(-14px)scale(1.05)}.skill-name{text-align:center;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.16em;opacity:0;pointer-events:none;white-space:nowrap;font-family:IBM Plex Mono,monospace;font-size:.7rem;transition:opacity .3s,transform .3s,color .3s;position:absolute;bottom:1.1rem;left:0;right:0;transform:translateY(6px)}.skill-item:hover .skill-name,.skill-item:focus-visible .skill-name{opacity:1;color:var(--text);transform:translateY(0)}.skill-index{letter-spacing:.1em;color:var(--text-secondary);opacity:.35;font-family:IBM Plex Mono,monospace;font-size:.55rem;transition:opacity .3s;position:absolute;top:.6rem;left:.7rem}.skill-item:hover .skill-index,.skill-item:focus-visible .skill-index{opacity:.7}@media (width<=1024px) and (width>=641px){.skills-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.75rem}.skill-icon{font-size:2.8rem}.skill-name{font-size:.62rem;bottom:.8rem}}@media (width<=640px){.skills-grid{grid-template-columns:repeat(3,1fr);gap:.5rem}.skill-item{padding:1rem}.skill-icon{font-size:2.2rem}.skill-name{letter-spacing:.12em;font-size:.55rem;bottom:.6rem}.skill-index{font-size:.5rem;top:.4rem;left:.5rem}}@media (hover:none){.skill-name{opacity:1;transform:none}.skill-icon{filter:grayscale(.1);transform:translateY(-6px)}}.shader-image-wrapper{width:100%;height:100%;position:relative;overflow:hidden}.shader-image{object-fit:cover;object-position:top;filter:grayscale();width:100%;height:100%;transition:filter .4s ease-out;display:block}.shader-image-wrapper:hover .shader-image{filter:grayscale(0)}.carousel-wrapper{flex-direction:column;gap:.75rem;display:flex}.carousel-track{scroll-snap-type:x proximity;scrollbar-width:thin;scrollbar-color:var(--text-secondary) transparent;flex-direction:row;align-items:stretch;gap:1rem;padding-bottom:6px;padding-right:2rem;display:flex;overflow:auto hidden}.carousel-track::-webkit-scrollbar{height:3px}.carousel-track::-webkit-scrollbar-track{background:0 0}.carousel-track::-webkit-scrollbar-thumb{background:var(--text-secondary);opacity:.4}.carousel-progress-bar{background:var(--glass-border);flex-shrink:0;height:1px;position:relative}.carousel-progress-fill{background:var(--text-secondary);opacity:.6;height:100%;transition:width .15s;position:absolute;top:0;left:0}@media (width<=640px){.carousel-track{padding-right:1rem}}.projects-page{width:100%;min-width:0}.contact-group{flex-direction:column;gap:.6rem;display:flex}.contact-group+.contact-group{margin-top:1.5rem}.contact-label{text-transform:uppercase;letter-spacing:.18em;color:var(--text-secondary);opacity:.7;font-family:IBM Plex Mono,monospace;font-size:.65rem;font-weight:400}.contact-emails{flex-direction:column;gap:.4rem;display:flex}.contact-link{color:var(--text);border-bottom:1px dotted #0000;width:fit-content;font-size:.9rem;text-decoration:none;transition:border-color .2s,color .2s}.contact-link:hover{border-bottom-color:var(--text-secondary);color:var(--text-secondary)}.contact-socials{flex-wrap:wrap;gap:.75rem;display:flex}.social-link{color:var(--text-secondary);letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--glass-border,#ffffff14);align-items:center;gap:.5rem;padding:.5rem .7rem;font-family:IBM Plex Mono,monospace;font-size:.7rem;text-decoration:none;transition:color .2s,border-color .2s,background-color .2s,transform .2s;display:inline-flex}.social-link:hover,.social-link:focus-visible{color:var(--text);border-color:var(--text-secondary);background-color:#ffffff08;outline:none;transform:translateY(-1px)}[data-theme=light] .social-link:hover,[data-theme=light] .social-link:focus-visible{background-color:#00000008}.social-icon{flex-shrink:0;justify-content:center;align-items:center;width:1rem;height:1rem;display:inline-flex}.social-icon svg{width:100%;height:100%}.social-name{line-height:1}@media (width<=640px){.contact-socials{gap:.5rem}.social-link{padding:.4rem .55rem;font-size:.6rem}.social-icon{width:.85rem;height:.85rem}}.home-name-overlay{z-index:10;flex-direction:column;gap:.25rem;display:flex;position:fixed;top:4rem;left:4rem}.page-content{transition:opacity .28s}body.menu-is-open .page-content{opacity:0;pointer-events:none}@media (width<=640px){.home-name-overlay{top:2rem;left:2rem}}.page{grid-template:"header header""portrait bio"1fr/auto 1fr;gap:1rem 2rem;height:100dvh;padding:4rem;display:grid;position:relative;overflow:hidden}.page.no-portrait{grid-template-columns:1fr;grid-template-areas:"header""bio"}.name-group{z-index:10;flex-direction:column;grid-area:header;gap:.25rem;display:flex}.portrait-column{z-index:1;grid-area:portrait;align-self:stretch;position:relative;overflow:hidden}.portrait{object-fit:cover;filter:grayscale();width:350px;height:100%;transition:filter .5s;display:block}.portrait-column:hover .portrait{filter:grayscale(0)}.content{grid-area:bio;align-self:end;min-height:0;max-height:100%;animation:.35s viewFadeIn;overflow-y:auto}.content--fill{align-self:stretch;align-items:center;max-height:100%;display:flex;overflow-y:hidden}@keyframes viewFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.text-column{z-index:1;flex-direction:column;gap:1.5rem;display:flex}.greeting{color:var(--text-secondary);letter-spacing:.02em;font-size:1rem;font-weight:400}.section-intro{color:var(--text-secondary);font-size:.9rem;line-height:1.5}.not-found{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:2rem;display:flex;position:fixed;inset:0}.not-found-code{color:var(--text);font-family:Instrument Serif,serif;font-size:clamp(5rem,15vw,12rem);font-weight:400;line-height:1}.not-found-message{color:var(--text-secondary);max-width:30ch;font-size:.9rem;line-height:1.5}.not-found-back{color:var(--text-secondary);text-align:center;background:0 0;border:none;margin-top:.5rem;padding:0;font-family:inherit;font-size:.8rem;transition:color .2s}.not-found-back:hover{color:var(--text)}.bio{flex-direction:column;gap:1rem;display:flex}.bio p{color:var(--text);font-size:1.1rem;font-weight:400;line-height:1.65}.inline-link{color:var(--text);border-bottom:1px dotted var(--text-secondary);text-decoration:none;transition:border-color .2s,color .2s}.inline-link:hover{color:var(--text-secondary);border-bottom-style:solid}.quote{color:var(--quote-color);-webkit-user-select:none;user-select:none;z-index:11;max-width:70%;font-size:1rem;font-style:italic}.bottom-bar{z-index:10}.name-wrapper{-webkit-backdrop-filter:blur(5px);padding:.3rem 0 0}.name{letter-spacing:-.04em;color:var(--name-color);white-space:nowrap;margin:0;font-family:Instrument Serif,serif;font-size:clamp(4.5rem,10vw,10rem);font-weight:300;line-height:.9}@keyframes charOut{0%{opacity:1}to{opacity:0}}@keyframes charIn{0%{opacity:0}to{opacity:1}}.name .char-out{animation-name:charOut;animation-duration:55ms;animation-timing-function:ease-in;animation-delay:calc(var(--i) * 22ms);animation-fill-mode:both}.name .char-in{animation-name:charIn;animation-duration:55ms;animation-timing-function:ease-out;animation-delay:calc(var(--i) * 22ms);animation-fill-mode:both}.quote-cursor{margin-left:1px;font-style:normal;animation:.75s step-end infinite blink-cursor}@keyframes blink-cursor{0%,to{opacity:1}50%{opacity:0}}.name-short{display:none}@media (width<=1024px) and (width>=641px){#root{height:auto;position:fixed;inset:40px;overflow-y:auto}.page{grid-template:"portrait name""portrait quote""bio bio"1fr/auto 1fr;gap:.25rem 1.5rem;height:auto;min-height:100%;padding:3rem;display:grid;overflow:visible}.page.no-portrait{grid-template:"name""quote""bio"1fr/1fr}.name-group{display:contents}.portrait-column{grid-area:portrait;align-self:start}.portrait{width:clamp(140px,25vw,220px);height:auto}.bottom-bar{display:contents}.name-wrapper{-webkit-backdrop-filter:none;grid-area:name;align-self:start}.name{font-size:clamp(2.5rem,8vw,4.5rem)}.name-full{display:none}.name-short{display:inline}.quote{grid-area:quote;align-self:start;max-width:100%;margin:0;font-size:.9rem}.content{grid-area:bio;align-self:start;max-height:none;padding-top:1rem;overflow-y:visible}}@media (width<=640px){#root{height:auto;position:fixed;inset:16px;overflow-y:auto}.page{grid-template:"name""quote""portrait""bio"1fr/1fr;gap:.5rem;height:auto;min-height:100%;padding:3rem 1.5rem;display:grid;overflow:visible}.page.no-portrait{grid-template-rows:auto auto 1fr;grid-template-areas:"name""quote""bio"}.name-group{display:contents}.portrait-column{grid-area:portrait}.portrait{width:100%;max-width:none;height:auto;max-height:none}.bottom-bar{display:contents}.name-wrapper{-webkit-backdrop-filter:none;grid-area:name}.name{font-size:15vw}.name-full{display:none}.name-short{display:inline}.quote{grid-area:quote;max-width:100%;font-size:.85rem}.content{grid-area:bio;align-self:start;max-height:none;padding-top:.5rem;overflow-y:visible}.bio p{font-size:1rem}}
