@import url("https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700&display=swap");:root{--bg:#FFFDF8;--bg-secondary:#FFF8E8;--bg-tertiary:#F9F4E8;--bg-card:#FFFFFF;--bg-card-secondary:#FFF9ED;--text:#111827;--text-secondary:#374151;--text-muted:#6B7280;--heading:#111827;--border:#E5E7EB;--border-card:#EEE7D8;--accent:#F5B700;--accent-hover:#E0A800;--accent-active:#C98F00;--accent-bg:rgba(245,183,0,0.14);--secondary:#FF8C00;--secondary-hover:#E67E00;--link:#B77900;--link-hover:#8F5F00;--accent-tech:#2563EB;--accent-nature:#2E7D32;--danger:#DC2626;--shadow-card:0 1px 3px rgba(0,0,0,0.04),0 4px 12px rgba(0,0,0,0.03);--radius:6px;--content-max:1060px;--sidebar-width:260px;--shell-max:calc(var(--sidebar-width) + var(--content-max) + var(--gutter) * 2);--navbar-height:60px;--gutter:1.5rem;color-scheme:light}@media (prefers-color-scheme:dark){:root:not([data-theme=light]){--bg:#0B0F14;--bg-secondary:#121821;--bg-tertiary:#1A2230;--bg-card:#111827;--bg-card-secondary:#172033;--text:#F8FAFC;--text-secondary:#CBD5E1;--text-muted:#94A3B8;--heading:#F8FAFC;--border:#263041;--border-card:#1B2432;--accent:#F5B700;--accent-hover:#FFD24A;--accent-active:#E0A800;--accent-bg:rgba(245,183,0,0.16);--secondary:#FF8C00;--secondary-hover:#FF9F1C;--link:#F5B700;--link-hover:#FFD24A;--accent-tech:#60A5FA;--accent-nature:#4CAF50;--danger:#F87171;--shadow-card:0 1px 3px rgba(0,0,0,0.12),0 4px 12px rgba(0,0,0,0.1);color-scheme:dark}}html[data-theme=dark]{--bg:#0B0F14;--bg-secondary:#121821;--bg-tertiary:#1A2230;--bg-card:#111827;--bg-card-secondary:#172033;--text:#F8FAFC;--text-secondary:#CBD5E1;--text-muted:#94A3B8;--heading:#F8FAFC;--border:#263041;--border-card:#1B2432;--accent:#F5B700;--accent-hover:#FFD24A;--accent-active:#E0A800;--accent-bg:rgba(245,183,0,0.16);--secondary:#FF8C00;--secondary-hover:#FF9F1C;--link:#F5B700;--link-hover:#FFD24A;--accent-tech:#60A5FA;--accent-nature:#4CAF50;--danger:#F87171;--shadow-card:0 1px 3px rgba(0,0,0,0.12),0 4px 12px rgba(0,0,0,0.1);color-scheme:dark}*{box-sizing:border-box}html.no-transitions,html.no-transitions *,html.no-transitions :after,html.no-transitions :before{transition:none!important}html{scroll-behavior:smooth}body,html{background:var(--bg)}body{margin:0;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;font-size:16px;line-height:1.6}a{color:inherit;text-decoration:none}img{max-width:100%}h1,h2,h3,h4{color:var(--heading);font-family:Outfit,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.3;letter-spacing:-.02em}p{margin:0 0 1rem}.navbar{position:-webkit-sticky;position:sticky;top:0;z-index:50;height:var(--navbar-height);border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--bg) 92%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.navbar-inner{justify-content:space-between;height:100%;max-width:var(--content-max);margin:0 auto;padding:0 var(--gutter)}.navbar-inner,.navbar-left{display:flex;align-items:center}.navbar-left{gap:2rem}.navbar-brand{gap:.5rem;color:var(--heading);font-family:Outfit,sans-serif;font-size:1.05rem;font-weight:700;letter-spacing:-.02em}.navbar-brand,.navbar-right{display:flex;align-items:center}.navbar-right{gap:.75rem}.nav-links{display:none;align-items:center;gap:.25rem}.nav-link{display:inline-flex;align-items:center;color:var(--text-muted);font-family:Outfit,sans-serif;font-size:.92rem;font-weight:500;padding:.4rem .65rem;border-radius:var(--radius);transition:background .15s ease,color .15s ease}.nav-link:hover{background:var(--accent-bg);color:var(--heading)}.nav-link-active{background:var(--accent-bg);color:var(--accent);font-weight:600}.nav-link-icon{display:none}.nav-link-text{display:inline}.menu-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text);cursor:pointer;font-size:1.1rem;padding:0;transition:background .15s ease}.menu-button:hover{background:var(--accent-bg)}.mobile-panel{display:none;position:absolute;top:var(--navbar-height);left:0;right:0;background:var(--bg);border-bottom:1px solid var(--border);padding:1rem var(--gutter);box-shadow:0 8px 24px rgba(0,0,0,.08)}.mobile-panel-open{display:flex;flex-direction:column;gap:.25rem}.mobile-panel .nav-links{display:flex;flex-direction:column;align-items:stretch}.mobile-panel .nav-link{padding:.65rem .75rem;font-size:1rem}.icon-button{display:flex;align-items:center;justify-content:center;color:var(--text-muted);padding:.35rem;border:none;background:none;border-radius:var(--radius);cursor:pointer;transition:color .15s ease}.icon-button:hover{color:var(--accent)}.sidebar-top-actions{display:flex;align-items:center;gap:.25rem}.theme-toggle{display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius);background:transparent;color:var(--text-muted);cursor:pointer;font:inherit;padding:.35rem;transition:color .15s ease}.theme-toggle:hover{color:var(--accent)}.theme-toggle-icon{display:inline-grid;place-items:center;font-size:1.35rem;line-height:1}.shell{min-height:100vh;display:flex;flex-direction:column}.sidebar{display:none}.shell-main{flex:1 1;display:flex;flex-direction:column}.desktop-header{display:none}.shell-content{flex:1 1;max-width:var(--content-max);margin:0 auto;padding:2rem var(--gutter) 4rem;width:100%}.sidebar-inner{display:flex;flex-direction:column;gap:1.25rem;padding:1.25rem 1rem}.sidebar-top{justify-content:space-between}.sidebar-brand,.sidebar-top{display:flex;align-items:center}.sidebar-brand{gap:.45rem;color:var(--heading);font-family:Outfit,sans-serif;font-size:1.35rem;font-weight:700;letter-spacing:-.02em}.sidebar-section{display:flex;flex-direction:column;gap:.45rem}.sidebar-role,.sidebar-section a{font-size:1.02rem}.sidebar-role{color:var(--text-muted);margin:0;line-height:1.5}.sidebar-nav,.sidebar-nav .nav-links{display:flex;flex-direction:column}.sidebar-nav .nav-links{align-items:stretch;gap:.1rem}.sidebar-nav .nav-link{display:grid;grid-template-columns:24px 1fr;align-items:center;grid-gap:.5rem;gap:.5rem;width:100%;padding:.55rem .6rem;border-radius:var(--radius);font-size:1.05rem}.sidebar-nav .nav-link-icon{display:inline-flex;justify-content:center;align-items:center;width:22px;height:22px;font-size:.85rem;color:var(--text-muted)}.sidebar-nav .nav-link-active .nav-link-icon,.sidebar-nav .nav-link:hover .nav-link-icon{color:var(--heading)}.sidebar-divider{border:none;margin:0}.sidebar-divider,.site-footer{border-top:1px solid var(--border)}.site-footer{max-width:var(--content-max);margin:0 auto;padding:1.5rem var(--gutter) 2.5rem;width:100%}.footer-inner{justify-content:space-between;flex-wrap:wrap;gap:1rem}.footer-inner,.footer-links{display:flex;align-items:center}.footer-links{gap:1.25rem}.footer-links a{color:var(--text-muted);font-size:.88rem;transition:color .15s ease}.footer-links a:hover{color:var(--accent)}.footer-copy{color:var(--text-muted);font-size:.88rem;margin:0}.not-found-container{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:60vh;gap:1rem}.not-found-container h1{font-size:clamp(2.2rem,5vw,3rem);margin:0;line-height:1.15}.not-found-container p{color:var(--text-muted);font-size:1.05rem;margin:0}.page-layout{display:grid;grid-gap:1.5rem;gap:1.5rem}.article-hero,.page-hero{display:grid;grid-gap:.5rem;gap:.5rem;margin-bottom:1rem}.article-hero h1,.page-hero h1{font-size:clamp(2.2rem,5vw,3rem);margin:0;line-height:1.15}.page-description{color:var(--text-muted);font-size:1.05rem;margin:0;max-width:48rem}.home-hero{display:flex;align-items:flex-start;gap:1.5rem;padding:1.5rem 0 .5rem}.home-avatar{width:120px;height:120px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--heading);font-size:2.4rem}.home-hero-text{display:grid;grid-gap:.5rem;gap:.5rem}.home-hero-text h1{font-size:clamp(1.8rem,4vw,2.5rem);margin:0;line-height:1.2}.home-hero-text p{color:var(--text-muted);font-size:1.05rem;line-height:1.6;margin:0;max-width:38rem}.home-hero-links{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.25rem}.home-hero-links a{color:var(--link);font-weight:500;font-size:.95rem;text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px;transition:color .15s ease}.home-hero-links a:hover{color:var(--link-hover)}.section-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin:2.5rem 0 1rem;border-bottom:2px solid var(--border);padding-bottom:.5rem}.section-header h2{margin:0;font-size:1.6rem;font-weight:700}.section-link{color:var(--accent);font-family:Outfit,sans-serif;font-size:.88rem;font-weight:600;white-space:nowrap;transition:color .15s ease}.section-link:hover{color:var(--accent-hover);text-decoration:underline;text-underline-offset:3px}.post-grid{display:grid;grid-gap:1rem;gap:1rem;grid-template-columns:1fr}.post-card{display:grid;grid-gap:.5rem;gap:.5rem;padding:1rem 1.15rem;background:var(--bg-card);border:2px solid var(--border-card);border-radius:var(--radius);box-shadow:var(--shadow-card);transition:border-color .2s ease,box-shadow .2s ease}.post-card:hover{border-color:var(--accent);box-shadow:0 2px 8px rgba(0,0,0,.06)}.post-card time{color:var(--text-muted);font-size:.82rem}.post-card h3{font-size:1.1rem;font-weight:600;margin:0;line-height:1.35}.post-card p{color:var(--text-muted);font-size:.9rem;margin:0;line-height:1.5}.post-list{display:grid;grid-gap:.2rem;gap:.2rem}.post-row{display:grid;grid-gap:.35rem;gap:.35rem;border-bottom:1px solid var(--border);padding:.7rem 0;transition:background .15s ease}.post-row:hover{background:var(--accent-bg);margin:0 -.5rem;padding:.7rem .5rem;border-radius:var(--radius)}.post-row-date time{color:var(--text-muted);font-size:.82rem}.post-row-body{display:grid;grid-gap:.2rem;gap:.2rem}.post-row-meta{display:flex;align-items:center;flex-wrap:wrap;gap:.45rem;color:var(--text-muted);font-size:.82rem}.post-row h3{font-size:1.15rem;font-weight:600;margin:0;letter-spacing:-.01em}.post-row-title-large{font-size:clamp(1.25rem,1.5vw,1.5rem)}.post-row p{color:var(--text-muted);margin:0;max-width:50ch;font-size:.92rem}.year-group{margin-bottom:1.5rem}.year-heading{display:flex;align-items:center;gap:.75rem;margin-bottom:.35rem}.year-heading h2{margin:0;font-size:1.5rem;font-weight:600}.year-heading span{color:var(--text-muted)}.feature-grid{display:grid;grid-gap:1rem;gap:1rem;grid-template-columns:1fr}.feature-card{display:grid;align-content:start;grid-gap:.5rem;gap:.5rem;padding:1.15rem;background:var(--bg-card);border:2px solid var(--border-card);border-radius:var(--radius);box-shadow:var(--shadow-card);transition:border-color .2s ease}.feature-card:hover{border-color:var(--accent)}.feature-label{color:var(--accent);font-family:Outfit,sans-serif;font-size:.75rem;font-weight:700;letter-spacing:.06em;margin:0;text-transform:uppercase}.feature-card h3{font-size:1.35rem;font-weight:600;margin:0}.feature-card p:last-child{color:var(--text-muted);margin:0;font-size:.9rem}.project-grid,.topic-grid{display:grid;grid-gap:1rem;gap:1rem;grid-template-columns:1fr}.project-card,.topic-card{background:var(--bg-card);border:2px solid var(--border-card);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:1.15rem;transition:border-color .2s ease}.project-card:hover,.topic-card:hover{border-color:var(--accent)}.project-card h3,.topic-card h3{margin:0 0 .3rem;font-size:1.1rem}.project-card p,.topic-card p{color:var(--text-muted);margin:0;font-size:.9rem}.project-year{color:var(--accent);font-family:Outfit,sans-serif;font-size:.75rem;font-weight:700;letter-spacing:.06em;margin:0 0 .3rem;text-transform:uppercase}.project-grid-home{gap:1rem}.project-card-home{min-height:auto}.tag-list{display:flex;flex-wrap:wrap;gap:.5rem}.tag-chip{border:1px solid var(--border-card);border-radius:999px;font-family:Outfit,sans-serif;font-size:.85rem;font-weight:500;padding:.3rem .65rem;transition:border-color .15s ease,background .15s ease}.tag-chip:hover{border-color:var(--accent);background:var(--accent-bg)}.article-layout{display:block}.article-main{display:grid;grid-gap:1.5rem;gap:1.5rem;min-width:0}.article-kicker{color:var(--accent);font-family:Outfit,sans-serif;font-size:.78rem;font-weight:700;letter-spacing:.06em;margin:0;text-transform:uppercase}.article-meta{display:flex;align-items:center;gap:.65rem;color:var(--text-muted);font-size:.88rem}.article-meta-top{margin-bottom:.15rem}.meta-separator{width:4px;height:4px;border-radius:50%;background:var(--text-muted)}.prose{font-size:clamp(1.02rem,1.15vw,1.1rem);line-height:1.75;color:var(--text)}.prose>*{max-width:72ch}.prose h2,.prose h3,.prose h4{margin:2rem 0 .65rem;scroll-margin-top:calc(var(--navbar-height) + 2rem)}.prose h2{border-bottom:1px solid var(--border);padding-bottom:.4rem;font-size:clamp(1.6rem,2.2vw,2rem);font-weight:700}.prose h3{font-size:clamp(1.3rem,1.8vw,1.6rem);font-weight:600}.prose h4{font-size:1.1rem;font-weight:700}.prose p{margin:0 0 1rem}.prose ol,.prose ul{margin:0 0 1.15rem;padding-left:1.35rem}.prose li{margin:.4rem 0}.prose li::marker{color:var(--text-muted)}.prose hr{border:0;border-top:1px solid var(--border);margin:2rem 0}.prose a{color:var(--link);text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:2px}.prose a:hover{color:var(--link-hover)}.prose blockquote{border-left:4px solid var(--accent);color:var(--text-muted);font-size:1.05em;margin:1.5rem 0;padding:.25rem 0 .25rem 1.15rem}.prose blockquote>:last-child{margin-bottom:0}.prose code,.prose pre{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace}.prose pre{overflow-x:auto;background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius);font-size:.9rem;line-height:1.7;margin:1.5rem 0;padding:1rem 1.15rem}.prose :not(pre)>code{background:var(--accent-bg);border-radius:4px;font-size:.9em;padding:.15rem .35rem;color:var(--accent)}.prose pre code{background:transparent;padding:0;color:inherit}.prose table{width:100%;border-collapse:collapse;margin:1.5rem 0}.prose td,.prose th{border-bottom:1px solid var(--border);padding:.75rem .4rem;text-align:left}.prose th{color:var(--heading);font-family:Outfit,sans-serif;font-size:.88rem;font-weight:700}.toc{display:none}.toc-card{position:-webkit-sticky;position:sticky;top:calc(var(--navbar-height) + 1.5rem);display:grid;grid-gap:1rem;gap:1rem;background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius);padding:1rem}.toc-eyebrow{color:var(--text-muted);font-family:Outfit,sans-serif;font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.toc-nav{display:grid;grid-gap:.15rem;gap:.15rem}.toc-link{border-radius:var(--radius);color:var(--text-muted);font-size:.88rem;line-height:1.35;padding:.35rem .5rem;transition:background .15s ease,color .15s ease}.toc-link:hover{background:var(--accent-bg);color:var(--heading)}.toc-link-nested{margin-left:.75rem}.toc-link-active{background:var(--accent-bg);color:var(--accent);font-weight:600}.button{display:inline-flex;align-items:center;width:-moz-fit-content;width:fit-content;border:2px solid var(--accent);border-radius:var(--radius);background:var(--accent);color:var(--heading);font-family:Outfit,sans-serif;font-size:.92rem;font-weight:600;padding:.55rem 1rem;cursor:pointer;transition:background .15s ease,transform .1s ease}.button:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.button:active{transform:scale(.97)}.button-secondary{background:transparent;border:2px solid var(--border-card);color:var(--heading)}.button-secondary:hover{background:var(--accent-bg);border-color:var(--accent);color:var(--accent)}.blog-intro{margin-bottom:1.5rem;max-width:42rem}.blog-intro p{color:var(--text-muted);font-size:1.05rem;margin:0}.home-section{margin-top:0}.desktop-header-label,.home-kicker{display:none}.logo{color:var(--accent);flex-shrink:0}.typing-cursor{display:inline-block;color:var(--accent);animation:blink .7s step-end infinite;margin-left:1px;font-weight:300}@keyframes blink{50%{opacity:0}}@media (min-width:600px){.feature-grid,.post-grid,.project-grid,.topic-grid{grid-template-columns:repeat(2,1fr)}.post-row{grid-template-columns:120px minmax(0,1fr);gap:.65rem;align-items:start}}@media (min-width:800px){.navbar .nav-links{display:flex}.menu-button{display:none}.mobile-panel{display:none!important}.home-avatar{width:120px;height:120px;font-size:2.8rem}.feature-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width:1020px){.navbar{display:none}.shell{display:grid;grid-template-columns:var(--sidebar-width) minmax(0,1fr);max-width:var(--shell-max);margin:0 auto}.sidebar{display:block;position:-webkit-sticky;position:sticky;top:0;height:100vh;overflow-y:auto;border-right:1px solid var(--border)}.shell-main{min-width:0}.shell-content{max-width:none;padding-top:2.5rem}.site-footer{max-width:none}.post-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1200px){.post-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width:1360px){.article-layout{display:grid;grid-template-columns:minmax(0,1fr) 220px;grid-gap:2rem;gap:2rem;align-items:start}.toc{display:block}.toc-card{top:2rem}}.fallback-notice{background:var(--bg-card-secondary);border-left:3px solid var(--accent);padding:.75rem 1rem;margin-bottom:1.5rem;border-radius:4px;font-size:.9rem;color:var(--text-muted)}