body{margin:0;min-width:320px;min-height:100vh}.navbar{position:sticky;top:0;z-index:50;background:var(--bg)}.navbar-container{width:min(calc(100% - 2rem),var(--content-max));margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 0}.navbar-logo{font-size:.95rem;font-weight:600}.navbar-actions{display:flex;align-items:center;gap:1rem}.nav-selector{position:relative}.nav-selector-trigger{display:inline-flex;align-items:center;gap:.45rem;padding:.38rem .55rem;border:1px solid transparent;background:transparent;color:var(--muted);font:inherit;cursor:pointer}.nav-selector-trigger.open,.nav-selector-trigger:hover{color:var(--text);background:#1f1f1b0a}.nav-selector-icon{display:inline-flex;align-items:center;justify-content:center;width:1.35rem;height:1.35rem;border-radius:999px;background:#ece8dd;color:var(--muted)}.nav-selector-icon.active{background:color-mix(in srgb,var(--section-accent) 16%,transparent);color:var(--section-accent)}.nav-selector-label{font-size:.92rem}.nav-selector-caret{color:var(--muted)}.nav-selector-menu{position:absolute;top:calc(100% + .45rem);right:0;min-width:11rem;padding:.35rem;border:1px solid var(--line);background:var(--bg);display:grid;gap:.15rem}.nav-selector-item{display:flex;align-items:center;gap:.55rem;padding:.45rem .5rem;color:var(--muted);font-size:.92rem}.nav-selector-item:hover,.nav-selector-item.active{color:var(--text)}.nav-selector-item-icon{display:inline-flex;align-items:center;justify-content:center;width:1.45rem;height:1.45rem;border-radius:999px;background:color-mix(in srgb,var(--section-accent) 16%,transparent);color:var(--section-accent)}@media (max-width: 720px){.navbar-container{width:min(calc(100% - 1.5rem),var(--content-max))}.nav-selector-menu{right:auto;left:0}.nav-selector-label{display:none}}.github-chart{display:grid;gap:.45rem;width:100%;max-width:34rem;margin-top:.55rem;color:var(--muted)}.github-chart-label,.github-chart-fallback{font-size:.82rem;color:var(--muted)}.github-chart-grid{display:grid;grid-auto-flow:column;grid-template-rows:repeat(7,1fr);grid-auto-columns:minmax(0,1fr);gap:.18rem;align-items:stretch}.github-chart-cell{aspect-ratio:1 / 1;width:100%;min-width:0;border-radius:2px;background:var(--cell-color)}.github-chart-cell-placeholder{opacity:.28}.github-chart-cell-loading{background:#e8e3d8;opacity:.5}.github-chart:hover .github-chart-label,.github-chart:hover .github-chart-fallback{color:var(--text)}@media (max-width: 720px){.github-chart-grid{gap:.12rem}}.home-page{padding:2.5rem 0 2rem}.home-index{display:grid;gap:.75rem}.home-intro-line{max-width:34rem;font-size:.95rem;line-height:1.6}.home-links{display:grid;margin-top:.75rem;gap:.55rem}.home-link{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.2rem 0}.home-link-text{display:grid;gap:.2rem}.home-link-title{font-size:.96rem;font-weight:600;color:var(--text)}.home-link-copy{font-size:.88rem;color:var(--muted)}.home-link-icon{display:inline-flex;align-items:center;justify-content:center;width:1.8rem;height:1.8rem;border-radius:999px;background:color-mix(in srgb,var(--section-accent) 14%,transparent);color:var(--section-accent);opacity:0;transform:translateY(2px) scale(.92);transition:opacity .16s ease,transform .16s ease}.home-link:hover .home-link-title{color:var(--section-accent)}.home-link:hover .home-link-icon{opacity:1;transform:translateY(0) scale(1)}@media (hover: none){.home-link-icon{opacity:1;transform:none}}.home-socials{display:flex;flex-wrap:wrap;gap:.9rem 1.2rem;margin-top:2rem}.home-social-link{color:var(--muted);font-size:.9rem}.home-social-link:hover{color:var(--text)}.projects-page{padding:2.5rem 0 2rem}.projects-page-list{display:grid;gap:1rem}.projects-page-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.45rem 1.5rem}.projects-page-main h2{font-size:.98rem;margin-bottom:.18rem}.projects-page-main p{color:var(--muted);font-size:.9rem}.projects-page-meta{min-width:120px;text-align:right}.projects-page-links{display:flex;justify-content:flex-end;gap:.9rem}.projects-page-links a,.projects-page-tags{color:var(--muted);font-size:.88rem}.projects-page-tags{margin-top:.2rem}.projects-page-links a:hover,.projects-page-links a:focus-visible{color:var(--text)}@media (max-width: 640px){.projects-page-item{grid-template-columns:1fr;gap:.3rem}.projects-page-meta{text-align:left}.projects-page-links{justify-content:flex-start}}.blog-page{padding:2.5rem 0 2rem}.blog-page-list{display:grid;gap:1rem}.blog-page-item{display:grid;gap:.18rem}.blog-page-date{color:var(--muted);font-size:.86rem}.blog-page-item h2{font-size:.98rem}.blog-page-excerpt{color:var(--muted);font-size:.9rem}.blog-page-item:hover h2,.blog-page-item:focus-visible h2{color:var(--text)}.blog-post{padding:2.5rem 0 2rem}.blog-post-header{margin-bottom:1.15rem}.blog-post-header h1{font-size:clamp(1.45rem,3vw,2rem);line-height:1.08}.blog-post-meta{display:flex;flex-wrap:wrap;gap:.65rem .9rem;margin-bottom:.5rem;color:var(--muted);font-size:.86rem}.blog-post-meta span{display:inline-flex;align-items:center;gap:.4rem}.blog-post-content{line-height:1.72}.blog-post-content h2{margin:1.35rem 0 .5rem;font-size:1rem}.blog-post-content h3{margin:1.05rem 0 .45rem;font-size:.96rem}.blog-post-content p,.blog-post-content li{font-size:.95rem}.blog-post-content p{margin-bottom:.8rem}.blog-post-content ul,.blog-post-content ol{margin:0 0 .8rem 1.15rem}.blog-post-content strong{font-weight:600}.blog-post-content a{text-decoration:underline;text-underline-offset:.14em}.blog-post-content pre{margin:.95rem 0;padding:.75rem .85rem;background:#efe9dc;border-radius:.3rem;overflow-x:auto}.blog-post-content code{font-family:var(--font-mono);font-size:.88rem}.about-page{padding:2.5rem 0 2rem}.about-copy{display:grid;gap:.8rem;max-width:34rem}.about-copy p{color:var(--text)}.about-copy a{text-decoration:underline;text-underline-offset:.14em}.about-section{margin-top:1.35rem}.about-experience-list{display:grid;gap:1rem}.about-experience-item{display:grid;gap:.18rem}.about-experience-header{margin-bottom:.1rem}.about-experience-header h2{font-size:.98rem}.about-experience-header p,.about-experience-period{color:var(--muted);font-size:.88rem}.about-experience-period{margin-bottom:.18rem}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #f7f5ef;--text: #1f1f1b;--muted: #666257;--line: #d9d4c8;--line-strong: #c8c1b2;--content-max: 620px;--narrow-max: 560px;--font-sans: "Manrope", "Segoe UI", sans-serif;--font-mono: "IBM Plex Mono", "Consolas", monospace;color-scheme:light}html{scroll-behavior:smooth;scrollbar-gutter:stable}body{min-width:320px;min-height:100vh;font-family:var(--font-sans);background:var(--bg);color:var(--text);line-height:1.65}h1,h2,h3,h4,h5,h6{color:var(--text);font-family:var(--font-sans);font-weight:600;line-height:1.15;letter-spacing:-.03em}h1{font-size:clamp(2rem,5vw,3.15rem)}h2{font-size:clamp(1.3rem,2.4vw,1.7rem)}p{font-size:1rem;color:var(--text)}a{color:inherit;text-decoration:none}img{display:block;width:100%}.page-shell{width:min(calc(100% - 2rem),var(--content-max));margin:0 auto}.content-narrow{width:min(calc(100% - 2rem),var(--narrow-max))}.page{min-height:calc(100vh - 120px)}.eyebrow,.section-kicker{display:inline-block;margin-bottom:.8rem;font-size:.78rem;font-weight:600;color:var(--muted)}.section-header-label{display:inline-flex;align-items:center;gap:.4rem}.section-header-icon{display:inline-flex;align-items:center;justify-content:center;width:1.3rem;height:1.3rem;border-radius:999px;background:color-mix(in srgb,var(--section-accent) 16%,transparent);color:var(--section-accent)}.page-header{display:grid;gap:.35rem;margin-bottom:1rem}.page-header h1{font-size:clamp(1.45rem,3vw,2rem);line-height:1.08}.page-intro{max-width:34rem;color:var(--muted);font-size:.95rem;line-height:1.6}.back-link{display:inline-flex;align-items:center;gap:.45rem;margin-bottom:.9rem;color:var(--muted);font-size:.9rem}.back-link:hover,.text-link:hover,a:hover{color:var(--text)}.text-link,.button-link,.button-link-secondary{display:inline-flex;align-items:center;gap:.4rem;color:var(--muted);font-weight:500}::selection{background:#ddd7ca}@media (max-width: 720px){.page-shell,.content-narrow{width:min(calc(100% - 1.5rem),var(--content-max))}h1{font-size:clamp(1.9rem,10vw,2.65rem)}}#root,.app-wrapper{min-height:100vh}.content{min-height:calc(100vh - 120px)}.route-transition{min-height:inherit;will-change:opacity,transform}
