@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial}}}@layer theme{:root,:host{--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--aspect-video:16 / 9;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:"Inter CJK Variable", -apple-system, BlinkMacSystemFont, system-ui, 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}@font-face{font-family:Inter CJK Variable;font-weight:100 900;font-style:normal;font-display:swap;src:url(/fonts/InterCJKVariable.woff2)format("woff2")}:root{--bg:#f7f7f7;--bg-elevated:#fff;--text:#161616}@media (prefers-color-scheme:dark){:root{--bg:#161616;--bg-elevated:#1e1e1e;--text:#f7f7f7}}body{background:var(--bg);color:var(--text);word-break:keep-all;overflow-wrap:break-word;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter CJK Variable,-apple-system,BlinkMacSystemFont,system-ui,sans-serif}::selection{background:var(--text)}@supports (color:color-mix(in lab, red, red)){::selection{background:color-mix(in srgb, var(--text) 12%, transparent)}}::selection{color:var(--text)}@media (hover:hover) and (pointer:fine){*{cursor:none!important}a:active,button:active,[role=button]:active{transform:none}button,[role=button],.portfolio-card,.blog-post-link{transition:transform .3s cubic-bezier(.2,0,0,1),box-shadow .3s cubic-bezier(.2,0,0,1),background-color .3s cubic-bezier(.2,0,0,1)!important}.cursor-lifted{background-color:var(--bg-elevated)!important;transform:scale(1.02)!important;box-shadow:0 1px 2px #0000000a,0 2px 4px #00000005,0 4px 8px #00000005!important}.portfolio-card.cursor-lifted{border-radius:12px;background-color:#0000!important;transform:none!important;box-shadow:0 1px 2px #0000000a,0 2px 4px #00000005,0 4px 8px #00000005!important}.album-cover.cursor-lifted{z-index:10;position:relative;background-color:#0000!important;transform:scale(1.05)!important;box-shadow:0 2px 8px #0000001f,0 1px 3px #00000014!important}a.underline.cursor-lifted,a[class*=underline].cursor-lifted{box-shadow:none!important;background-color:#0000!important;transform:none!important}a.download-btn{background-image:none;transition:transform .2s cubic-bezier(.2,0,0,1)}a.download-btn:hover{background-size:0% 0;transform:scale(1.03)}a.download-btn:active{transform:scale(.97)}}h1,h2,h3{text-wrap:balance}p,li,figcaption{text-wrap:pretty}a,button,[role=button]{transition:transform .15s cubic-bezier(.2,0,0,1)}a:active,button:active,[role=button]:active{transform:scale(.96)}a{background-image:linear-gradient(currentColor,currentColor);background-position:0 100%;background-repeat:no-repeat;background-size:0% 1px;text-decoration:none;transition:background-size .25s cubic-bezier(.2,0,0,1),transform .15s cubic-bezier(.2,0,0,1)}a:hover{background-size:100% 1px}a.underline,a[class*=underline]{text-decoration:underline;-webkit-text-decoration-color:var(--text);-webkit-text-decoration-color:var(--text);-webkit-text-decoration-color:var(--text);text-decoration-color:var(--text);background-image:none}@supports (color:color-mix(in lab, red, red)){a.underline,a[class*=underline]{-webkit-text-decoration-color:color-mix(in srgb, var(--text) 32%, transparent);-webkit-text-decoration-color:color-mix(in srgb, var(--text) 32%, transparent);-webkit-text-decoration-color:color-mix(in srgb, var(--text) 32%, transparent);text-decoration-color:color-mix(in srgb, var(--text) 32%, transparent)}}a.underline,a[class*=underline]{text-underline-offset:2px;text-decoration-thickness:1px;transition:text-decoration-color .2s cubic-bezier(.2,0,0,1),text-decoration-thickness .2s cubic-bezier(.2,0,0,1),transform .15s cubic-bezier(.2,0,0,1)}a.underline:hover,a[class*=underline]:hover{-webkit-text-decoration-color:var(--text);-webkit-text-decoration-color:var(--text);-webkit-text-decoration-color:var(--text);text-decoration-color:var(--text)}@supports (color:color-mix(in lab, red, red)){a.underline:hover,a[class*=underline]:hover{-webkit-text-decoration-color:color-mix(in srgb, var(--text) 72%, transparent);-webkit-text-decoration-color:color-mix(in srgb, var(--text) 72%, transparent);-webkit-text-decoration-color:color-mix(in srgb, var(--text) 72%, transparent);text-decoration-color:color-mix(in srgb, var(--text) 72%, transparent)}}a.underline:hover,a[class*=underline]:hover{text-decoration-thickness:2px}a.underline:active,a[class*=underline]:active{-webkit-text-decoration-color:var(--text);-webkit-text-decoration-color:var(--text);-webkit-text-decoration-color:var(--text);text-decoration-color:var(--text);text-decoration-thickness:2px}a.social-icon{opacity:.72;background-image:none;transition:opacity .2s cubic-bezier(.2,0,0,1),transform .15s cubic-bezier(.2,0,0,1)}a.social-icon:hover{opacity:1;background-size:0% 0}a.social-icon:active{opacity:1}a.portfolio-card,.portfolio-card,a.album-cover{background-image:none}a.portfolio-card:hover,a.blog-post-link:hover,a.album-cover:hover{background-size:0% 0}a.blog-post-link{background-image:none;transition:background-color .15s cubic-bezier(.2,0,0,1),transform .15s cubic-bezier(.2,0,0,1)}a.blog-post-link:active{transform:scale(.96)}.fade-in{opacity:0;filter:blur(4px);transition:opacity .5s cubic-bezier(.2,0,0,1),filter .5s cubic-bezier(.2,0,0,1),transform .5s cubic-bezier(.2,0,0,1);transform:translateY(16px)}.fade-in-visible{opacity:1;filter:blur();transform:translateY(0)}.mdx-content{flex-direction:column;gap:16px;display:flex}.mdx-content h1{letter-spacing:-1.2px;color:var(--text);margin-top:40px;font-size:40px;font-weight:600;line-height:1.3}.mdx-content h2{letter-spacing:-.84px;color:var(--text);margin-top:32px;font-size:28px;font-weight:600;line-height:1.35}.mdx-content h3{letter-spacing:-.6px;color:var(--text);margin-top:24px;font-size:20px;font-weight:600;line-height:1.4}.mdx-content h1:first-child,.mdx-content h2:first-child,.mdx-content h3:first-child{margin-top:0}.mdx-content h1+p,.mdx-content h2+p,.mdx-content h3+p,.mdx-content h1+ul,.mdx-content h2+ul,.mdx-content h3+ul,.mdx-content h1+ol,.mdx-content h2+ol,.mdx-content h3+ol{margin-top:-8px}.mdx-content p{letter-spacing:-.48px;color:var(--text);font-size:16px;font-weight:400;line-height:1.75}@supports (color:color-mix(in lab, red, red)){.mdx-content p{color:color-mix(in srgb, var(--text) 72%, transparent)}}.mdx-content strong{color:var(--text);font-weight:600!important}.mdx-content em{font-style:italic}.mdx-content ul{letter-spacing:-.48px;color:var(--text);padding-left:20px;font-size:16px;line-height:1.5;list-style:outside}@supports (color:color-mix(in lab, red, red)){.mdx-content ul{color:color-mix(in srgb, var(--text) 72%, transparent)}}.mdx-content ul{flex-direction:column;gap:8px;display:flex}.mdx-content ol{letter-spacing:-.48px;color:var(--text);padding-left:20px;font-size:16px;line-height:1.5;list-style:decimal}@supports (color:color-mix(in lab, red, red)){.mdx-content ol{color:color-mix(in srgb, var(--text) 72%, transparent)}}.mdx-content ol{flex-direction:column;gap:8px;display:flex}.mdx-content blockquote{background:var(--text)}@supports (color:color-mix(in lab, red, red)){.mdx-content blockquote{background:color-mix(in srgb, var(--text) 4%, transparent)}}.mdx-content blockquote{letter-spacing:-.48px;color:var(--text);border-radius:12px;padding:16px 20px;font-size:16px;line-height:1.5}@supports (color:color-mix(in lab, red, red)){.mdx-content blockquote{color:color-mix(in srgb, var(--text) 72%, transparent)}}.mdx-content blockquote{flex-direction:column;gap:12px;display:flex}.mdx-content blockquote p{color:inherit}.mdx-content code:not(pre code),code:not(pre code){letter-spacing:-.42px;color:var(--text);font-family:Geist Mono,monospace;font-size:.875em}@supports (color:color-mix(in lab, red, red)){.mdx-content code:not(pre code),code:not(pre code){color:color-mix(in srgb, var(--text) 72%, transparent)}}.mdx-content code:not(pre code),code:not(pre code){background:var(--bg-elevated);outline:1px solid var(--text)}@supports (color:color-mix(in lab, red, red)){.mdx-content code:not(pre code),code:not(pre code){outline:1px solid color-mix(in srgb, var(--text) 8%, transparent)}}.mdx-content code:not(pre code),code:not(pre code){vertical-align:baseline;line-height:inherit;border-radius:6px;padding:.15em .4em}.mdx-content pre{background:var(--bg-elevated);border:1px solid var(--text)}@supports (color:color-mix(in lab, red, red)){.mdx-content pre{border:1px solid color-mix(in srgb, var(--text) 8%, transparent)}}.mdx-content pre{border-radius:12px;padding:16px 20px;overflow-x:auto;box-shadow:0 2px 4px #0000000a,0 1px 2px -1px #0000000a,0 0 1px #0000000a}.mdx-content pre code{letter-spacing:-.48px;color:var(--text);font-family:Geist Mono,monospace;font-size:16px;line-height:1.5}@supports (color:color-mix(in lab, red, red)){.mdx-content pre code{color:color-mix(in srgb, var(--text) 72%, transparent)}}.mdx-content pre code{background:0 0;border:none;border-radius:0;padding:0}.mdx-content img{object-fit:cover;border-radius:6px;width:100%}.mdx-content figure{background:var(--bg-elevated);border:1px solid var(--text);flex-direction:column;gap:6px;display:flex}@supports (color:color-mix(in lab, red, red)){.mdx-content figure{border:1px solid color-mix(in srgb, var(--text) 8%, transparent)}}.mdx-content figure{border-radius:12px;padding:6px;overflow:hidden;box-shadow:0 2px 4px #0000000a,0 1px 2px -1px #0000000a,0 0 1px #0000000a}.mdx-content figure img{border-radius:6px}.mdx-content figcaption{letter-spacing:-.36px;color:var(--text);font-size:12px;line-height:1.5}@supports (color:color-mix(in lab, red, red)){.mdx-content figcaption{color:color-mix(in srgb, var(--text) 48%, transparent)}}.mdx-content figcaption{text-align:center;padding:6px}.mdx-content hr{background:var(--text);border:none;height:1px}@supports (color:color-mix(in lab, red, red)){.mdx-content hr{background:color-mix(in srgb, var(--text) 8%, transparent)}}}@layer components;@layer utilities{.pointer-events-none{pointer-events:none}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.sticky{position:sticky}.-inset-4{inset:calc(var(--spacing) * -4)}.inset-0{inset:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.top-0{top:calc(var(--spacing) * 0)}.top-1\.5{top:calc(var(--spacing) * 1.5)}.top-2{top:calc(var(--spacing) * 2)}.top-3{top:calc(var(--spacing) * 3)}.top-5{top:calc(var(--spacing) * 5)}.top-\[13px\]{top:13px}.top-\[14px\]{top:14px}.top-\[22px\]{top:22px}.top-\[27px\]{top:27px}.top-\[30px\]{top:30px}.right-3{right:calc(var(--spacing) * 3)}.bottom-4{bottom:calc(var(--spacing) * 4)}.left-0{left:calc(var(--spacing) * 0)}.left-1\.5{left:calc(var(--spacing) * 1.5)}.left-2{left:calc(var(--spacing) * 2)}.z-50{z-index:50}.z-\[9999\]{z-index:9999}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mx-4{margin-inline:calc(var(--spacing) * 4)}.mx-auto{margin-inline:auto}.mt-5{margin-top:calc(var(--spacing) * 5)}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.flex{display:flex}.grid{display:grid}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.aspect-square{aspect-ratio:1}.aspect-video{aspect-ratio:var(--aspect-video)}.h-1{height:calc(var(--spacing) * 1)}.h-5{height:calc(var(--spacing) * 5)}.h-6{height:calc(var(--spacing) * 6)}.h-12{height:calc(var(--spacing) * 12)}.h-16{height:calc(var(--spacing) * 16)}.h-\[3px\]{height:3px}.h-\[120px\]{height:120px}.h-\[137px\]{height:137px}.h-\[240px\]{height:240px}.h-full{height:100%}.h-px{height:1px}.min-h-full{min-height:100%}.min-h-screen{min-height:100vh}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.w-6{width:calc(var(--spacing) * 6)}.w-7{width:calc(var(--spacing) * 7)}.w-8{width:calc(var(--spacing) * 8)}.w-9{width:calc(var(--spacing) * 9)}.w-12{width:calc(var(--spacing) * 12)}.w-\[11px\]{width:11px}.w-\[17px\]{width:17px}.w-\[21px\]{width:21px}.w-\[120px\]{width:120px}.w-\[200px\]{width:200px}.w-\[320px\]{width:320px}.w-fit{width:fit-content}.w-full{width:100%}.max-w-\[1000px\]{max-width:1000px}.min-w-0{min-width:calc(var(--spacing) * 0)}.flex-1{flex:1}.shrink-0{flex-shrink:0}.-translate-x-1\/2{--tw-translate-x:calc(calc(1 / 2 * 100%) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.-translate-y-1\/2{--tw-translate-y:calc(calc(1 / 2 * 100%) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-marquee{animation:15s linear infinite marquee}.resize{resize:both}.resize-none{resize:none}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-0\.5{gap:calc(var(--spacing) * .5)}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-2\.5{gap:calc(var(--spacing) * 2.5)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-5{gap:calc(var(--spacing) * 5)}.gap-6{gap:calc(var(--spacing) * 6)}.gap-10{gap:calc(var(--spacing) * 10)}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-\[var\(--text\)\]\/8{border-color:var(--text)}@supports (color:color-mix(in lab, red, red)){.border-\[var\(--text\)\]\/8{border-color:color-mix(in oklab, var(--text) 8%, transparent)}}.bg-\[var\(--bg\)\],.bg-\[var\(--bg\)\]\/80{background-color:var(--bg)}@supports (color:color-mix(in lab, red, red)){.bg-\[var\(--bg\)\]\/80{background-color:color-mix(in oklab, var(--bg) 80%, transparent)}}.bg-\[var\(--bg-elevated\)\]{background-color:var(--bg-elevated)}.bg-\[var\(--text\)\],.bg-\[var\(--text\)\]\/4{background-color:var(--text)}@supports (color:color-mix(in lab, red, red)){.bg-\[var\(--text\)\]\/4{background-color:color-mix(in oklab, var(--text) 4%, transparent)}}.bg-\[var\(--text\)\]\/8{background-color:var(--text)}@supports (color:color-mix(in lab, red, red)){.bg-\[var\(--text\)\]\/8{background-color:color-mix(in oklab, var(--text) 8%, transparent)}}.bg-\[var\(--text\)\]\/12{background-color:var(--text)}@supports (color:color-mix(in lab, red, red)){.bg-\[var\(--text\)\]\/12{background-color:color-mix(in oklab, var(--text) 12%, transparent)}}.bg-transparent{background-color:#0000}.object-contain{object-fit:contain}.object-cover{object-fit:cover}.p-1{padding:calc(var(--spacing) * 1)}.p-1\.5{padding:calc(var(--spacing) * 1.5)}.p-5{padding:calc(var(--spacing) * 5)}.px-0\.5{padding-inline:calc(var(--spacing) * .5)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-5{padding-block:calc(var(--spacing) * 5)}.py-20{padding-block:calc(var(--spacing) * 20)}.py-\[60px\]{padding-block:60px}.pr-1{padding-right:calc(var(--spacing) * 1)}.pr-3{padding-right:calc(var(--spacing) * 3)}.pr-4{padding-right:calc(var(--spacing) * 4)}.pb-4{padding-bottom:calc(var(--spacing) * 4)}.pb-10{padding-bottom:calc(var(--spacing) * 10)}.pl-1{padding-left:calc(var(--spacing) * 1)}.pl-3{padding-left:calc(var(--spacing) * 3)}.pl-4{padding-left:calc(var(--spacing) * 4)}.text-center{text-align:center}.text-right{text-align:right}.align-text-bottom{vertical-align:text-bottom}.font-mono{font-family:var(--font-mono)}.text-\[12px\]{font-size:12px}.text-\[14px\]{font-size:14px}.text-\[16px\]{font-size:16px}.text-\[24px\]{font-size:24px}.text-\[40px\]{font-size:40px}.leading-\[1\.3\]{--tw-leading:1.3;line-height:1.3}.leading-\[1\.4\]{--tw-leading:1.4;line-height:1.4}.leading-\[1\.5\]{--tw-leading:1.5;line-height:1.5}.leading-\[1\.6\]{--tw-leading:1.6;line-height:1.6}.leading-\[1\.45\]{--tw-leading:1.45;line-height:1.45}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-normal{--tw-font-weight:var(--font-weight-normal);font-weight:var(--font-weight-normal)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-\[-0\.36px\]{--tw-tracking:-.36px;letter-spacing:-.36px}.tracking-\[-0\.42px\]{--tw-tracking:-.42px;letter-spacing:-.42px}.tracking-\[-0\.48px\]{--tw-tracking:-.48px;letter-spacing:-.48px}.tracking-\[-0\.72px\]{--tw-tracking:-.72px;letter-spacing:-.72px}.tracking-\[-1\.2px\]{--tw-tracking:-1.2px;letter-spacing:-1.2px}.tracking-\[-2\.7px\]{--tw-tracking:-2.7px;letter-spacing:-2.7px}.tracking-\[-3px\]{--tw-tracking:-3px;letter-spacing:-3px}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-line{white-space:pre-line}.whitespace-pre-wrap{white-space:pre-wrap}.text-\[\#f7f7f7\]\/60{color:#f7f7f799;color:lab(97.2321% 0 0/.6)}.text-\[var\(--bg\)\]{color:var(--bg)}.text-\[var\(--text\)\],.text-\[var\(--text\)\]\/36{color:var(--text)}@supports (color:color-mix(in lab, red, red)){.text-\[var\(--text\)\]\/36{color:color-mix(in oklab, var(--text) 36%, transparent)}}.text-\[var\(--text\)\]\/48{color:var(--text)}@supports (color:color-mix(in lab, red, red)){.text-\[var\(--text\)\]\/48{color:color-mix(in oklab, var(--text) 48%, transparent)}}.text-\[var\(--text\)\]\/72{color:var(--text)}@supports (color:color-mix(in lab, red, red)){.text-\[var\(--text\)\]\/72{color:color-mix(in oklab, var(--text) 72%, transparent)}}.text-\[var\(--text\)\]\/90{color:var(--text)}@supports (color:color-mix(in lab, red, red)){.text-\[var\(--text\)\]\/90{color:color-mix(in oklab, var(--text) 90%, transparent)}}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.underline{text-decoration-line:underline}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.opacity-0{opacity:0}.shadow-\[0px_0px_0px_1px_rgba\(22\,22\,22\,0\.06\)\,0px_2px_4px_0px_rgba\(22\,22\,22\,0\.04\)\,0px_1px_2px_-1px_rgba\(22\,22\,22\,0\.04\)\]{--tw-shadow:0px 0px 0px 1px var(--tw-shadow-color,#1616160f), 0px 2px 4px 0px var(--tw-shadow-color,#1616160a), 0px 1px 2px -1px var(--tw-shadow-color,#1616160a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-\[0px_2px_4px_0px_rgba\(0\,0\,0\,0\.04\)\,0px_1px_2px_-1px_rgba\(0\,0\,0\,0\.04\)\,0px_0px_1px_0px_rgba\(0\,0\,0\,0\.04\)\]{--tw-shadow:0px 2px 4px 0px var(--tw-shadow-color,#0000000a), 0px 1px 2px -1px var(--tw-shadow-color,#0000000a), 0px 0px 1px 0px var(--tw-shadow-color,#0000000a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-\[0px_2px_4px_0px_rgba\(22\,22\,22\,0\.04\)\,0px_1px_2px_-1px_rgba\(22\,22\,22\,0\.04\)\,0px_0px_1px_0px_rgba\(22\,22\,22\,0\.04\)\]{--tw-shadow:0px 2px 4px 0px var(--tw-shadow-color,#1616160a), 0px 1px 2px -1px var(--tw-shadow-color,#1616160a), 0px 0px 1px 0px var(--tw-shadow-color,#1616160a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-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,)}.backdrop-blur-\[32px\]{--tw-backdrop-blur:blur(32px);-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{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))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-150{--tw-duration:.15s;transition-duration:.15s}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.duration-500{--tw-duration:.5s;transition-duration:.5s}.outline-none{--tw-outline-style:none;outline-style:none}@media (hover:hover){.group-hover\:opacity-0:is(:where(.group):hover *){opacity:0}.group-hover\:opacity-100:is(:where(.group):hover *){opacity:1}.group-hover\:brightness-0:is(:where(.group):hover *){--tw-brightness:brightness(0%);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,)}.group-hover\:invert:is(:where(.group):hover *){--tw-invert:invert(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,)}}.placeholder\:text-\[var\(--text\)\]\/24::placeholder{color:var(--text)}@supports (color:color-mix(in lab, red, red)){.placeholder\:text-\[var\(--text\)\]\/24::placeholder{color:color-mix(in oklab, var(--text) 24%, transparent)}}@media (hover:hover){.hover\:bg-\[var\(--text\)\]\/4:hover{background-color:var(--text)}@supports (color:color-mix(in lab, red, red)){.hover\:bg-\[var\(--text\)\]\/4:hover{background-color:color-mix(in oklab, var(--text) 4%, transparent)}}.hover\:bg-\[var\(--text\)\]\/8:hover{background-color:var(--text)}@supports (color:color-mix(in lab, red, red)){.hover\:bg-\[var\(--text\)\]\/8:hover{background-color:color-mix(in oklab, var(--text) 8%, transparent)}}.hover\:text-\[var\(--text\)\]\/72:hover{color:var(--text)}@supports (color:color-mix(in lab, red, red)){.hover\:text-\[var\(--text\)\]\/72:hover{color:color-mix(in oklab, var(--text) 72%, transparent)}}}.focus\:border-\[var\(--text\)\]\/24:focus{border-color:var(--text)}@supports (color:color-mix(in lab, red, red)){.focus\:border-\[var\(--text\)\]\/24:focus{border-color:color-mix(in oklab, var(--text) 24%, transparent)}}.active\:bg-\[var\(--text\)\]\/8:active{background-color:var(--text)}@supports (color:color-mix(in lab, red, red)){.active\:bg-\[var\(--text\)\]\/8:active{background-color:color-mix(in oklab, var(--text) 8%, transparent)}}@media not all and (min-width:750px){.max-\[750px\]\:bottom-2{bottom:calc(var(--spacing) * 2)}.max-\[750px\]\:hidden{display:none}.max-\[750px\]\:h-\[140px\]{height:140px}.max-\[750px\]\:w-auto{width:auto}.max-\[750px\]\:w-full{width:100%}.max-\[750px\]\:flex-1{flex:1}.max-\[750px\]\:flex-col{flex-direction:column}.max-\[750px\]\:gap-1{gap:calc(var(--spacing) * 1)}.max-\[750px\]\:gap-3{gap:calc(var(--spacing) * 3)}.max-\[750px\]\:p-2{padding:calc(var(--spacing) * 2)}.max-\[750px\]\:py-10{padding-block:calc(var(--spacing) * 10)}}@media (prefers-color-scheme:dark){.dark\:invert{--tw-invert:invert(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,)}}}.mdx-portfolio img{border-radius:12px!important}.mdx-portfolio>p,.mdx-portfolio>div,.mdx-portfolio>blockquote,.mdx-portfolio>h1,.mdx-portfolio>h2,.mdx-portfolio>h3,.mdx-portfolio>ul,.mdx-portfolio>ol,.mdx-portfolio>pre{opacity:0;filter:blur(4px);transition:opacity .5s cubic-bezier(.2,0,0,1),filter .5s cubic-bezier(.2,0,0,1),transform .5s cubic-bezier(.2,0,0,1);transform:translateY(16px)}.mdx-portfolio>.is-visible{opacity:1;filter:blur();transform:translateY(0)}.mdx-portfolio p:has(>img){box-shadow:none!important;background:0 0!important;border:none!important;border-radius:0!important;padding:0!important}@media (max-width:750px){.mobile-logo-scale{transform:scale(var(--mobile-scale,.35));max-width:none!important;max-height:none!important}}.mdx-content p:has(>img){background:var(--bg-elevated);border:1px solid var(--text)}@supports (color:color-mix(in lab, red, red)){.mdx-content p:has(>img){border:1px solid color-mix(in srgb, var(--text) 8%, transparent)}}.mdx-content p:has(>img){border-radius:12px;padding:6px;overflow:hidden;box-shadow:0 2px 4px #0000000a,0 1px 2px -1px #0000000a,0 0 1px #0000000a}@keyframes fade-in-view{0%{opacity:0;filter:blur(4px);transform:translateY(8px)}to{opacity:1;filter:blur();transform:translateY(0)}}@keyframes fade-out-view{0%{opacity:1;filter:blur()}to{opacity:0;filter:blur(2px)}}::view-transition-old(root){animation:.15s cubic-bezier(.2,0,0,1) forwards fade-out-view}::view-transition-new(root){animation:.3s cubic-bezier(.2,0,0,1) forwards fade-in-view}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}
