@font-face{font-family:SkipStdB;src:url(/fonts/FOT-Skip%20Std%20B.woff2) format("opentype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:RodinPro;src:url(/fonts/FOT-Rodin%20Pro%20DB.woff2) format("opentype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:NewRodinPro;src:url(/fonts/FOT-NewRodin%20Pro%20DB.woff2) format("opentype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:BMSpace;src:url(/fonts/BMSPA___.woff2) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:JetBrainsMono;src:url(/fonts/JetBrainsMono-Regular.woff2) format("truetype");font-weight:400;font-style:normal;font-display:swap}:root{--bg: #252221;--fg: #f7f4f0;--fg-muted: #c7c2bb;--accent: #2f6fff;--transition-fast: .2s ease;--transition-base: .3s ease;--transition-theme: background-color .3s ease, color .3s ease, border-color .3s ease, box-shadow .3s ease;--accent-strong: #1b4fd8;--accent-soft: #9bb9ff;--accent-glow: rgba(47, 111, 255, .24);--selection-gradient: linear-gradient(90deg, rgba(47, 111, 255, .22) 0%, rgba(47, 111, 255, .1) 48%, rgba(47, 111, 255, 0) 100%);--secondary-accent: var(--accent-strong);--highlight-accent: var(--accent-soft);--dynamic-accent: rgba(47, 111, 255, .16);--surface: #2d2a29;--surface-border: rgba(255, 255, 255, .12);--card-bg: #2d2a29;--card-border: rgba(255, 255, 255, .14);--card-shadow: 0 14px 30px rgba(0, 0, 0, .35);--chip-bg: rgba(255, 255, 255, .08);--chip-border: rgba(255, 255, 255, .2);--subtle: var(--surface-border);--link-color: var(--accent);--link-hover-color: var(--accent-strong);--blue-highlight: var(--accent-soft);--hover-skill-text: var(--bg);--code-bg: #1d2021;--main-font: "SkipStdB", sans-serif;--secondary-font: "RodinPro", sans-serif;--tertiary-font: "NewRodinPro", sans-serif;--quaternary-font: "BMSpace", monospace;--code-font: "JetBrainsMono", monospace;--space-1: 8px;--space-2: 12px;--space-3: 16px;--space-4: 24px;--space-5: 32px;--mobile-nav-height: 64px;--mobile-drawer-width: 214px;--mobile-fab-gap: 10px;--mobile-theme-toggle-width: 66px}html[data-theme=light]{--bg: #fffaf3;--fg: #37352f;--fg-muted: #5b6474;--surface: #fffdf8;--surface-border: rgba(27, 34, 48, .12);--card-bg: #fffdf8;--card-border: rgba(27, 34, 48, .12);--card-shadow: 0 18px 40px rgba(27, 34, 48, .12);--chip-bg: rgba(47, 111, 255, .08);--chip-border: rgba(47, 111, 255, .18);--dynamic-accent: rgba(47, 111, 255, .12);--hover-skill-text: var(--fg);--code-bg: #f5f2ed}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}html{background-color:var(--bg)}body,html{margin:0;padding:0;font-family:var(--main-font);background-color:var(--bg);color:var(--fg);height:100%;display:flex;flex-direction:column;overflow-x:hidden}html.theme-change-lock,html.theme-change-lock *,html.theme-change-lock *:before,html.theme-change-lock *:after{transition:none!important}html.theme-change-lock .theme-toggle,html.theme-change-lock .theme-toggle *,html.theme-change-lock .theme-toggle *:before,html.theme-change-lock .theme-toggle *:after{transition-property:background-color,color,border-color,box-shadow,opacity,fill,stroke!important;transition-duration:.14s!important;transition-timing-function:ease!important}script,style,meta,link,head,title{transition:none!important}h1,h2{font-family:var(--quaternary-font)}h3{font-family:var(--secondary-font)}h4,h5,h6{font-family:var(--tertiary-font)}*{box-sizing:border-box}ul,ol{list-style:none!important;list-style-type:none!important;list-style-image:none!important;margin:0;padding:0}ul li,ol li{list-style:none!important;list-style-type:none!important;list-style-image:none!important;display:block!important}li::marker{content:none!important;color:transparent!important;font-size:0!important;display:none!important}#content{flex-grow:1;display:flex;position:relative;padding-top:50px;z-index:2}.mobile-nav-floating,.mobile-nav-backdrop{display:none}.mobile-nav-floating{position:fixed;right:calc(16px + var(--mobile-theme-toggle-width) + var(--mobile-fab-gap));top:16px;z-index:1400}.mobile-nav-toggle{appearance:none;display:inline-flex;align-items:center;justify-content:center;padding:12px;border:1px solid var(--surface-border);border-radius:6px;background-color:var(--bg);color:var(--fg);font-family:var(--main-font);font-size:.8rem;font-weight:600;line-height:1;cursor:pointer;box-shadow:0 4px 24px #0003;transition:var(--transition-theme)}.mobile-nav-toggle:hover{background-color:var(--surface);border-color:var(--accent)}.mobile-nav-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.mobile-nav-toggle-icon{width:16px;height:16px;flex:0 0 auto}.mobile-nav-backdrop{position:fixed;inset:0;border:0;padding:0;background:#0b0d1242;z-index:1200}#navbar{position:fixed;top:75px;z-index:20;padding:0;transition:var(--transition-theme)}.navbar-image{display:block;width:80px;height:80px;aspect-ratio:1 / 1;object-fit:contain;margin:0 auto var(--space-4) auto;border-radius:8px}#navbar ul{list-style:none;padding:0;margin-left:var(--space-4);margin-right:var(--space-4)}#navbar li{margin-bottom:5px;position:relative;transform:none;background-color:transparent;width:auto;min-width:0;box-shadow:none}#navbar a{display:block;padding:8px 16px;color:var(--fg-muted);text-decoration:none;font-weight:700;font-size:1.1em;text-transform:uppercase;letter-spacing:.12em;position:relative;border-radius:4px;transition:var(--transition-theme)}#navbar a:before{content:none}#navbar a.is-active{color:var(--accent);background-image:var(--selection-gradient)}#navbar ul:hover a.is-active:not(:hover){background-image:none;color:var(--fg-muted)}#navbar a:hover{color:var(--fg);background-image:var(--selection-gradient)}.theme-toggle{position:fixed;top:24px;right:32px;z-index:30;background-color:var(--bg);color:var(--fg);border:1px solid var(--surface-border);border-radius:6px;padding:8px 14px;font-size:.75em;font-weight:600;letter-spacing:.08em;cursor:pointer;transition:var(--transition-theme);display:inline-flex;align-items:center;gap:8px;font-family:var(--main-font);text-transform:uppercase}.theme-toggle:hover{background-color:var(--surface);border-color:var(--accent)}.theme-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.theme-toggle__icon{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;transition:opacity .2s ease}.theme-icon{width:16px;height:16px;flex-shrink:0}.theme-label{display:inline}.theme-toggle__icon--sun{color:#f2c76d}.theme-toggle__icon--moon{color:var(--accent-soft)}html[data-theme=light] .theme-toggle__icon--sun{opacity:1}html[data-theme=light] .theme-toggle__icon--moon,html[data-theme=dark] .theme-toggle__icon--sun{opacity:.35}html[data-theme=dark] .theme-toggle__icon--moon{opacity:1}#main-content{flex-grow:1;padding:var(--space-4) var(--space-4) var(--space-4) calc(var(--space-4) * 10);position:relative;z-index:1;overflow-y:auto;user-select:text;transition:var(--transition-theme)}#main-content h1{font-size:2.8em;font-weight:700;font-family:var(--main-font);color:var(--accent);margin-top:0;margin-bottom:var(--space-4);position:relative;display:inline-block;padding-bottom:var(--space-2);letter-spacing:-.02em;line-height:1.1;transition:color .3s ease}#main-content h1:after{content:"";position:absolute;bottom:0;left:0;width:60px;height:3px;background-color:var(--accent);transition:background-color .3s ease}#main-content h2{font-size:1.5em;font-weight:700;color:var(--fg);margin-top:var(--space-4);margin-bottom:var(--space-2);letter-spacing:-.01em;transition:color .3s ease}#main-content h3{font-size:1.2em;font-weight:700;color:var(--fg);margin-top:var(--space-3);margin-bottom:var(--space-1);transition:color .3s ease}#main-content h4{font-size:1em;font-weight:600;color:var(--fg-muted);margin-top:var(--space-2);margin-bottom:var(--space-1);text-transform:uppercase;letter-spacing:.04em;font-size:.9em;transition:color .3s ease}.page-header,#main-header{margin-bottom:var(--space-4);display:grid;gap:0}#main-content .page-header h1,#main-content #main-header h1{margin-bottom:0}.summary-with-hero{display:flex;align-items:center;gap:var(--space-4)}.summary-with-hero .summary-text{flex:1;min-width:0}.summary-with-hero .summary-text p:first-child{margin-top:0}#main-content .hero-hint{margin-bottom:0}.landing-content h2{margin-top:var(--space-4)}#main-content p{line-height:1.7;margin-bottom:var(--space-2)}#main-content a:not(#navbar a):not(.content-card-title-link):not(.social-links a){color:var(--link-color);text-decoration:none;font-weight:700;position:relative;transition:color .3s ease}#main-content a:not(#navbar a):not(.content-card-title-link):not(.social-links a):hover{color:var(--link-hover-color);text-decoration:none}#main-content a:not(#navbar a):not(.content-card-title-link):not(.social-links a):after{content:"";position:absolute;width:100%;height:2px;bottom:-2px;left:0;background-color:var(--link-color);transform:scaleX(0);transform-origin:bottom left;transition:transform .3s ease-in-out,background-color .2s ease}#main-content a:not(#navbar a):not(.content-card-title-link):not(.social-links a):hover:after{transform:scaleX(1);background-color:var(--link-hover-color)}#main-content ul{list-style:none!important;list-style-type:none!important;padding-left:var(--space-4);margin-bottom:var(--space-2)}#main-content ul ul{margin-top:var(--space-1);margin-bottom:var(--space-1);padding-left:var(--space-3)}#main-content ul ul li{margin-bottom:calc(var(--space-1) * .75)}#main-content ul li{margin-bottom:0;position:relative;padding-left:var(--space-3);list-style:none!important;list-style-type:none!important}#main-content ul li::marker{content:none!important;display:none!important;font-size:0!important}#main-content ul li:before{content:"";position:absolute;left:0;top:.75em;width:10px;height:2px;background-color:var(--accent)}#main-content .social-links{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-4)}#main-content .page-header .social-links,#main-content #main-header .social-links{margin-bottom:0;margin-top:14px}#main-content .social-links a{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:6px 12px;background-color:var(--chip-bg);border-radius:4px;color:var(--link-color)!important;font-weight:600;font-size:.75em;text-decoration:none!important;border-bottom:none!important;border:none;transition:var(--transition-theme);text-transform:none;letter-spacing:0;line-height:1}#main-content .social-links a:visited{color:var(--link-color)!important}#main-content .social-links a:hover{color:var(--link-hover-color)!important;background-image:var(--selection-gradient)}#main-content .social-links a span{display:inline-block}.social-links-icon{width:12px;height:12px;flex:0 0 auto}.content-card{background:transparent;border-style:solid;border-width:1px 0;border-color:var(--surface-border);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-3);position:relative;overflow:hidden;transition:var(--transition-theme);border-radius:0;box-shadow:none}.content-card:hover{border-color:var(--accent-soft);background-image:var(--selection-gradient)}.content-card:before{content:none}.content-card em{color:var(--accent);transition:color .3s ease}.content-card>*{position:relative;z-index:1}.content-card ul{list-style:none!important;list-style-type:none!important;padding-left:0;margin:var(--space-2) 0}.content-card ul li{position:relative;padding-left:var(--space-4);margin-bottom:var(--space-2);line-height:1.6;list-style:none!important;list-style-type:none!important}.content-card ul li::marker{content:none!important;display:none!important;font-size:0!important}.content-card ul li:before{content:"";position:absolute;left:0;top:.75em;width:10px;height:2px;background-color:var(--accent);transition:background-color .3s ease}.content-card ul ul{margin-top:var(--space-2);margin-bottom:0}.content-card ul ul li{padding-left:var(--space-3)}.content-card ul ul li:before{width:6px}.content-card-image{position:absolute;top:var(--space-3);right:var(--space-4);height:clamp(60px,9vw,110px);width:auto;opacity:.85;z-index:1}.content-card:has(.content-card-image){padding-right:calc(var(--space-4) + clamp(60px,9vw,110px) + var(--space-3))}#main-content .content-card h3{font-size:1.3em;font-weight:700;color:var(--fg);line-height:1.2;margin-top:0;margin-bottom:var(--space-1)}#main-content .content-card h3+p{margin-top:0}#main-content .content-card h3 a.content-card-title-link{color:inherit;font-weight:inherit;text-decoration:none;position:relative;transition:color .3s ease}#main-content .content-card h3 a.content-card-title-link:hover{color:var(--accent);text-decoration:none}#main-content .content-card h3 a.content-card-title-link:after{content:none}#main-content .content-card h4{margin-top:0;margin-bottom:0}#main-content .content-card .achievement-text p{margin-top:var(--space-1);margin-bottom:0}.achievement-content{display:flex;flex-direction:row;align-items:stretch}.achievement-text{flex:1;display:flex;flex-direction:column}.achievement-logos{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-1);padding-left:var(--space-3)}.achievement-logos img{height:clamp(36px,6vw,66px);width:auto;opacity:.75}.job-duration,.education-duration,.content-card-date{font-size:.85em;color:var(--fg-muted);margin:0 0 var(--space-2) 0;padding-left:0;border-left:none;display:flex;align-items:center;gap:8px}.job-duration:before,.education-duration:before,.content-card-date:before{content:"";width:4px;height:4px;background-color:var(--accent-soft);border-radius:50%}.skills-category{margin-bottom:var(--space-3)}.skills-category:last-child{margin-bottom:0}.skills-category h4{color:var(--fg-muted);font-size:.75em;text-transform:uppercase;letter-spacing:.12em;font-weight:600;margin:0 0 var(--space-2) 0;transition:color .3s ease}.tag-list{display:flex!important;flex-wrap:wrap;gap:var(--space-2);padding:0!important;margin:0}#main-content .tag-list li,.tag-list li{background-color:var(--chip-bg);color:var(--fg-muted);padding:6px 12px;padding-left:12px!important;font-size:.8em;font-weight:600;border:none;border-radius:4px;transition:var(--transition-theme);text-transform:none;letter-spacing:0;display:inline-flex!important;align-items:center;justify-content:center;text-align:center;margin-bottom:0;line-height:1}#main-content .tag-list li:before,.tag-list li:before{content:none!important;display:none!important}.tag-list li:hover{background-image:var(--selection-gradient);color:var(--accent)}.related-skills{margin-top:var(--space-2)}.related-skills h5{color:var(--fg-muted);margin-bottom:var(--space-1);font-size:.75em;text-transform:uppercase;letter-spacing:.12em;font-weight:600;transition:color .3s ease}.related-skills ul{display:flex;flex-wrap:wrap;gap:var(--space-2);padding-left:0;margin-bottom:0}#main-content .related-skills ul li,.related-skills ul li{background-color:var(--chip-bg);color:var(--fg-muted);padding:6px 12px;padding-left:12px!important;border-radius:4px;font-size:.8em;font-weight:600;margin-bottom:0;border:none;transition:var(--transition-theme);cursor:default;text-transform:none;letter-spacing:0;display:inline-flex!important;align-items:center;justify-content:center;text-align:center;line-height:1}.related-skills ul li:hover{background-image:var(--selection-gradient);color:var(--accent)}#main-content .related-skills ul li:before,.related-skills ul li:before{content:none!important;display:none!important}.blog-section{margin-bottom:var(--space-5)}.blog-post-item h3{margin-top:0;font-size:1.2em;color:var(--fg);line-height:1.4;transition:color .3s ease}.blog-post-meta{font-size:.8em;color:var(--fg-muted);margin-top:0;margin-bottom:var(--space-2);font-style:normal;text-transform:uppercase;letter-spacing:.03em;transition:color .3s ease}.blog-post-description{color:var(--fg-muted);font-size:.95em;line-height:1.6;transition:color .3s ease}.blog-post-tags{margin-top:var(--space-2)}.blog-post-outer-container{margin:0 auto}.back-to-blog-link{display:inline-block;margin-bottom:var(--space-4);color:var(--fg-muted);text-decoration:none;font-weight:600;font-size:.8em;text-transform:uppercase;letter-spacing:.06em;transition:color .3s ease}.back-to-blog-link:hover{color:var(--accent)}.back-to-blog-link:after{content:none!important}.article-social-links{margin-bottom:var(--space-4)}.article-social-links .social-links{margin-bottom:0!important}html[data-theme=dark] .astro-code{background-color:var(--shiki-dark-bg)!important}html[data-theme=dark] .astro-code span{color:var(--shiki-dark)!important}#main-content .markdown-body pre,.markdown-body pre,pre.astro-code,pre[class*=astro-code]{font-family:var(--code-font)!important;direction:ltr;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;line-height:1.5;font-size:.9em;tab-size:4;hyphens:none;padding:1em;margin:1.5em 0;overflow:auto;border-radius:4px}#main-content .markdown-body pre code,.markdown-body pre code,pre.astro-code code,pre[class*=astro-code] code{background:transparent!important;padding:0;font-family:var(--code-font)!important}pre.astro-code span,pre[class*=astro-code] span,.markdown-body pre span{font-family:var(--code-font)!important}#main-content .markdown-body :not(pre)>code,.markdown-body :not(pre)>code{background:var(--code-bg);color:var(--fg);padding:.2em .4em;border-radius:3px;font-family:var(--code-font)!important;font-size:.9em;transition:background-color .3s ease,color .3s ease}#main-content .markdown-body h3,#main-content .markdown-body h4,#main-content .markdown-body h5,#main-content .markdown-body h6{color:var(--accent);transition:color .3s ease}#main-content .markdown-body a:not(#navbar a){color:var(--accent);text-decoration:none;font-weight:400}#main-content .markdown-body a:hover:not(#navbar a){text-decoration:underline;color:var(--highlight-accent)}#main-content .markdown-body a:not(#navbar a):after{content:none!important}.toc-floating{position:fixed;bottom:24px;right:24px;z-index:100}.toc-fab{display:flex;align-items:center;gap:8px;padding:12px 18px;background-color:var(--bg);border:1px solid var(--surface-border);border-radius:6px;color:var(--fg);font-family:var(--main-font);font-size:.8em;font-weight:600;cursor:pointer;box-shadow:0 2px 12px #00000026;transition:var(--transition-theme)}.toc-fab:hover{background-color:var(--surface);border-color:var(--accent)}.toc-fab-icon{display:flex;align-items:center;justify-content:center;color:var(--accent)}.toc-fab-label{text-transform:uppercase;letter-spacing:.08em}.toc-panel{position:absolute;bottom:calc(100% + 12px);right:0;width:280px;max-height:60vh;background-color:var(--bg);border:1px solid var(--surface-border);border-radius:6px;box-shadow:0 4px 24px #0003;opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .2s ease,visibility .2s ease,transform .2s ease,var(--transition-theme);overflow:hidden}.toc-open .toc-panel{opacity:1;visibility:visible;transform:translateY(0)}.toc-open .toc-fab{background-color:var(--surface)}.toc-open .toc-fab-icon{color:var(--accent)}.toc-panel-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3);border-bottom:1px solid var(--surface-border)}.toc-panel-title{font-weight:700;font-size:.75em;text-transform:uppercase;letter-spacing:.1em;transition:color .3s ease;color:var(--accent)}.toc-close{display:flex;align-items:center;justify-content:center;padding:4px;background:none;border:none;color:var(--fg-muted);cursor:pointer;transition:color .3s ease}.toc-close:hover{color:var(--accent)}.toc-list{list-style:none!important;padding:var(--space-2);margin:0;max-height:calc(60vh - 60px);overflow-y:auto}.toc-list li{position:static!important;margin-bottom:0!important}.toc-list li:before{content:none!important;display:none!important}.toc-item{margin-bottom:0;position:static}.toc-list .toc-item:before{content:none!important;display:none!important}.toc-link{display:block;padding:8px 12px;color:var(--fg-muted);text-decoration:none;font-size:.85em;line-height:1.4;border-radius:4px;transition:var(--transition-theme)}.toc-link:hover{color:var(--fg)}.toc-link:after{content:none!important}.toc-link.toc-active{color:var(--accent);background-image:var(--selection-gradient)}.toc-depth-3 .toc-link{padding-left:24px;font-size:.8em}.toc-depth-4 .toc-link{padding-left:36px;font-size:.75em}a[data-footnote-ref]{font-size:.75em;vertical-align:super;text-decoration:none;color:var(--accent);font-weight:700;padding:0 2px;transition:color .3s ease}a[data-footnote-ref]:hover{color:var(--accent-strong)}a[data-footnote-ref]:after{content:none!important}.footnotes{margin-top:var(--space-5);padding-top:var(--space-4);border-top:1px solid var(--surface-border);font-size:.9em;transition:border-color .3s ease}.footnotes h2{font-size:1.2em;margin-bottom:var(--space-3)}.footnotes ol{padding-left:var(--space-4);margin:0}.footnotes li{margin-bottom:var(--space-2);color:var(--fg-muted);transition:color .3s ease}.footnotes li:before{content:none}.footnotes li p{margin:0;display:inline}a[data-footnote-backref]{margin-left:var(--space-1);text-decoration:none;color:var(--accent)}a[data-footnote-backref]:after{content:none!important}.footnote-tooltip{position:absolute;z-index:1000;transition:background-color .3s ease,border-color .3s ease,color .3s ease;max-width:350px;padding:var(--space-3);background-color:var(--surface);border:1px solid var(--surface-border);border-radius:8px;box-shadow:var(--card-shadow);font-size:.85em;line-height:1.5;color:var(--fg);opacity:0;transform:translateY(4px);transition:opacity .2s ease,transform .2s ease;pointer-events:none}.footnote-tooltip-visible{opacity:1;transform:translateY(0)}.footnote-tooltip p{margin:0}.footnote-tooltip a{color:var(--accent);word-break:break-word}.article-header{margin-bottom:var(--space-5);padding-bottom:var(--space-4);border-bottom:1px solid var(--surface-border)}.article-title{font-size:2em;font-weight:700;line-height:1.25;margin:0 0 var(--space-3) 0;color:var(--accent);transition:color .3s ease}.article-title:after{content:none}.article-meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3);font-size:.85em;color:var(--fg-muted);margin-bottom:0;transition:color .3s ease}.meta-author{font-weight:600;color:var(--fg);transition:color .3s ease}.meta-date{position:relative;padding-left:var(--space-3)}.meta-date:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:1px;background-color:var(--fg-muted);transition:background-color .3s ease}.meta-reading-time{padding:4px 0;background-color:transparent;border-left:none;font-size:.85em;color:var(--fg-muted);font-weight:500;transition:color .3s ease}.article-tags{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-3)}#main-content .article-tag,.article-tag{display:inline-flex;align-items:center;justify-content:center;text-align:center;padding:6px 12px;background-color:var(--chip-bg);border:none;border-radius:4px;font-size:.75em;font-weight:600;color:var(--link-color);text-decoration:none;text-transform:none;letter-spacing:0;transition:var(--transition-theme);line-height:1}.article-tag-button{appearance:none;cursor:pointer;font-family:var(--main-font)}.article-tag:hover{background-image:var(--selection-gradient);color:var(--link-hover-color)}.article-tag:after{content:none!important}.article-list-container{width:100%}.tag-filter-wrapper{margin-bottom:var(--space-4)}.tag-filter-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:240px;padding:10px 16px;background-color:var(--chip-bg);border:1px solid transparent;border-radius:6px;font-family:var(--main-font);font-size:.85em;font-weight:600;color:var(--fg-muted);cursor:pointer;transition:var(--transition-theme);text-transform:none;letter-spacing:0}.tag-filter-toggle:hover{background-image:var(--selection-gradient);color:var(--accent)}.tag-filter-toggle-icon{width:8px;height:8px;border-right:2px solid var(--accent);border-bottom:2px solid var(--accent);transform:rotate(-45deg);transition:transform .2s ease}.tag-filter-toggle-icon.expanded{transform:rotate(45deg)}.tag-filter{display:none;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-3);padding-left:var(--space-3)}.tag-filter.tag-filter-expanded{display:flex}.tag-filter-btn{padding:8px 16px;background-color:transparent;border:none;border-radius:4px;font-size:.8em;font-weight:600;color:var(--fg-muted);cursor:pointer;transition:var(--transition-theme);font-family:var(--main-font);text-transform:none;letter-spacing:0}.tag-filter-btn:hover,.tag-filter-btn-active{color:var(--accent);background-image:var(--selection-gradient)}.tag-filter-btn-active:hover{color:var(--accent)}.tag-inline-btn{background:none;border:none;padding:0;color:var(--accent);cursor:pointer;font-family:inherit;font-size:inherit;font-style:inherit;text-decoration:none;transition:opacity .2s ease}.tag-inline-btn:hover{opacity:.7}.markdown-body h1,.markdown-body h2,.markdown-body h3,.markdown-body h4,.markdown-body h5,.markdown-body h6{scroll-margin-top:100px}.blog-post-content-wrapper{background-color:transparent;padding:0;margin-top:var(--space-4);box-shadow:none;max-width:900px}.blog-post-content-wrapper .markdown-body{font-size:1.05rem;line-height:1.8;color:var(--fg)}.blog-post-content-wrapper .markdown-body p{margin-bottom:1.5em}.blog-post-content-wrapper .markdown-body h2{font-size:1.5em;font-weight:700;margin-top:2.5em;margin-bottom:1em;color:var(--accent);position:relative}.blog-post-content-wrapper .markdown-body h3{font-size:1.25em;font-weight:700;margin-top:2em;margin-bottom:.75em;color:var(--fg)}.blog-post-content-wrapper .markdown-body h4{font-size:1.1em;font-weight:600;margin-top:1.5em;margin-bottom:.5em;color:var(--fg)}.blog-post-content-wrapper .markdown-body h2+p,.blog-post-content-wrapper .markdown-body h3+p,.blog-post-content-wrapper .markdown-body h4+p{margin-top:0}.markdown-body blockquote{margin:2em 0;padding:var(--space-4);border-left:2px solid var(--accent-soft);background-color:var(--surface);border-radius:8px;font-style:italic;transition:var(--transition-theme)}.markdown-body blockquote p{margin:0;color:var(--fg);line-height:1.7}.markdown-body blockquote p:not(:last-child){margin-bottom:1em}.blog-post-content-wrapper .markdown-body ul,.blog-post-content-wrapper .markdown-body ol{margin:1.5em 0;padding-left:var(--space-4)}.blog-post-content-wrapper .markdown-body ul{list-style:none!important;list-style-type:none!important}.blog-post-content-wrapper .markdown-body ul li{margin-bottom:.75em;line-height:1.7;position:relative;padding-left:var(--space-3);list-style:none!important;list-style-type:none!important}.blog-post-content-wrapper .markdown-body ul li::marker{content:none!important;display:none!important;font-size:0!important}.blog-post-content-wrapper .markdown-body ul li:before{content:"";position:absolute;left:0;top:.75em;width:10px;height:2px;background-color:var(--accent)}.blog-post-content-wrapper .markdown-body ol{list-style:decimal}.blog-post-content-wrapper .markdown-body ol li{margin-bottom:.75em;line-height:1.7;padding-left:var(--space-1)}.blog-post-content-wrapper .markdown-body ol li:before{content:none}.blog-post-content-wrapper .markdown-body ul ul,.blog-post-content-wrapper .markdown-body ol ol,.blog-post-content-wrapper .markdown-body ul ol,.blog-post-content-wrapper .markdown-body ol ul{margin:.5em 0}.blog-post-content-wrapper .markdown-body a{color:var(--accent);text-decoration:underline;text-decoration-color:var(--accent-glow);text-underline-offset:3px;transition:text-decoration-color .2s ease}.blog-post-content-wrapper .markdown-body a:hover{text-decoration-color:var(--accent)}.markdown-body hr{margin:3em 0;border:none;height:1px;background:linear-gradient(to right,transparent,var(--surface-border),transparent)}.markdown-body table{width:100%;margin:2em 0;border-collapse:collapse;font-size:.9em;border-radius:8px;overflow:hidden;border:1px solid var(--surface-border)}.markdown-body th,.markdown-body td{padding:var(--space-3);text-align:left;border-bottom:1px solid var(--surface-border)}.markdown-body th{background-color:var(--surface);font-weight:700;color:var(--accent);font-size:.85em;letter-spacing:.03em}.markdown-body tr:last-child td{border-bottom:none}.markdown-body tr:nth-child(2n){background-color:#00000005}html[data-theme=dark] .markdown-body tr:nth-child(2n){background-color:#ffffff05}.markdown-body img{max-width:100%;height:auto;border-radius:8px;margin:2em 0;box-shadow:var(--card-shadow)}.blog-post-content-wrapper .markdown-body :not(pre)>code{background-color:var(--surface);padding:.2em .5em;border-radius:4px;font-size:.9em;border:1px solid var(--surface-border)}.blog-post-content-wrapper .markdown-body pre{margin:2em 0;border-radius:8px;border:1px solid var(--surface-border)}.blog-post-content-wrapper .markdown-body strong{font-weight:700;color:var(--fg)}.blog-post-content-wrapper .markdown-body em{font-style:italic;color:var(--fg)}@media(max-width:768px){body{font-size:14px}#content{padding-top:0;z-index:auto}.mobile-nav-floating{display:flex}.mobile-nav-backdrop{display:block;opacity:0;pointer-events:none;visibility:hidden;transition:opacity .22s ease,visibility .22s ease}html.mobile-nav-open .mobile-nav-backdrop{opacity:1;visibility:visible;pointer-events:auto}html.mobile-nav-open,html.mobile-nav-open body{overflow:hidden}#navbar{position:fixed;top:0;left:0;bottom:0;width:min(calc(100vw - 32px),var(--mobile-drawer-width));height:100dvh;margin:0;padding:24px 18px;background-color:var(--bg);border-right:1px solid var(--surface-border);box-shadow:0 18px 50px #00000047;overflow-y:auto;z-index:1300;display:flex;flex-direction:column;justify-content:center;transform:translate(calc(-100% - 20px));opacity:0;visibility:hidden;pointer-events:none;transition:transform .24s ease,opacity .24s ease,visibility .24s ease;will-change:transform}html.mobile-nav-open #navbar{transform:translate(0);opacity:1;visibility:visible;pointer-events:auto}.navbar-image{display:block;width:96px;height:96px;margin:0 0 var(--space-4) 2px;flex:0 0 auto}#navbar ul{display:grid;gap:8px;width:100%;margin:0;padding:0;flex:0 0 auto}#navbar li{margin-bottom:0}#navbar a{display:flex;align-items:center;min-height:44px;padding:11px 14px;border-radius:10px;background-color:transparent;font-size:.92em;font-weight:800;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.08em;transition:var(--transition-theme)}#navbar a:before{content:none!important}#navbar a.is-active{color:var(--accent);background-image:var(--selection-gradient)}#navbar a:hover{color:var(--fg);background-image:var(--selection-gradient)}.mobile-nav-toggle,.theme-toggle{height:44px;border:1px solid var(--surface-border);border-radius:6px;background-color:var(--bg);box-shadow:0 4px 24px #0003}html.mobile-nav-open .mobile-nav-toggle{background-color:var(--surface);border-color:var(--accent);color:var(--accent)}.theme-toggle{top:16px;right:16px;bottom:auto;width:var(--mobile-theme-toggle-width);min-width:0;justify-content:center;padding:0;gap:0px;z-index:1400}.theme-label{display:none}.theme-icon{width:20px;height:20px}#main-content{padding:20px 16px 36px}#main-content h1{font-size:1.8em}#main-content h1:after{height:4px}#main-content h2{font-size:1.5em}#main-content h3,#main-content .content-card h3{font-size:1.2em}.content-card{padding:var(--space-2) var(--space-3);margin-bottom:var(--space-2)}.related-skills ul{gap:var(--space-1)}.related-skills ul li{padding:4px 10px;font-size:.75em}#main-content .tag-list li,.tag-list li{padding:4px 10px;font-size:.7em}#main-content .markdown-body h1{font-size:1.6em}.toc-floating{bottom:16px;right:16px}.toc-fab-label{display:none}.toc-fab{padding:12px;border-radius:50%}.toc-panel{width:calc(100vw - 32px);max-width:320px}.tag-filter-toggle{max-width:none}.tag-filter{gap:var(--space-1)}.tag-filter-btn{padding:5px 10px;font-size:.8em}.article-title{font-size:1.6em}.article-meta{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.meta-date{padding-left:0}.meta-date:before{content:none}.footnote-tooltip{max-width:calc(100vw - 40px);left:20px!important;right:20px}.blog-post-content-wrapper .markdown-body{font-size:1rem}}.webgpu-host{color-scheme:dark;--webgpu-bg: var(--card-bg);--webgpu-surface: var(--surface);--webgpu-surface-2: var(--surface);--webgpu-surface-3: var(--card-bg);--webgpu-surface-4: var(--surface);--webgpu-surface-5: var(--card-bg);--webgpu-surface-muted: var(--surface);--webgpu-border: var(--card-border);--webgpu-border-strong: var(--card-border);--webgpu-border-stronger: var(--surface-border);--webgpu-text: var(--fg);--webgpu-text-muted: var(--fg-muted);--webgpu-text-subtle: var(--fg-muted);--webgpu-text-faint: var(--fg-muted);--webgpu-accent: var(--accent);--webgpu-accent-soft-2: rgba(47, 111, 255, .08);--webgpu-accent-soft-3: rgba(47, 111, 255, .12);--webgpu-accent-outline: rgba(47, 111, 255, .3);--webgpu-font: var(--tertiary-font);--webgpu-mono-font: var(--code-font);--webgpu-input-bg: var(--surface);--webgpu-input-bg-muted: var(--card-bg);--webgpu-input-bg-strong: var(--surface);--webgpu-input-border: var(--card-border);--webgpu-hover-bg: rgba(255, 255, 255, .06);--webgpu-hover-bg-2: rgba(255, 255, 255, .04);--webgpu-overlay-bg: rgba(0, 0, 0, .6);--webgpu-icon-bg: transparent;--webgpu-icon-border: var(--card-border);--webgpu-icon-color: var(--fg-muted);--webgpu-success-text: #4ade80;--webgpu-success-bg: rgba(74, 222, 128, .1);--webgpu-success-border: rgba(74, 222, 128, .3);--webgpu-success-hover-bg: rgba(74, 222, 128, .15);--webgpu-success-hover-border: rgba(74, 222, 128, .5);--webgpu-success-outline: rgba(74, 222, 128, .2);--webgpu-error-text: #ff6b6b;--webgpu-error-bg: rgba(255, 107, 107, .1);--webgpu-danger-bg: rgba(255, 107, 107, .1);--webgpu-danger-border: rgba(255, 107, 107, .3);--webgpu-danger-hover-bg: rgba(255, 107, 107, .15);--webgpu-danger-hover-border: rgba(255, 107, 107, .5)}html[data-theme=light] .webgpu-host{color-scheme:light;--webgpu-hover-bg: rgba(0, 0, 0, .04);--webgpu-hover-bg-2: rgba(0, 0, 0, .03);--webgpu-accent-soft-2: rgba(47, 111, 255, .06);--webgpu-accent-soft-3: rgba(47, 111, 255, .1);--webgpu-overlay-bg: rgba(255, 255, 255, .7)}.site-footer{padding:20px var(--space-4);text-align:center;color:var(--fg-muted);font-size:14px;background:var(--bg);transition:var(--transition-theme)}.site-footer p{margin:0}
