:root{--color-mocha:oklch(60.74% 0.054 47.17);--color-mocha-light:oklch(94.1% 0.019 46.81);--color-pantone-gray:oklch(90.16% 0.01 252.82);--color-pantone-olive:oklch(40.88% 0.037 118.04);--color-pantone-accent-1:oklch(54.33% 0.138 35.52);--color-pantone-accent-2:oklch(48.44% 0.114 44.08);--bg-000:60 2.1% 18.4%;--bg-100:60 2.7% 14.5%;--color-primary:oklch(25.075% 0.0251 261.091);--color-text:oklch(25.075% 0.0251 261.091);--color-text-light:oklch(58% 0.03 260);--color-background:oklch(100% 0 0);--color-surface:oklch(90.16% 0.01 252.82);--color-border:oklch(76.973% 0.00313 264.73);--color-accent:oklch(0.646 0.222 41.116);--color-accent-blue:rgb(51,140,171);--color-accent-gold:rgb(236,154,29);--color-accent-green:rgb(97,199,101);--color-accent-red:rgb(234,75,76);--font-size-step--2:clamp(0.5rem,0.8665rem + -0.4886vw,0.7688rem);--font-size-step--1:clamp(0.7075rem,0.8609rem + -0.2045vw,0.82rem);--font-size-step-0:clamp(0.875rem,0.8295rem + 0.2273vw,1rem);--font-size-step-1:clamp(0.9338rem,0.7592rem + 0.8727vw,1.4138rem);--font-size-step-2:clamp(0.9963rem,0.6315rem + 1.8239vw,1.9994rem);--font-size-step-3:clamp(1.0631rem,0.4218rem + 3.2068vw,2.8269rem);--font-size-step-4:clamp(1.1344rem,0.0932rem + 5.2057vw,3.9975rem);--font-size-step-5:clamp(1.21rem,-0.4055rem + 8.0773vw,5.6525rem);--font-sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-mono:var(--font-mono),ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--space-xs:calc(var(--font-size-step-0) * 0.5);--space-sm:calc(var(--font-size-step-0) * 0.75);--space-md:calc(var(--font-size-step-0) * 1);--space-lg:calc(var(--font-size-step-0) * 1.5);--space-xl:calc(var(--font-size-step-0) * 2);--space-2xl:calc(var(--font-size-step-0) * 2.5);--space-3xl:calc(var(--font-size-step-0) * 3);--space-4xl:calc(var(--font-size-step-0) * 3.5);--space-5xl:calc(var(--font-size-step-2) * 4);--my-line-height-tight:1.1;--my-line-height-normal:1.5;--my-line-height-base:var(--my-line-height-normal);--my-line-height-heading:var(--my-line-height-tight);--my-z-index-background:-1;--my-z-index-content:1;--my-z-index-header:50;--my-z-index-menu:60;--my-z-index-loader:9999;--container-sm:640px;--container-md:768px;--container-lg:1024px;--container-xl:1280px;--shadow-sm:0 1px 2px 0 rgb(0 0 0/0.05);--shadow-md:0 4px 6px -1px rgb(0 0 0/0.1);--shadow-lg:0 10px 15px -3px rgb(0 0 0/0.1);--transition-fast:150ms ease;--transition-base:250ms ease;--transition-slow:350ms ease}@media (prefers-color-scheme:dark){:root{--color-text:var(--color-pantone-gray);--color-text-light:oklch(67.042% 0.02325 259.239);--color-background:hsl(var(--bg-100)/1);--color-surface:hsl(var(--bg-000)/1);--color-border:oklch(90.16% 0.01 252.82);--color-primary:oklch(98.8% 0.007 260);--color-primary-dark:oklch(20.38% 0.042 135.52)}}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-feature-settings:normal;line-height:132.5%;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-mono);color:var(--color-text);background-color:var(--color-background);line-height:1.6;letter-spacing:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeSpeed;overscroll-behavior:none;overflow-x:hidden;scroll-snap-type:y mandatory;font-feature-settings:"kern" on,"liga" on}h1,h2,h3,h4,h5,h6{font-weight:450;line-height:1.4;margin-bottom:var(--space-sm)}h1{font-size:clamp(2rem,5vw,3.5rem)}h2{font-size:clamp(1.75rem,4vw,2.5rem)}h3{font-size:clamp(1.5rem,3vw,2rem)}h4{font-size:clamp(1.25rem,2.5vw,1.5rem)}p{margin-bottom:var(--space-sm);line-height:132.5%}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark);text-decoration:underline}mark{background-color:rgb(232,243,232);word-break:break-word;overflow-wrap:break-word}pre{border:1px solid var(--color-border);border-radius:8px;padding:var(--space-md);margin:var(--space-md) 0;overflow-x:auto}code,pre{background:var(--color-surface);font-family:var(--font-mono)}code{font-size:.875em;padding:.125rem .25rem;border-radius:4px}pre code{background:none;padding:0}pre[data-theme]{background:transparent!important;border:1px solid var(--color-border)!important;border-radius:8px!important;padding:var(--space-lg)!important;padding-top:var(--space-xl)!important;margin:var(--space-lg) 0!important;overflow-x:auto;font-family:var(--font-mono)!important;line-height:1.4!important;position:relative;font-feature-settings:"liga" 1,"calt" 1}pre[data-theme] code{background:transparent!important;padding:0!important;border-radius:0!important;font-family:inherit!important;display:block;width:-moz-fit-content;width:fit-content;min-width:100%}.line--highlighted{background-color:rgba(255,255,255,.1);display:block;margin:0 -1rem;padding:0 1rem}.word--highlighted{background-color:rgba(255,255,255,.2);border-radius:4px;padding:.125rem .25rem}pre[data-language]:before{content:attr(data-language);position:absolute;top:.5rem;left:0;padding-left:.75rem;padding-bottom:.25rem;font-size:.75rem;color:var(--color-border);text-transform:uppercase;letter-spacing:.025em;border-bottom:1px solid var(--color-border)!important;width:100%}.container{width:100%;max-width:var(--container-lg);margin:0 auto;padding-block:var(--space-xl);padding-inline:0;display:flex;flex-direction:column}.blog-container{width:100%;max-width:var(--container-xl);margin:0 auto;padding-inline:var(--space-md)}@media (min-width:55em){p{line-height:145%}.container{padding-block:0}.blog-container{padding-inline:var(--space-3xl)}}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-sm) var(--space-md);border:none;border-radius:8px;font-weight:500;text-decoration:none;transition:all var(--transition-fast);cursor:pointer}.btn-primary{background:var(--color-primary);color:var(--color-pantone-olive)}.btn-primary:hover{background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md);color:var(--color-primary)}.grid{display:grid;gap:var(--space-md)}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}@media (max-width:768px){.grid-cols-2,.grid-cols-3{grid-template-columns:1fr}}*{--sc-opsz:1;--sc-slnt:0;--sc-wght:1;font-synthesis:none}@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.pageLayout--col4,.web-app{display:flex;flex-direction:column;margin:0 auto;min-height:100vh;min-height:100dvh}@media (min-width:80em){.header-main,.web-app{max-width:1600px;margin:0 auto}.pageLayout--col4{grid-gap:48px;display:grid;grid-auto-flow:column;grid-template-columns:144px minmax(0,18fr) 144px;grid-template-rows:1fr;max-width:1600px}.pageLayout--main{grid-column:2}.pageLayout--aside--right{grid-column:3}.aside-col--left,.pageLayout--aside--right{align-items:center;display:flex;flex-direction:column}.aside-col--left{height:100vh;grid-column:1}.aside-module--root{min-width:0}}@media screen and (min-width:55em){.project-card{grid-gap:0 4%;padding:var(--space-xl) 0;grid-template-columns:43% 55%;grid-template-areas:"leftHead rightContent";display:grid}}.leftHead{grid-area:leftHead;padding-top:var(--space-sm)}.rightContent{padding-top:var(--space-lg);grid-area:rightContent}.pageLayout--main{position:relative;min-width:0}@media screen and (max-width:80em){.aside-col--left,.pageLayout--aside--right{display:none}}.pageLayout--fixed--100vh{height:100vh;position:fixed;top:0;z-index:1}.aside-module--root{opacity:1;pointer-events:auto;transition:opacity .1s;align-content:space-between;display:grid;grid-template-rows:144px auto 144px;height:100%;padding:48px 0}.aside-module--pos_top{grid-row:1/2}.aside-module--pos_center{grid-row:2/3}.socials-nav--link{border-radius:4px;outline:none;position:relative;cursor:pointer}.socials-nav--icon-wrapper{border-radius:4px;padding:16px;color:var(--color-text);transition:all var(--transition-base)}.socials-nav--icon-wrapper :hover{color:var(--color-accent);box-shadow:var(--shadow-md)}.socials-nav--icon-svg{width:24px;height:24px}.content{z-index:var(--my-z-index-content);max-width:1140px;margin-left:auto;margin-right:auto;padding-left:1rem;padding-right:1rem;position:relative}.header-container{z-index:var(--my-z-index-header);position:fixed;pointer-events:none;width:100vw;top:0;left:0;background-color:transparent;box-shadow:none;transition:background-color .5s var(--my-ease-out-2),box-shadow .5s var(--my-ease-out-2)}.header-container-glass{height:68px;background-color:color-mix(in srgb,var(--c-glass) 12%,transparent);backdrop-filter:blur(8px) url(#glassHeaderFilter) saturate(var(--saturation));-webkit-backdrop-filter:blur(8px) saturate(var(--saturation));box-shadow:inset 0 0 0 1px in srgb,color-mix(var(--c-light) calc(var(--glass-reflex-light) * 10%),transparent),inset 1.8px 3px 0 -2px color-mix(in srgb,var(--c-light) calc(var(--glass-reflex-light) * 90%),transparent),inset -2px -2px 0 -2px color-mix(in srgb,var(--c-light) calc(var(--glass-reflex-light) * 80%),transparent),inset -3px -8px 1px -6px color-mix(in srgb,var(--c-light) calc(var(--glass-reflex-light) * 60%),transparent),inset -.3px -1px 4px 0 color-mix(in srgb,var(--c-dark) calc(var(--glass-reflex-dark) * 12%),transparent),inset -1.5px 2.5px 0 -2px color-mix(in srgb,var(--c-dark) calc(var(--glass-reflex-dark) * 20%),transparent),inset 0 3px 4px -2px color-mix(in srgb,var(--c-dark) calc(var(--glass-reflex-dark) * 20%),transparent),inset 2px -6.5px 1px -4px color-mix(in srgb,var(--c-dark) calc(var(--glass-reflex-dark) * 10%),transparent),0 1px 5px 0 color-mix(in srgb,var(--c-dark) calc(var(--glass-reflex-dark) * 10%),transparent),0 6px 16px 0 color-mix(in srgb,var(--c-dark) calc(var(--glass-reflex-dark) * 8%),transparent);transition:background-color .4s cubic-bezier(1,0,.4,1),box-shadow .4s cubic-bezier(1,0,.4,1),color .4s cubic-bezier(1,0,.4,1);border-bottom-left-radius:1em;border-bottom-right-radius:1em}.glass-header__filter{position:absolute;width:0;height:0;z-index:-1}.app-header-block{display:flex;align-items:center;justify-content:space-between;flex:1;height:var(--my-nav-height)}.app-header-block,.header-main{pointer-events:auto}.header-main--bordered{pointer-events:auto;border-width:0 0 4px;border-image-slice:1;border-image-source:linear-gradient(to right,var(--sc-red-1),var(--color-accent-secondary));border-left:0;border-right:0;border-top:0}.header-nav{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.75rem}.logo-wrap a{font-size:1.4rem;font-weight:700;text-decoration:none;color:var(--gray-lightest)}.nav-stripe{flex:1;height:1px;background:linear-gradient(to right,var(--sc-red-1),var(--color-accent-secondary));margin:0 1rem}.contact{font-size:.875rem;color:var(--gray-lightest)}.section-grid-wrapper{padding-top:2.5rem;padding-bottom:2.5rem}.section-grid-inner{margin-right:auto;margin-left:auto;padding-right:1rem;padding-left:1rem}@media (min-width:640px){.section-grid-inner{max-width:640px;padding-right:1.5rem;padding-left:1.5rem}}@media (min-width:768px){.section-grid-inner{max-width:768px}}@media (min-width:1024px){.section-grid-inner{max-width:1024px;padding-right:2rem;padding-left:2rem}}@media (min-width:1280px){.section-grid-inner{max-width:1280px}}@media (min-width:var(--my-content-max-width )){.section-grid-inner{max-width:var(--my-content-max-width)}}.section-grid-inner{position:relative;height:auto;flex-shrink:1;flex-direction:row;flex-wrap:nowrap;align-items:stretch;width:100%;max-width:var(--container-lg);margin:0 auto;padding-block:var(--space-xl);padding-inline:0;display:flex;flex-direction:column}@media (min-width:55em){.section-grid-inner{padding-block:0}}.section-grid-inner{gap:var(--my-grid-column-gap,0)}.hamburger-button{backface-visibility:hidden}.hamburger-line-1,.hamburger-line-2{backface-visibility:hidden;transition:all .4s var(--my-ease-bounce)}.hamburger-button.is-active .hamburger-line-1{transform:translateY(0) rotate(45deg)}.hamburger-button.is-active .hamburger-line-2{transform:translateY(0) rotate(-45deg)}.menu-button.is-active .burger-line-container:first-child{animation:var(--my-animation-burger-close-1) .5s var(--my-ease-out) forwards}.menu-button.is-active .burger-line-container:nth-child(2){animation:var(--my-animation-burger-close-2) .5s var(--my-ease-out) forwards}.scrollbar-thin{scrollbar-width:thin}.scrollbar-thin::-webkit-scrollbar{width:6px;height:6px}.scrollbar-thin::-webkit-scrollbar-track{background:transparent}.scrollbar-thin::-webkit-scrollbar-thumb{background-color:var(--color-primary);border-radius:9999px;border:1px solid var(--color-accent-primary)}.scrollbar-thin::-webkit-scrollbar-thumb:hover{background-color:var(--color-accent-primary)}.timeline-item{padding:3vw;margin-inline:3vw;border-radius:3vw;background:hsl(0 0% 100%/.1);display:grid;gap:min(2rem,5vw)}@media (min-width:700px){.timeline-item{grid-template-columns:1fr 1fr}}.project{padding:3vw;margin-inline:3vw;border-radius:3vw;background:hsl(0 0% 100%/.1);display:grid;gap:min(2rem,5vw)}@media (min-width:700px){.project{grid-template-columns:1fr 1fr}}.project__name{font-size:clamp(2rem,5vw + .5rem,3rem)}.project p{font-size:clamp(1rem,5vw + .5rem,1.5rem)}.project__img{width:100%;aspect-ratio:1/1;border:2vw solid white;box-shadow:0 0 .5rem rgb(0 0 0/.15)}.post-tag{text-decoration-color:rgb(235,72,136)}::view-transition-old(root){animation:exit-fade .25s ease-out forwards}::view-transition-new(root){animation:enter-fade .25s ease-out .1s backwards}@keyframes exit-fade{0%{opacity:1}to{opacity:0}}@keyframes enter-fade{0%{opacity:0}to{opacity:1}}.anim-initial-state{opacity:0;transform:translate(var(--my-translateX),var(--my-translateY)) rotate(var(--my-rotate)) scale(var(--my-scaleX),var(--my-scaleY))}.anim-final-state{opacity:1;transform:translate(0) rotate(0) scale(1)}.anim-in{transition:transform .8s var(--my-ease-out),opacity .8s var(--my-ease-out);will-change:transform,opacity}html.is-ready .anim-trigger.is-active .anim-initial-state{opacity:1;transform:translate(0) rotate(0) scale(1)}.mask-fade-to-black{-webkit-mask-image:linear-gradient(180deg,rgba(0,0,0,0) 0,black 10%);mask-image:linear-gradient(180deg,rgba(0,0,0,0) 0,black 10%)}@font-face{font-family:monaspaceArgon;src:url(/_next/static/media/036da11928224ebb-s.p.woff2) format("woff2");font-display:swap}@font-face{font-family:monaspaceArgon Fallback;src:local("Arial");ascent-override:69.55%;descent-override:14.72%;line-gap-override:7.36%;size-adjust:135.87%}.__className_ad95ef{font-family:monaspaceArgon,monaspaceArgon Fallback}.__variable_ad95ef{--font-mono-argon:"monaspaceArgon","monaspaceArgon Fallback"}@font-face{font-family:monaspaceNeon;src:url(/_next/static/media/91273a7108032bce-s.p.woff2) format("woff2");font-display:swap}@font-face{font-family:monaspaceNeon Fallback;src:local("Arial");ascent-override:69.55%;descent-override:14.72%;line-gap-override:7.36%;size-adjust:135.87%}.__className_c133ea{font-family:monaspaceNeon,monaspaceNeon Fallback}.__variable_c133ea{--font-mono:"monaspaceNeon","monaspaceNeon Fallback"}