.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}:root{--bg: #fafafa;--bg-secondary: #f4f4f5;--bg-tertiary: #e4e4e7;--text: #52525b;--text-heading: #18181b;--text-muted: #71717a;--border: #e4e4e7;--accent: #6366f1;--accent-hover: #4f46e5;--accent-subtle: rgba(99, 102, 241, .08);--nav-bg: rgba(250, 250, 250, .8);--card-bg: #ffffff;--gradient: linear-gradient(135deg, #6366f1 0%, #a855f7 50%, #6366f1 100%);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .06), 0 2px 4px -2px rgba(0, 0, 0, .04);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .06), 0 4px 6px -4px rgba(0, 0, 0, .04);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--space-4xl: 6rem;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 2rem;--text-4xl: 2.5rem;--text-5xl: 3.5rem;--max-width: 768px;--nav-height: 3.5rem;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease}[data-theme=dark]{--bg: #0a0a0b;--bg-secondary: #141416;--bg-tertiary: #1e1e22;--text: #a0a0ab;--text-heading: #ececef;--text-muted: #5a5a65;--border: #232328;--accent: #818cf8;--accent-hover: #a5b4fc;--accent-subtle: rgba(129, 140, 248, .08);--nav-bg: rgba(20, 20, 22, .85);--card-bg: #141416;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .2);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3), 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .35), 0 2px 4px -2px rgba(0, 0, 0, .25);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4), 0 4px 6px -4px rgba(0, 0, 0, .3)}*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}html{scroll-behavior:smooth;scroll-padding-top:calc(var(--nav-height) + var(--space-2xl));-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:1.7;color:var(--text);background:var(--bg);transition:background var(--transition-slow),color var(--transition-slow);min-height:100vh}::selection{background:var(--accent);color:#fff}.container{max-width:var(--max-width);margin:0 auto;padding:calc(var(--nav-height) + var(--space-3xl)) var(--space-lg) var(--space-3xl);min-height:100vh;position:relative;z-index:1}a{color:var(--accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-hover)}h1,h2,h3,h4,h5,h6{color:var(--text-heading);line-height:1.25;font-weight:600;letter-spacing:-.02em}h1{font-size:var(--text-3xl);font-weight:700;letter-spacing:-.03em}h2{font-size:var(--text-2xl);margin-top:var(--space-2xl);margin-bottom:var(--space-lg)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}p{margin-bottom:var(--space-md)}p:last-child{margin-bottom:0}strong{color:var(--text-heading);font-weight:600}img{max-width:100%;height:auto;display:block}ul,ol{padding-left:1.5em}li{margin-bottom:var(--space-xs)}blockquote{border-left:3px solid var(--accent);padding:var(--space-md) var(--space-lg);margin:var(--space-xl) 0;background:var(--accent-subtle);border-radius:0 var(--radius-md) var(--radius-md) 0;color:var(--text);font-style:italic}blockquote p{margin-bottom:var(--space-sm)}blockquote p:last-child{margin-bottom:0}code{font-family:var(--font-mono);font-size:.875em;background:var(--bg-secondary);padding:.15em .4em;border-radius:var(--radius-sm);border:1px solid var(--border)}pre{overflow-x:auto;padding:var(--space-lg);border-radius:var(--radius-lg);border:1px solid var(--border);margin:var(--space-xl) 0;font-size:var(--text-sm);line-height:1.6}pre code{background:none;padding:0;border:none;font-size:inherit}table{width:100%;border-collapse:collapse;margin:var(--space-xl) 0;font-size:var(--text-sm)}th,td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border);text-align:left}th{font-weight:600;color:var(--text-heading)}hr{border:none;border-top:1px solid var(--border);margin:var(--space-2xl) 0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.page-title{margin-top:0;margin-bottom:var(--space-2xl)}@media(max-width:640px){.container{padding-left:var(--space-md);padding-right:var(--space-md)}h1{font-size:var(--text-2xl)}h2{font-size:var(--text-xl)}}.nav{position:fixed;top:var(--space-md);left:50%;transform:translate(-50%);z-index:100}.nav-inner{display:flex;align-items:center;gap:2px;padding:4px;background:var(--nav-bg);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border:1px solid var(--border);border-radius:var(--radius-full);box-shadow:var(--shadow-lg)}.nav a{padding:.4rem .875rem;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:500;color:var(--text-muted);text-decoration:none;transition:all var(--transition-fast);white-space:nowrap}.nav a:hover{color:var(--text-heading);background:var(--accent-subtle)}.nav a.active{color:var(--text-heading);background:var(--bg-secondary);box-shadow:var(--shadow-xs)}[data-theme=dark] .nav a.active{background:var(--bg-tertiary)}.nav .theme-toggle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;border-radius:var(--radius-full);cursor:pointer;color:var(--text-muted);transition:all var(--transition-fast);margin-left:2px}.nav .theme-toggle:hover{color:var(--text-heading);background:var(--accent-subtle)}.nav .theme-toggle svg{width:16px;height:16px}.nav .theme-toggle .icon-sun{display:none}.nav .theme-toggle .icon-moon,[data-theme=dark] .nav .theme-toggle .icon-sun{display:block}[data-theme=dark] .nav .theme-toggle .icon-moon{display:none}@media(max-width:640px){.nav{top:var(--space-sm);left:var(--space-sm);right:var(--space-sm);transform:none}.nav-inner{justify-content:center}.nav a{padding:.375rem .625rem;font-size:var(--text-xs)}.nav .theme-toggle{width:28px;height:28px}.nav .theme-toggle svg{width:14px;height:14px}}.hero{min-height:60vh;display:flex;flex-direction:column;justify-content:center;padding:var(--space-xl) 0}.hero-name{font-size:clamp(2.5rem,7vw,var(--text-5xl));font-weight:800;line-height:1.05;letter-spacing:-.04em;color:var(--text-heading);margin-bottom:var(--space-lg)}.hero-gradient{background:var(--gradient);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradient-shift 4s ease infinite}@keyframes gradient-shift{0%,to{background-position:0% center}50%{background-position:100% center}}@media(prefers-reduced-motion:reduce){.hero-gradient{animation:none}}.hero-tagline{font-size:var(--text-xl);color:var(--text-muted);font-weight:400;margin-bottom:var(--space-md)}.hero-description{font-size:var(--text-lg);color:var(--text);max-width:520px;line-height:1.7;margin-bottom:var(--space-2xl)}.social-links{display:flex;align-items:center;gap:var(--space-xs);flex-wrap:wrap}.social-links a{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);color:var(--text-muted);transition:all var(--transition-fast)}.social-links a:hover{color:var(--text-heading);background:var(--accent-subtle);transform:translateY(-1px)}.social-links svg{width:18px;height:18px;fill:currentColor}.site-footer{max-width:var(--max-width);margin:0 auto;padding:var(--space-2xl) var(--space-lg) var(--space-xl);text-align:center;color:var(--text-muted);font-size:var(--text-sm)}.site-footer a{color:var(--text-muted);transition:color var(--transition-fast)}.site-footer a:hover{color:var(--text-heading)}.rss-link{margin-left:var(--space-xs)}.post-list{display:flex;flex-direction:column;gap:var(--space-xs)}.blog-post-item{display:block;padding:var(--space-lg);border-radius:var(--radius-lg);text-decoration:none;transition:all var(--transition-fast);border:1px solid transparent}.blog-post-item:hover{background:var(--bg-secondary);border-color:var(--border)}.blog-post-item h3{font-size:var(--text-lg);font-weight:600;color:var(--text-heading);margin-bottom:var(--space-xs);transition:color var(--transition-fast)}.blog-post-item.has-logo{display:flex;align-items:flex-start;gap:var(--space-lg)}.post-logo{width:48px;height:48px;border-radius:var(--radius-md);object-fit:cover;flex-shrink:0;margin-top:2px}.post-item-content{min-width:0}.blog-post-item:hover h3{color:var(--accent)}.blog-post-item .post-description{font-size:var(--text-sm);color:var(--text-muted);line-height:1.5;margin-bottom:var(--space-sm);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.blog-post-item time{font-size:var(--text-xs);color:var(--text-muted);font-variant-numeric:tabular-nums}.card-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-lg)}@media(max-width:640px){.card-grid{grid-template-columns:1fr}}.card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color var(--transition-base),box-shadow var(--transition-base)}.card:hover{border-color:var(--accent);box-shadow:var(--shadow-md)}.card a{display:block;text-decoration:none;color:inherit}.card-image{width:100%;aspect-ratio:16 / 10;object-fit:cover;border-bottom:1px solid var(--border)}.card-body{padding:var(--space-lg)}.card-date{font-size:var(--text-xs);color:var(--text-muted);margin-bottom:var(--space-sm);font-variant-numeric:tabular-nums}.card-body h3{font-size:var(--text-base);font-weight:600;color:var(--text-heading);margin-bottom:var(--space-sm);line-height:1.4}.card:hover .card-body h3{color:var(--accent)}.card-description{font-size:var(--text-sm);color:var(--text-muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.tag{display:inline-block;padding:.2em .65em;font-size:var(--text-xs);font-weight:500;color:var(--accent);background:var(--accent-subtle);border-radius:var(--radius-full);transition:all var(--transition-fast);text-decoration:none}.tag:hover{background:var(--accent);color:#fff}.tag-cloud{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-3xl)}.tag-section{margin-bottom:var(--space-2xl)}.tag-section h2{font-size:var(--text-lg);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border)}.tag-section ul{list-style:none;padding:0}.tag-section li{margin-bottom:var(--space-xs)}.tag-section a{color:var(--text);font-size:var(--text-sm)}.tag-section a:hover{color:var(--accent)}.author-bio{display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-xl);margin:var(--space-2xl) 0;background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border)}.author-bio img{width:56px;height:56px;border-radius:var(--radius-full);object-fit:cover;flex-shrink:0}.author-name{font-weight:600;color:var(--text-heading);font-size:var(--text-sm)}.author-description{color:var(--text-muted);font-size:var(--text-sm)}.post-navigation{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);margin:var(--space-2xl) 0;padding-top:var(--space-xl);border-top:1px solid var(--border)}.post-navigation a{display:block;padding:var(--space-md);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text);transition:all var(--transition-fast)}.post-navigation a:hover{background:var(--bg-secondary);color:var(--accent)}.post-navigation .next{text-align:right}.post-navigation .nav-label{display:block;font-size:var(--text-xs);color:var(--text-muted);margin-bottom:var(--space-xs);text-transform:uppercase;letter-spacing:.05em}.related-posts{margin:var(--space-xl) 0}.related-posts h3{font-size:var(--text-base);margin-bottom:var(--space-md);color:var(--text-muted);font-weight:500}.related-posts ul{list-style:none;padding:0}.related-posts li{margin-bottom:var(--space-sm)}.related-posts a{font-size:var(--text-sm);color:var(--text)}.related-posts a:hover{color:var(--accent)}.about-header{display:flex;align-items:flex-start;gap:var(--space-2xl);margin-bottom:var(--space-3xl)}.about-photo{width:160px;height:160px;border-radius:var(--radius-xl);object-fit:cover;flex-shrink:0;border:3px solid var(--border)}.about-intro h1{margin-bottom:var(--space-md)}.about-intro p{color:var(--text);line-height:1.7}@media(max-width:640px){.about-header{flex-direction:column;align-items:center;text-align:center;gap:var(--space-xl)}.about-photo{width:120px;height:120px}}.timeline{position:relative;padding-left:var(--space-2xl)}.timeline:before{content:"";position:absolute;left:0;top:var(--space-sm);bottom:var(--space-sm);width:2px;background:var(--border);border-radius:1px}.timeline-item{position:relative;padding-bottom:var(--space-xl)}.timeline-item:last-child{padding-bottom:0}.timeline-item:before{content:"";position:absolute;left:calc(-1 * var(--space-2xl) - 4px);top:6px;width:10px;height:10px;border-radius:var(--radius-full);background:var(--accent);border:2px solid var(--bg);box-shadow:0 0 0 2px var(--accent)}.timeline-date{font-size:var(--text-xs);color:var(--text-muted);margin-bottom:var(--space-xs);font-variant-numeric:tabular-nums}.timeline-role{font-weight:600;color:var(--text-heading);font-size:var(--text-sm)}.timeline-company a{font-size:var(--text-sm);color:var(--accent)}.skills-list{display:flex;flex-wrap:wrap;gap:var(--space-sm);list-style:none;padding:0}.skills-list li{padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--text);margin-bottom:0}.lost-container{text-align:center;padding:var(--space-4xl) 0}.lost-container h1{margin-bottom:var(--space-xl)}.lost-container img{margin:0 auto var(--space-xl);border-radius:var(--radius-lg);max-width:400px}.lost-container a{display:inline-block;padding:var(--space-sm) var(--space-xl);background:var(--accent);color:#fff;border-radius:var(--radius-full);font-weight:500;transition:all var(--transition-fast)}.lost-container a:hover{background:var(--accent-hover);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-md)}.read-time{color:var(--text-muted);font-size:var(--text-sm)}.post-header{margin-bottom:var(--space-2xl)}.title-image{width:100%;border-radius:var(--radius-lg);margin-bottom:var(--space-xl)}.post-header-logo{width:64px;height:64px;border-radius:var(--radius-md);object-fit:cover;margin-bottom:var(--space-lg)}.post-header h1{font-size:clamp(1.75rem,4vw,var(--text-3xl));font-weight:700;letter-spacing:-.03em;line-height:1.2;margin-bottom:var(--space-md)}.post-meta{display:flex;align-items:center;gap:var(--space-sm);color:var(--text-muted);font-size:var(--text-sm)}.post-meta .separator{color:var(--border)}.post-tags{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-top:var(--space-md)}.post-content{font-size:var(--text-base);line-height:1.8}.post-content>*+*{margin-top:var(--space-md)}.post-content h2{margin-top:var(--space-2xl);margin-bottom:var(--space-md);font-size:var(--text-xl)}.post-content h3{margin-top:var(--space-xl);margin-bottom:var(--space-md)}.post-content img{border-radius:var(--radius-md);margin:var(--space-md) auto}.post-content a{text-decoration:underline;text-underline-offset:2px;text-decoration-color:var(--accent-subtle)}.post-content a:hover{text-decoration-color:var(--accent)}.breaker,div.breaker{border:none;border-top:1px solid var(--border);margin:var(--space-2xl) 0;display:block}.bigger-image{width:calc(100% + 4rem);max-width:none;margin-left:-2rem;margin-right:-2rem;border-radius:var(--radius-lg)}@media(max-width:640px){.bigger-image{width:calc(100% + 2rem);margin-left:-1rem;margin-right:-1rem;border-radius:var(--radius-md)}}.side-by-side{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);margin:var(--space-xl) 0}@media(max-width:640px){.side-by-side{grid-template-columns:1fr}}.toleft,.toright{overflow:hidden}.toleft img,.toright img{width:100%;border-radius:var(--radius-md)}.evidence{background:#22c55e1a;padding:.1em .3em;border-radius:var(--radius-sm)}[data-theme=dark] .evidence{background:#22c55e26}.spoiler{color:transparent;background:var(--bg-tertiary);border-radius:var(--radius-sm);padding:.1em .3em;cursor:pointer;transition:all var(--transition-base)}.spoiler:hover,.spoiler:focus{color:var(--text);background:transparent}.star{background:#facc1526;padding:.1em .3em;border-radius:var(--radius-sm)}[data-theme=dark] .star{background:#facc151a}.post-content iframe{max-width:100%;border:0}.post-content p:has(>iframe){aspect-ratio:16 / 9;width:100%}.post-content p:has(>iframe) iframe{width:100%;height:100%;border-radius:var(--radius-md)}.post-content video{max-width:100%;border-radius:var(--radius-md)}.post-content .gist{margin:var(--space-xl) 0}.post-content .gist .gist-file{border-radius:var(--radius-md)!important;border-color:var(--border)!important}.post-content .gist .gist-data{border-radius:var(--radius-md) var(--radius-md) 0 0!important}.post-content .gist .gist-meta{border-radius:0 0 var(--radius-md) var(--radius-md)!important}
