:root{--color-bg:#fff;--color-surface:#f8f9fa;--color-surface-alt:#f9fafb;--color-surface-variant:#e1e3e4;--color-text:#171717;--color-text-muted:#444748;--color-outline:#747878;--color-outline-variant:#c4c7c7;--color-accent:#4d7c0f;--color-accent-ink:#3e6a00;--color-inverse:#fff;--color-navbar-bg:#ffffffe6;--font-serif:"Newsreader",ui-serif,Georgia,serif;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-tech:"Space Grotesk","Inter",sans-serif;--font-mono:ui-monospace,"SF Mono",Menlo,Consolas,monospace;--container-max:800px;--gutter:1.5rem;--section-gap:5rem;--radius:.25rem;--radius-lg:.5rem;font-family:var(--font-sans);--buncss-light:initial;--buncss-dark: ;color-scheme:light}:root[data-theme=dark]{--color-bg:#0f1113;--color-surface:#17191c;--color-surface-alt:#1b1e22;--color-surface-variant:#2a2d31;--color-text:#e8eaed;--color-text-muted:#a7acb1;--color-outline:#6b7075;--color-outline-variant:#333740;--color-accent:#a3c86d;--color-accent-ink:#b6d982;--color-inverse:#0f1113;--color-navbar-bg:#0f1113d9;--buncss-light: ;--buncss-dark:initial;color-scheme:dark}*{box-sizing:border-box}html,body,#root{height:100%}body{background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-size:1rem;line-height:1.6}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}h1,h2,h3,h4{font-family:var(--font-serif);letter-spacing:-.02em;margin:0;font-weight:400;line-height:1.2}p{margin:0}.app{display:flex;background:var(--color-bg);flex-direction:column;min-height:100%}.main{max-width:var(--container-max);padding:8rem var(--gutter)0;flex:1;width:100%;margin:0 auto}.page{padding-bottom:var(--section-gap)}.page>h1{letter-spacing:-.02em;margin-bottom:1rem;font-size:2.5rem}.section{margin-bottom:var(--section-gap)}.section__label{font-family:var(--font-tech);letter-spacing:.05em;text-transform:uppercase;color:var(--color-outline);margin-bottom:2rem;font-size:.875rem;font-weight:500}.navbar{position:fixed;z-index:50;background:var(--color-navbar-bg);backdrop-filter:saturate(180%)blur(8px);-webkit-backdrop-filter:saturate(180%)blur(8px);border-bottom:1px solid var(--color-outline-variant);width:100%;top:0;left:0}.navbar__inner{display:flex;max-width:var(--container-max);padding:0 var(--gutter);justify-content:space-between;align-items: center;height:4rem;margin:0 auto}.navbar__brand{font-family:var(--font-sans);letter-spacing:-.02em;color:var(--color-text);font-size:1.25rem;font-weight:700}.navbar__links{display:none;align-items: center;gap:2rem}@media (min-width:768px){.navbar__links{display:flex}}.navbar__link{font-family:var(--font-serif);letter-spacing:-.01em;text-transform:uppercase;color:var(--color-text-muted);border-bottom:1px solid #0000;padding-bottom:.125rem;transition:color .2s,border-color .2s;font-size:.875rem}.navbar__link:hover{color:var(--color-text)}.navbar__link--active{color:var(--color-text);border-bottom-color:var(--color-text)}.navbar__actions{display:flex;align-items: center;gap:1rem}.navbar__icon{color:var(--color-text);font-size:1.25rem}.navbar__toggle{display:inline-flex;border:1px solid var(--color-outline-variant);border-radius:var(--radius);color:var(--color-text);cursor:pointer;background:0 0;justify-content:center;align-items: center;width:2.25rem;height:2.25rem;padding:0;transition:border-color .15s,color .15s}.navbar__toggle:hover{border-color:var(--color-accent);color:var(--color-accent)}.navbar__toggle:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@media (min-width:768px){.navbar__toggle{display:none}}@media (max-width:767px){.navbar__resume,.navbar__icon{display:none}}.navbar__mobile{display:flex;padding:0 var(--gutter);background:var(--color-navbar-bg);backdrop-filter:saturate(180%)blur(8px);-webkit-backdrop-filter:saturate(180%)blur(8px);overflow:hidden;opacity:0;border-top:1px solid #0000;flex-direction:column;gap:.25rem;max-height:0;transition:max-height .26s,opacity .2s,padding .26s,border-color .26s}.navbar__mobile--open{opacity:1;padding:.5rem var(--gutter)1rem;border-top-color:var(--color-outline-variant);overflow-y:auto;max-height:calc(100vh - 4rem)}@media (min-width:768px){.navbar__mobile{display:none}}@media (prefers-reduced-motion:reduce){.navbar__mobile{transition:none}}.navbar__mobile-link{font-family:var(--font-serif);letter-spacing:-.01em;text-transform:uppercase;color:var(--color-text-muted);border-bottom:1px solid var(--color-outline-variant);padding:.75rem .25rem;transition:color .15s;font-size:1rem}.navbar__mobile-link:hover,.navbar__mobile-link--active{color:var(--color-text)}.navbar__mobile-resume{align-self: flex-start;margin-top:.75rem}.btn{display:inline-flex;font-family:var(--font-serif);letter-spacing:-.01em;text-transform:uppercase;cursor:pointer;border:1px solid #0000;border-radius:0;justify-content:center;align-items: center;padding:.5rem 1rem;transition:transform .12s,background .2s,color .2s;font-size:.875rem}.btn:active{transform:scale(.98)}.btn--primary{background:var(--color-text);color:var(--color-inverse)}.btn--primary:hover{background:#000}.btn--ghost{color:var(--color-text);border-color:var(--color-text);background:0 0}.btn--ghost:hover{background:var(--color-text);color:var(--color-inverse)}.hero{margin-bottom:2.5rem}.hero__title{letter-spacing:-.02em;margin-bottom:1.5rem;font-size:2.5rem;line-height:1.2}.hero__tagline{color:var(--color-text-muted);max-width:42rem;font-size:1.125rem;line-height:1.7}.hero__rule{display:flex;align-items: center;gap:1rem;margin-top:2rem}.hero__rule-line{background:var(--color-outline-variant);opacity:.3;flex:1;height:1px}.hero__rule-tag{font-family:var(--font-mono);letter-spacing:.15em;text-transform:uppercase;color:var(--color-outline);font-size:.8125rem}.competencies{display:grid;grid-template-columns:1fr;gap:3rem}@media (min-width:768px){.competencies{grid-template-columns:repeat(3,1fr)}}.competency__head{display:flex;align-items: center;gap:.5rem;margin-bottom:1rem}.competency__icon{color:var(--color-accent);font-size:1.25rem}.competency__title{font-family:var(--font-serif);font-size:1.125rem;line-height:1.3}.competency__list{list-style:none;display:flex;color:var(--color-text-muted);flex-direction:column;gap:.5rem;margin:0;padding:0}.competency__item{display:flex;align-items: center;gap:.5rem}.competency__dot{background:var(--color-accent);border-radius:9999px;flex:none;width:4px;height:4px}.project-list{display:flex;flex-direction:column;gap:3rem}.project-card{border:1px solid #c4c7c74d;padding:2rem;transition:background .3s}.project-card:hover{background:#fff}.project-card__row{display:flex;flex-direction:column;justify-content:space-between;align-items: flex-start;gap:1.5rem}@media (min-width:768px){.project-card__row{flex-direction:row}}.project-card__body{flex:1}.project-card__title{font-family:var(--font-serif);margin-bottom:.5rem;font-size:1.75rem;line-height:1.3}.project-card__title a{color:inherit}.project-card__title a:hover{color:var(--color-accent-ink)}.project-card__desc{color:var(--color-text-muted);margin-bottom:1.5rem;font-size:1rem;line-height:1.6}.project-card__tags{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;margin:0;padding:0}.project-card__tag{font-family:var(--font-mono);background:var(--color-surface-variant);color:var(--color-text);border-radius:var(--radius);padding:.25rem .5rem;font-size:.8125rem;line-height:1.5}.project-card__media{overflow:hidden;background:#f3f4f5;flex:none;width:100%;height:8rem}@media (min-width:768px){.project-card__media{width:12rem}}.project-card__media img{object-fit:cover;filter:grayscale(100%);opacity:.6;width:100%;height:100%;transition:filter .5s,opacity .5s}.project-card:hover .project-card__media img{filter:grayscale(0);opacity:1}.timeline{position:relative;display:flex;border-left:1px solid #c4c7c74d;flex-direction:column;gap:4rem;padding-left:2rem}.timeline__item{position:relative}.timeline__dot{position:absolute;background:#a3a3a3;border-radius:9999px;width:8px;height:8px;top:.25rem;left:calc(-2rem - 5px)}.timeline__dot--current{background:var(--color-text)}.timeline__period{display:block;font-family:var(--font-mono);letter-spacing:.05em;text-transform:uppercase;color:var(--color-accent-ink);margin-bottom:.5rem;font-size:.8125rem}.timeline__role{font-family:var(--font-serif);margin-bottom:.5rem;font-size:1.25rem;line-height:1.3}.timeline__summary{color:var(--color-text-muted)}.skill-list{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;margin:0;padding:0}.skill-list__item{font-family:var(--font-mono);background:var(--color-surface-alt);border:1px solid var(--color-outline-variant);border-radius:var(--radius-lg);color:var(--color-text);padding:.25rem .6rem;font-size:.8125rem}.contact-form{display:flex;flex-direction:column;gap:1.5rem;max-width:32rem;margin-top:2rem}.contact-form__field{display:flex;flex-direction:column;gap:.375rem}.contact-form__field span{font-family:var(--font-tech);letter-spacing:.05em;text-transform:uppercase;color:var(--color-outline);font-size:.875rem}.contact-form__field input,.contact-form__field textarea{color:var(--color-text);border:none;border-bottom:1px solid var(--color-outline-variant);font:inherit;font-family:var(--font-sans);background:0 0;padding:.5rem 0}.contact-form__field input:focus,.contact-form__field textarea:focus{outline:none;border-bottom:2px solid var(--color-accent)}.contact-form__field textarea{resize:vertical;min-height:6rem}.contact-form__submit{font-family:var(--font-serif);letter-spacing:-.01em;text-transform:uppercase;background:var(--color-text);color:var(--color-inverse);cursor:pointer;border:none;align-self: flex-start;padding:.5rem 1rem;transition:transform .12s,background .2s;font-size:.875rem}.contact-form__submit:hover{background:#000}.contact-form__submit:active{transform:scale(.98)}.contact-form__submit:disabled{opacity:.6;cursor:progress;transform:none}.contact-form__success{color:var(--color-accent-ink);font-family:var(--font-mono)}.contact-form__error{color:#b3261e;font-family:var(--font-mono);font-size:.8125rem}.footer{border-top:1px solid var(--color-outline-variant);margin-top:var(--section-gap);background:var(--color-surface);width:100%}.footer__inner{max-width:var(--container-max);padding:3rem var(--gutter);display:flex;flex-direction:column;justify-content:space-between;align-items: center;gap:1rem;margin:0 auto}@media (min-width:768px){.footer__inner{flex-direction:row}}.footer__meta,.footer__socials a{font-family:var(--font-mono);letter-spacing:.15em;text-transform:uppercase;color:var(--color-text-muted);font-size:.625rem}.footer__socials{display:flex;gap:2rem}.footer__socials a{color:var(--color-outline);transition:color .2s}.footer__socials a:hover{color:var(--color-accent-ink)}.material-symbols-outlined{letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-feature-settings:"liga";-webkit-font-smoothing:antialiased;font-variation-settings:"FILL" 0,"wght" 300,"GRAD" 0,"opsz" 24;font-family:Material Symbols Outlined;font-size:1.25rem;font-style:normal;font-weight:400;line-height:1}.github-card{display:flex;border:1px solid var(--color-outline-variant);border-radius:var(--radius-lg);background:var(--color-surface);align-items: center;gap:1.5rem;padding:1.25rem}.github-card__avatar{overflow:hidden;border:1px solid var(--color-outline-variant);border-radius:9999px;flex:none;width:72px;height:72px}.github-card__avatar img{object-fit:cover;width:100%;height:100%}.github-card__chart{flex:1;min-width:0}.github-card__chart img{width:100%;height:auto}:root[data-theme=dark] .github-card__chart img{filter:invert(.92)hue-rotate(180deg)}@media (max-width:540px){.github-card{flex-direction:column;align-items:stretch}.github-card__avatar{align-self: center}}.latest-post{border:1px solid var(--color-outline-variant);border-radius:var(--radius);background:var(--color-surface);padding:1.25rem 1.5rem}.latest-post__head{display:flex;justify-content:space-between;align-items: center;margin-bottom:.75rem}.latest-post__label{font-family:var(--font-tech);letter-spacing:.1em;text-transform:uppercase;color:var(--color-outline);font-size:.75rem}.latest-post__all{font-family:var(--font-mono);color:var(--color-text-muted);transition:color .2s;font-size:.75rem}.latest-post__all:hover{color:var(--color-accent-ink)}.latest-post__body{display:block;color:inherit}.latest-post__meta{display:flex;font-family:var(--font-mono);color:var(--color-outline);align-items: center;gap:.5rem;margin-bottom:.375rem;font-size:.75rem}.latest-post__title{font-family:var(--font-serif);color:var(--color-text);margin-bottom:.375rem;transition:color .2s;font-size:1.375rem;line-height:1.3}.latest-post__body:hover .latest-post__title{color:var(--color-accent-ink)}.latest-post__excerpt{color:var(--color-text-muted);margin-bottom:.75rem;font-size:.9375rem;line-height:1.55}.latest-post__cta{font-family:var(--font-mono);letter-spacing:.05em;color:var(--color-accent-ink);font-size:.75rem}.blog-list{display:flex;flex-direction:column;gap:2.5rem}.blog-card{border-bottom:1px solid var(--color-outline-variant);padding-bottom:2.5rem}.blog-list .blog-card:last-child{border-bottom:none;padding-bottom:0}.blog-card__meta{display:flex;font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--color-outline);align-items: center;gap:1rem;margin-bottom:.75rem;font-size:.75rem}.blog-card__title{font-family:var(--font-serif);margin-bottom:.5rem;font-size:1.75rem;line-height:1.25}.blog-card__title a{color:var(--color-text);transition:color .2s}.blog-card__title a:hover{color:var(--color-accent-ink)}.blog-card__excerpt{color:var(--color-text-muted);margin-bottom:1rem;line-height:1.6}.blog-card__tags{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;margin:0;padding:0}.blog-card__tag{font-family:var(--font-mono);color:var(--color-text-muted);background:var(--color-surface-alt);border:1px solid var(--color-outline-variant);border-radius:var(--radius);padding:.125rem .5rem;font-size:.75rem}.blog-post{max-width:42rem}.blog-post__back{display:inline-block;font-family:var(--font-mono);color:var(--color-text-muted);margin-bottom:2rem;transition:color .2s;font-size:.8125rem}.blog-post__back:hover{color:var(--color-accent-ink)}.blog-post__header{border-bottom:1px solid var(--color-outline-variant);margin-bottom:3rem;padding-bottom:2rem}.blog-post__meta{display:flex;font-family:var(--font-mono);color:var(--color-outline);align-items: center;gap:.75rem;margin-bottom:1rem;font-size:.8125rem}.blog-post__title{letter-spacing:-.02em;margin-bottom:1.25rem;font-size:2.5rem}.blog-post__tags{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;margin:0;padding:0}.blog-post__tag{font-family:var(--font-mono);color:var(--color-text-muted);background:var(--color-surface-alt);border:1px solid var(--color-outline-variant);border-radius:var(--radius);padding:.125rem .5rem;font-size:.75rem}.blog-post__nav{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--color-outline-variant);gap:1rem;margin-top:4rem;padding-top:2rem}.blog-post__nav-link{display:flex;border:1px solid var(--color-outline-variant);border-radius:var(--radius);flex-direction:column;gap:.25rem;padding:1rem;transition:border-color .2s,background .2s}.blog-post__nav-link:hover{border-color:var(--color-accent);background:var(--color-surface-alt)}.blog-post__nav-link--right{text-align:right}.blog-post__nav-label{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--color-outline);font-size:.6875rem}.blog-post__nav-title{font-family:var(--font-serif);color:var(--color-text);font-size:1rem}.prose{font-family:var(--font-serif);color:var(--color-text);font-size:1.125rem;line-height:1.75}.prose>*+*{margin-top:1.5rem}.prose h1,.prose h2,.prose h3,.prose h4{margin-top:2.5rem;margin-bottom:.75rem;line-height:1.3}.prose h1{font-size:2rem}.prose h2{font-size:1.625rem}.prose h3{font-size:1.25rem}.prose__link{color:var(--color-accent-ink);border-bottom:1px solid var(--color-outline-variant);transition:border-color .2s}.prose__link:hover{border-bottom-color:var(--color-accent)}.prose__code{font-family:var(--font-mono);background:var(--color-surface-variant);border-radius:var(--radius);padding:.125rem .375rem;font-size:.9em}.prose__list{color:var(--color-text);padding-left:1.5rem}.prose__list li+li{margin-top:.5rem}.prose__quote{border-left:2px solid var(--color-accent);color:var(--color-text-muted);margin:0;padding:.25rem 0 .25rem 1.25rem;font-style:italic}.prose__hr{border:none;border-top:1px solid var(--color-outline-variant);margin:3rem 0}.codeblock{border:1px solid var(--color-outline-variant);border-radius:var(--radius);overflow:hidden;background:var(--color-surface-alt);font-family:var(--font-mono);margin:1.5rem 0}.codeblock__head{display:flex;border-bottom:1px solid var(--color-outline-variant);background:var(--color-surface);justify-content:space-between;align-items: center;padding:.5rem .875rem}.codeblock__meta{display:flex;color:var(--color-text-muted);align-items: center;gap:.5rem;font-size:.75rem}.codeblock__title{font-family:var(--font-mono);color:var(--color-text);font-size:.75rem}.codeblock__lang{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--color-outline);font-size:.6875rem}.codeblock__copy{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);border:1px solid var(--color-outline-variant);border-radius:var(--radius);cursor:pointer;background:0 0;padding:.125rem .5rem;transition:color .2s,border-color .2s;font-size:.6875rem}.codeblock__copy:hover{color:var(--color-accent-ink);border-color:var(--color-accent)}.codeblock__body{overflow-x:auto;font-size:.875rem;line-height:1.6}.codeblock__body pre{margin:0;padding:1rem 1.125rem;background:0 0!important}.codeblock__body code{font-family:var(--font-mono)}.codeblock__body--fallback{color:var(--color-text);margin:0;padding:1rem 1.125rem}.codeblock__body .shiki,.codeblock__body .shiki span{color:var(--shiki-light)!important;background-color:var(--shiki-light-bg)!important;font-style:var(--shiki-light-font-style)!important;font-weight:var(--shiki-light-font-weight)!important;text-decoration:var(--shiki-light-text-decoration)!important}:root[data-theme=dark] .codeblock__body .shiki,:root[data-theme=dark] .codeblock__body .shiki span{color:var(--shiki-dark)!important;background-color:var(--shiki-dark-bg)!important;font-style:var(--shiki-dark-font-style)!important;font-weight:var(--shiki-dark-font-weight)!important;text-decoration:var(--shiki-dark-text-decoration)!important}.tooltip{position:relative;display:inline-block;outline:none}.tooltip__trigger{border-bottom:1px dashed var(--color-accent);cursor:help;color:var(--color-text);transition:color .2s}.tooltip:hover .tooltip__trigger{color:var(--color-accent-ink)}.tooltip:focus-visible .tooltip__trigger{color:var(--color-accent-ink)}.tooltip__popover{position:absolute;font-family:var(--font-sans);color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-outline-variant);border-radius:var(--radius);opacity:0;pointer-events:none;z-index:40;width:max-content;min-width:14rem;max-width:22rem;padding:.625rem .75rem;transition:opacity .15s,transform .15s;font-size:.8125rem;font-style:normal;line-height:1.5;bottom:calc(100% + .5rem);left:50%;transform:translate(-50%)translateY(4px);box-shadow:0 6px 20px #0000001f}.tooltip__popover:after{content:"";position:absolute;border:5px solid #0000;border-top-color:var(--color-outline-variant);top:100%;left:50%;transform:translate(-50%)}.tooltip:hover .tooltip__popover{opacity:1;pointer-events:auto;transform:translate(-50%)translateY(0)}.tooltip:focus-visible .tooltip__popover{opacity:1;pointer-events:auto;transform:translate(-50%)translateY(0)}@media (max-width:540px){.tooltip__popover{min-width:11rem;max-width:80vw}}.theme-toggle{position:fixed;display:inline-flex;border:1px solid var(--color-outline-variant);background:var(--color-surface);color:var(--color-text);cursor:pointer;z-index:50;border-radius:9999px;justify-content:center;align-items: center;width:2.5rem;height:2.5rem;transition:background .15s,border-color .15s,transform .15s;bottom:1.25rem;right:1.25rem;box-shadow:0 2px 8px #00000014}.theme-toggle:hover{border-color:var(--color-accent);color:var(--color-accent)}.theme-toggle:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.theme-toggle .material-symbols-outlined{font-size:1.25rem}
