:root{--bg: #FAFAFA;--bg-elev: #FFFFFF;--bg-muted: #F4F4F5;--header-bg: rgba(250, 250, 250, .8);--fg: #0A0A0A;--fg-muted: #525252;--fg-subtle: #A3A3A3;--border: #E5E5E5;--border-strong: #D4D4D4;--accent: #10B981;--accent-fg: #022c22;--accent-muted: rgba(16, 185, 129, .12);--overlay-dark: rgba(0, 0, 0, .55);--overlay-darker: rgba(0, 0, 0, .72);--scanline: rgba(0, 0, 0, .12);--on-dark: #fff;--shadow-md: 0 4px 16px -4px rgba(0, 0, 0, .08), 0 2px 4px rgba(0, 0, 0, .03);--radius-sm: 4px;--radius: 10px;--radius-lg: 14px;--radius-pill: 999px;--mw-page: 1120px;--mw-reading: 1024px;--mw-lede: 620px;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Helvetica Neue", Arial, sans-serif;--font-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, "Liberation Mono", monospace;--fs-label: 11px;--fs-caption: 12px;--fs-meta: 13px;--t-fast: .15s ease;--t-base: .2s ease;--t-slow: .4s ease;--z-base: 1;--z-sticky: 50;--z-dropdown: 100;--z-overlay: 1000}[data-theme=dark]{--bg: #0A0A0A;--bg-elev: #111111;--bg-muted: #161616;--header-bg: rgba(10, 10, 10, .8);--fg: #FAFAFA;--fg-muted: #A3A3A3;--fg-subtle: #525252;--border: #1F1F1F;--border-strong: #2A2A2A;--accent-fg: #001A20;--shadow-md: 0 4px 24px -4px rgba(0, 0, 0, .5), 0 2px 4px rgba(0, 0, 0, .3);color-scheme:dark}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--bg: #0A0A0A;--bg-elev: #111111;--bg-muted: #161616;--header-bg: rgba(10, 10, 10, .8);--fg: #FAFAFA;--fg-muted: #A3A3A3;--fg-subtle: #525252;--border: #1F1F1F;--border-strong: #2A2A2A;--accent-fg: #001A20;--shadow-md: 0 4px 24px -4px rgba(0, 0, 0, .5), 0 2px 4px rgba(0, 0, 0, .3);color-scheme:dark}}*{box-sizing:border-box}html,body{margin:0;padding:0}h1,h2,h3,h4,h5,h6,p,ul,ol,dl,dd,figure{margin:0;padding:0}ul,ol{list-style:none}button{font-family:inherit;font-size:inherit;color:inherit;background:none;border:0;padding:0;cursor:pointer}body{background:var(--bg);color:var(--fg);font-family:var(--font-sans);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color var(--t-base),color var(--t-base)}a{color:inherit;text-decoration:none}::selection{background:var(--accent);color:var(--accent-fg)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}.skip-link{position:absolute;top:-999px;left:8px;padding:10px 14px;background:var(--fg);color:var(--bg);font-family:var(--font-mono);font-size:13px;border-radius:8px;z-index:1000}.skip-link:focus{top:8px}.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.project,.article-teaser,.info-panel,.project-card,.video-embed{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.project,.article-teaser,.social-card{transition:transform var(--t-base),box-shadow var(--t-base),border-color var(--t-base),background-color var(--t-base)}.project:hover,.article-teaser:hover{border-color:var(--border-strong);transform:translateY(-2px);box-shadow:var(--shadow-md)}.container{max-width:var(--mw-page);margin:0 auto;padding:0 32px}.site-header{position:sticky;top:0;z-index:50;backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px);background:var(--header-bg);border-bottom:1px solid var(--border)}.site-header>.container{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;height:64px;gap:24px}.brand{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:14px;font-weight:500;letter-spacing:-.01em;color:var(--fg);text-decoration:none;justify-self:start;margin:0}.brand:hover{color:var(--fg)}.brand .mark{width:10px;height:10px;border-radius:3px;background:var(--accent);box-shadow:0 0 0 4px var(--accent-muted)}.brand .domain{color:var(--fg-subtle)}.primary-nav{display:flex;align-items:center;gap:4px;justify-self:center;list-style:none;padding:0;margin:0}.primary-nav>li{display:block}.primary-nav a{padding:8px 14px;font-size:14px;color:var(--fg-muted);border-radius:8px;transition:color var(--t-fast),background-color var(--t-fast);text-decoration:none;margin:0;display:inline-block}.primary-nav a:hover{color:var(--fg);background:var(--bg-muted)}.primary-nav a[aria-current=page]{color:var(--fg);background:var(--bg-muted);font-weight:500}.nav-actions{display:flex;align-items:center;gap:8px;justify-self:end}.mobile-menu{display:none;position:relative}.mobile-menu>summary{list-style:none;cursor:pointer;user-select:none}.mobile-menu>summary::-webkit-details-marker{display:none}.mobile-menu>summary::marker{content:""}.mobile-menu .icon-close{display:none}.mobile-menu[open]>summary .icon-open{display:none}.mobile-menu[open]>summary .icon-close{display:inline-block}.mobile-menu>ul{position:absolute;top:calc(100% + 12px);right:0;min-width:220px;padding:8px;margin:0;list-style:none;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);z-index:100}.mobile-menu>ul a{display:block;padding:10px 14px;font-size:14px;color:var(--fg-muted);text-decoration:none;border-radius:6px;transition:color var(--t-fast),background-color var(--t-fast)}.mobile-menu>ul a:hover{color:var(--fg);background:var(--bg-muted)}.mobile-menu>ul a[aria-current=page]{color:var(--fg);background:var(--bg-muted);font-weight:500}.site-header button,.site-header .button{margin:0}.button{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;font-size:14px;font-weight:500;border-radius:8px;border:1px solid var(--border);background:var(--bg-elev);color:var(--fg);cursor:pointer;transition:color var(--t-fast),border-color var(--t-fast),background-color var(--t-fast);font-family:inherit;line-height:1.4;text-decoration:none;margin:0;white-space:nowrap}.button:hover{border-color:var(--border-strong);background:var(--bg-muted)}.button.primary{background:var(--fg);color:var(--bg);border-color:var(--fg)}.button.primary:hover{opacity:.9;background:var(--fg);color:var(--bg)}.button.icon{width:36px;height:36px;padding:0;display:inline-grid;place-items:center;color:var(--fg-muted);background:var(--bg-elev)}.button.icon:hover{color:var(--fg);border-color:var(--border-strong);background:var(--bg-muted)}.button.icon i{font-size:16px}.theme-toggle .icon-moon,[data-theme=dark] .theme-toggle .icon-sun{display:none}[data-theme=dark] .theme-toggle .icon-moon{display:inline-block}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .theme-toggle .icon-sun{display:none}:root:not([data-theme=light]) .theme-toggle .icon-moon{display:inline-block}}.kicker{font-family:var(--font-mono);font-size:12px;color:var(--accent);text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px;display:flex;align-items:center;gap:8px}.kicker:before,.kicker:after{content:"";width:14px;height:1px;background:var(--accent)}.caret{display:inline-block;width:.75ch;background:var(--accent);height:.85em;margin-left:4px;transform:translateY(.08em);animation:blink 1.1s ease-out infinite}@keyframes blink{0%,55%{opacity:1}75%{opacity:0}to{opacity:0}}section.page-section{padding:72px 0;border-top:1px solid var(--border)}.index-intro{max-width:var(--mw-reading);margin:0 auto;padding:40px 32px 0;font-size:16px;line-height:1.7;color:var(--fg-muted);text-align:center}.index-intro>p{margin:0 0 14px}.index-intro>p:last-child{margin-bottom:0}.index-intro strong{color:var(--fg);font-weight:500}.index-intro a{color:var(--accent);text-decoration:none;border-bottom:1px solid transparent;transition:border-color var(--t-fast)}.index-intro a:hover{border-bottom-color:var(--accent)}.index-intro ul,.index-intro ol{padding-left:0;margin:0 0 14px;list-style:none;text-align:left;display:inline-block}.index-intro li{margin:0 0 4px}.page-section>.container>header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:40px;gap:24px;flex-wrap:wrap}.page-section>.container>header hgroup{display:block}.page-section>.container>header h2{font-size:36px;letter-spacing:-.025em;font-weight:600;margin:0 0 8px;line-height:1.1}.page-section>.container>header p{color:var(--fg-muted);margin:0;font-size:15px}.link-arrow{display:inline-flex;align-items:center;gap:6px;color:var(--fg);font-weight:500;font-family:var(--font-sans);font-size:13px;transition:gap var(--t-fast),color var(--t-fast);cursor:pointer;text-decoration:none}.link-arrow:hover{gap:10px;color:var(--accent)}.tags{display:flex;flex-wrap:wrap;gap:6px;margin:0;padding:0;list-style:none}.tags>li{display:block}.tags span,.tags a{display:inline-block;padding:3px 9px;font-family:var(--font-mono);font-size:11px;color:var(--fg-muted);background:var(--bg-muted);border:1px solid var(--border);border-radius:4px;letter-spacing:.02em;text-decoration:none;transition:color var(--t-fast),border-color var(--t-fast),background-color var(--t-fast)}.tags a:hover{color:var(--fg);border-color:var(--border-strong);background:var(--bg-elev)}.retro-display{position:relative;overflow:hidden;margin:0;font-family:var(--font-mono);letter-spacing:.04em;color:var(--on-dark)}.retro-display:before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,var(--scanline) 0,var(--scanline) 1px,transparent 1px,transparent 3px);pointer-events:none;z-index:1}.retro-display>*{position:relative;z-index:2}.retro-display>i{position:absolute;inset:0;z-index:0;background-image:radial-gradient(circle at 20% 30%,rgba(255,255,255,.15) 0%,transparent 40%),radial-gradient(circle at 80% 70%,rgba(255,255,255,.1) 0%,transparent 40%)}.retro-display.amber{background:linear-gradient(135deg,#c38a2a,#7a4d10)}.retro-display.violet{background:linear-gradient(135deg,#7c3aed,#312e81)}.retro-display.crimson{background:linear-gradient(135deg,#b91c1c,#450a0a)}.retro-display.midnight{background:linear-gradient(135deg,#1e3a8a,#0c1226)}.retro-display.cyan{background:linear-gradient(135deg,#0891b2,#164e63)}.retro-display.emerald{background:linear-gradient(135deg,#059669,#064e3b)}footer.site-footer{border-top:1px solid var(--border);padding:56px 0 40px;margin-top:40px}.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:56px}.footer-grid h3,.footer-grid>nav>p{margin:0 0 14px;font-family:var(--font-mono);font-size:11px;color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.08em;font-weight:500}.footer-grid ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.footer-grid a{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:var(--fg-muted);transition:color var(--t-fast);text-decoration:none}.footer-grid a:hover{color:var(--fg)}.footer-grid a i{width:14px;font-size:13px;text-align:center;color:var(--fg-subtle);transition:color var(--t-fast)}.footer-grid a:hover i{color:var(--fg)}.colophon .brand{font-size:15px}.colophon p{color:var(--fg-muted);font-size:14px;max-width:340px;margin:12px 0 0;font-family:var(--font-sans);text-transform:none;letter-spacing:normal;font-weight:400}.site-footer address{font-style:normal;display:inline}.site-footer address a{display:inline-flex;align-items:center;gap:6px;color:inherit;transition:color var(--t-fast);text-decoration:none}.site-footer address a:hover{color:var(--fg)}.site-footer address a i{font-size:13px;color:var(--fg-subtle)}.site-footer address a:hover i{color:var(--fg)}.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid var(--border);font-family:var(--font-mono);font-size:12px;color:var(--fg-subtle);flex-wrap:wrap;gap:12px}@media(max-width:900px){.site-header>.container{grid-template-columns:1fr auto}.primary-nav{display:none}.mobile-menu{display:block}.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}@media(max-width:520px){.container{padding:0 20px}.footer-grid{grid-template-columns:1fr}}.page-hero>.container .lede{margin-left:auto;margin-right:auto}.page-hero h1{font-size:clamp(44px,7vw,88px);line-height:.98;letter-spacing:-.035em;font-weight:600;margin:0 0 24px}.page-hero h1 .role{display:inline-block;color:var(--accent);position:relative}.lede{font-size:20px;color:var(--fg-muted);max-width:var(--mw-lede);margin:0 0 36px;line-height:1.55}.lede strong{color:var(--fg);font-weight:500}.page-hero .actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.tech-marquee{margin-top:56px;padding-top:28px;border-top:1px solid var(--border);overflow:hidden;mask-image:linear-gradient(90deg,transparent 0,#000 80px,#000 calc(100% - 80px),transparent 100%);-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 80px,#000 calc(100% - 80px),transparent 100%)}.tech-marquee-inner{display:flex;width:max-content;will-change:transform;animation-name:tech-scroll;animation-duration:60s;animation-timing-function:linear;animation-iteration-count:infinite}.tech-track{display:flex;flex-shrink:0;gap:8px;padding-right:8px;margin:0;list-style:none}.tech-track li{flex-shrink:0;padding:6px 14px;background:var(--bg-elev);border-radius:var(--radius-pill);font-family:var(--font-mono);font-size:12px;color:var(--fg-muted);white-space:nowrap}@keyframes tech-scroll{0%{transform:translateZ(0)}to{transform:translate3d(-50%,0,0)}}.tech-marquee:hover .tech-marquee-inner{animation-play-state:paused}.project-showcase{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;list-style:none;padding:0;margin:0}.project-showcase>li{display:block;min-width:0}.project{display:flex;flex-direction:column;height:100%}.project>.retro-display{display:flex;flex-direction:column;justify-content:flex-start;padding:28px 24px;min-height:140px;border-bottom:1px solid var(--border)}.project>.retro-display>h3{margin:0;font-size:18px;font-weight:600;letter-spacing:-.015em;line-height:1.3;color:var(--on-dark)}.project .body{padding:20px;flex:1;display:flex;flex-direction:column}.project .body>p{font-size:14px;color:var(--fg-muted);margin:0 0 16px;line-height:1.55;flex:1}.project footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:16px;font-family:var(--font-mono);font-size:12px;color:var(--fg-subtle)}.project footer:has(>.link-arrow:only-child){justify-content:flex-end}.blog-section .article-teasers{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.blog-section .article-teasers>li{display:block}.blog-section .article-teaser{display:grid;grid-template-columns:140px 1fr auto;gap:0;align-items:stretch;margin:0}.blog-section .article-teaser:hover h3 a{color:var(--accent)}.blog-section .article-teaser>.cover{position:relative;margin:0;height:100%;min-height:100px;overflow:hidden;border-right:1px solid var(--border);background:var(--bg-muted)}.blog-section .article-teaser>.cover img{display:block;width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow)}.blog-section .article-teaser:hover>.cover img{transform:scale(1.04)}.blog-section .article-teaser>.cover>time{position:absolute;left:12px;bottom:12px;z-index:2;font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.04em;color:var(--on-dark);padding:5px 10px;background:var(--overlay-darker);border:1px solid rgba(255,255,255,.2);border-radius:6px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);white-space:nowrap}.blog-section .teaser-body,.blog-section .article-teaser>.meta{padding:20px 24px;align-self:center}.blog-section .article-teaser h3{font-size:18px;font-weight:500;letter-spacing:-.015em;margin:0 0 4px}.blog-section .article-teaser h3 a{color:var(--fg);transition:color var(--t-fast);text-decoration:none}.blog-section .article-teaser h3 a:hover{color:var(--accent)}.blog-section .article-teaser .excerpt{color:var(--fg-muted);font-size:14px;margin:0}.blog-section .article-teaser .meta{font-family:var(--font-mono);font-size:12px;color:var(--fg-subtle);margin:0}.split{display:grid;grid-template-columns:1fr 1fr;gap:16px}.info-panel{padding:28px}.info-panel>header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.info-panel>header h3{margin:0;font-size:18px;font-weight:600}.venues{margin-top:28px;font-size:13px;font-family:var(--font-mono);letter-spacing:.03em;line-height:1.9}.venues a{color:inherit;text-decoration:none;transition:color var(--t-fast)}.venues a:hover{color:var(--accent)}.venues em{font-style:italic}.about-bio>p{margin:0 0 16px;font-size:15px;color:var(--fg-muted);line-height:1.65}.about-bio>p:last-child{margin-bottom:0}.about-bio strong{color:var(--fg);font-weight:500}.expertise-list{display:flex;flex-direction:column;gap:14px;margin:0;padding:0}.expertise-list>div{display:grid;grid-template-columns:130px 1fr;gap:16px;align-items:baseline;padding-bottom:14px;border-bottom:1px solid var(--border)}.expertise-list>div:last-child{border-bottom:none;padding-bottom:0}.expertise-list dt{font-family:var(--font-mono);font-size:11px;color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.05em;margin:0}.expertise-list dd{margin:0;font-size:14px;color:var(--fg);line-height:1.55}.social-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;list-style:none;padding:0;margin:0}.social-grid>li{display:block;min-width:0}.social-card{display:flex;flex-direction:column;align-items:flex-start;gap:14px;padding:24px;height:100%;border-radius:var(--radius-lg);color:var(--on-dark);text-decoration:none;position:relative;overflow:hidden;isolation:isolate}.social-card:after{content:"";position:absolute;inset:0;background:#fff;opacity:0;transition:opacity var(--t-base);pointer-events:none;z-index:0}.social-card>*{position:relative;z-index:1}.social-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px -6px #00000040}.social-card:hover:after{opacity:.18}.social-card i{font-size:28px;line-height:1;color:var(--on-dark)}.social-card strong{font-size:15px;font-weight:600;letter-spacing:-.01em;color:var(--on-dark)}.social-card small{font-family:var(--font-mono);font-size:11px;color:#ffffffbf}.social-card.twitter{background:linear-gradient(135deg,#18181b,#000)}.social-card.bluesky{background:linear-gradient(135deg,#0085ff,#003d73)}.social-card.linkedin{background:linear-gradient(135deg,#0a66c2,#053866)}.social-card.youtube{background:linear-gradient(135deg,red,#8b0000)}.social-card.twitch{background:linear-gradient(135deg,#9146ff,#5a2a9e)}@media(max-width:900px){.split{grid-template-columns:1fr}.blog-section .article-teaser{grid-template-columns:110px 1fr}.blog-section .article-teaser .meta{display:none}.social-grid{grid-template-columns:repeat(3,1fr)}.expertise-list>div{grid-template-columns:1fr;gap:4px}}@media(max-width:520px){.page-hero{padding:72px 0 56px}.blog-section .article-teaser{grid-template-columns:88px 1fr}.blog-section .article-teaser .teaser-body{padding:16px}.blog-section .article-teaser>.cover>time{font-size:10px;padding:4px 7px;left:8px;bottom:8px}.social-grid{grid-template-columns:repeat(2,1fr)}.social-card{padding:18px}.social-card i{font-size:22px}}.page-hero{padding:120px 0 80px;position:relative;overflow:hidden}.page-hero:before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:56px 56px;mask-image:radial-gradient(ellipse 60% 50% at 50% 30%,#000 30%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse 60% 50% at 50% 30%,#000 30%,transparent 70%);opacity:.5;pointer-events:none}.page-hero>.container{position:relative;text-align:center;margin:0 auto}.page-hero .kicker{justify-content:center}.page-hero .kicker:after{content:"";width:14px;height:1px;background:var(--accent)}.page-hero .lede{font-size:18px;color:var(--fg-muted);max-width:var(--mw-lede);margin:0 auto;line-height:1.55}.page-hero .lede strong{color:var(--fg);font-weight:500}.page-hero.compact{padding:80px 0 56px}.page-hero.compact h1{font-size:clamp(34px,5vw,52px);margin-bottom:16px}.page-hero.compact .lede{font-size:17px}.archive-section.page-section{padding:64px 0 72px}.listing-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:32px;padding-bottom:20px;border-bottom:1px solid var(--border)}.listing-filters>ul{display:flex;flex-wrap:wrap;gap:8px;list-style:none;padding:0;margin:0}.listing-filters>ul>li{display:block}.chip-grid{display:flex;flex-wrap:wrap;gap:10px;list-style:none;padding:0;margin:0}.chip-grid>li{display:block}.chip,.toolbar-link,.rss-link{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;font-size:13px;font-weight:500;color:var(--fg-muted);background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-pill);transition:color var(--t-fast),border-color var(--t-fast),background-color var(--t-fast);text-decoration:none;white-space:nowrap;font-family:inherit}.chip:hover,.toolbar-link:hover,.rss-link:hover{color:var(--fg);border-color:var(--border-strong);background:var(--bg-muted)}.chip i,.toolbar-link i,.rss-link i{font-size:12px;color:var(--fg-subtle);transition:color var(--t-fast)}.chip:hover i,.toolbar-link:hover i,.rss-link:hover i{color:var(--fg-muted)}.chip.active{color:var(--accent);border-color:var(--accent);cursor:default}.chip.active:hover{color:var(--accent);border-color:var(--accent);background:var(--bg-elev)}.chip.active i{color:var(--accent)}.chip .count{font-family:var(--font-mono);font-size:11px;color:var(--fg-subtle);padding-left:6px;border-left:1px solid var(--border);margin-left:2px}.chip.active .count{color:var(--accent);border-left-color:var(--accent-muted)}.listing-actions{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.archive-section .article-teasers{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}.archive-section .article-teasers>li{display:block}.archive-section .article-teaser{display:grid;grid-template-columns:220px 1fr;gap:0;align-items:stretch;margin:0}.archive-section .article-teaser:hover h3 a{color:var(--accent)}.archive-section .article-teaser>.cover{position:relative;margin:0;height:100%;min-height:150px;overflow:hidden;border-right:1px solid var(--border);background:var(--bg-muted)}.archive-section .article-teaser>.cover img{display:block;width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow)}.archive-section .article-teaser:hover>.cover img{transform:scale(1.04)}.archive-section .article-teaser>.cover>time{position:absolute;left:12px;bottom:12px;z-index:2;font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.04em;color:var(--on-dark);padding:5px 10px;background:var(--overlay-darker);border:1px solid rgba(255,255,255,.2);border-radius:6px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);white-space:nowrap}.archive-section .teaser-body{padding:22px 26px;display:flex;flex-direction:column;justify-content:center;min-width:0}.archive-section .article-teaser h3{font-size:19px;font-weight:500;letter-spacing:-.015em;margin:0 0 8px;line-height:1.3}.archive-section .article-teaser h3 a{color:var(--fg);transition:color var(--t-fast);text-decoration:none}.archive-section .article-teaser h3 a:hover{color:var(--accent)}.archive-section .article-teaser .excerpt{color:var(--fg-muted);font-size:14px;line-height:1.55;margin:0;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.archive-section .article-teaser .tags{margin:12px 0 0}.pagination{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:48px;padding-top:32px;border-top:1px solid var(--border);flex-wrap:wrap}.page-nav{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;font-size:14px;font-weight:500;color:var(--fg);background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;transition:color var(--t-fast),border-color var(--t-fast),background-color var(--t-fast);white-space:nowrap}.page-nav:hover{border-color:var(--border-strong);background:var(--bg-muted);color:var(--fg)}.page-nav:hover.next,.page-nav:hover.prev{gap:10px}.page-nav.disabled{opacity:.4;pointer-events:none;cursor:not-allowed}.page-nav i{font-size:13px;color:var(--fg-subtle)}.page-numbers{display:flex;gap:4px;list-style:none;padding:0;margin:0;font-family:var(--font-mono);font-size:13px}.page-numbers>li{display:block}.page-numbers a,.page-numbers span{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 10px;color:var(--fg-muted);border-radius:8px;text-decoration:none;transition:color var(--t-fast),background-color var(--t-fast)}.page-numbers a:hover{color:var(--fg);background:var(--bg-muted)}.page-numbers a[aria-current=page]{color:var(--bg);background:var(--fg);font-weight:600;cursor:default}.page-numbers a[aria-current=page]:hover{color:var(--bg);background:var(--fg)}.page-numbers .gap{color:var(--fg-subtle);pointer-events:none}.page-indicator{display:none;font-family:var(--font-mono);font-size:13px;color:var(--fg-muted);margin:0}.page-indicator strong{color:var(--fg);font-weight:600}@media(max-width:900px){.archive-section .article-teaser{grid-template-columns:160px 1fr}.archive-section .article-teaser>.cover{min-height:130px}.archive-section .teaser-body{padding:18px 20px}}@media(max-width:720px){.pagination{justify-content:center}.page-numbers{display:none}.page-indicator{display:block;flex:1;text-align:center}}@media(max-width:520px){.page-hero{padding:72px 0 48px}.page-hero.compact{padding:56px 0 40px}.listing-toolbar{flex-direction:column;align-items:stretch;gap:12px}.listing-filters{justify-content:flex-start}.listing-actions{align-self:flex-start;gap:0;flex-wrap:wrap}.toolbar-link,.rss-link{padding-left:0;padding-right:12px}.archive-section .article-teaser{grid-template-columns:110px 1fr}.archive-section .article-teaser>.cover{min-height:110px}.archive-section .article-teaser>.cover>time{font-size:10px;padding:4px 7px;left:8px;bottom:8px}.archive-section .teaser-body{padding:14px 16px}.archive-section .article-teaser h3{font-size:16px;margin-bottom:4px}.archive-section .article-teaser .excerpt{font-size:13px;-webkit-line-clamp:2;line-clamp:2}.archive-section .article-teaser .tags{margin-top:8px}.pagination .page-nav span{display:none}.pagination .page-nav{padding:10px 14px}}.container-reading{max-width:var(--mw-reading);margin:0 auto;padding:0 32px}.post{padding-top:48px;padding-bottom:48px}.post-header{padding:24px 0 48px;position:relative}.post-header .kicker{justify-content:center}.post-header .kicker:after{content:"";width:14px;height:1px;background:var(--accent)}.post-header>.container-reading{text-align:center}.post-header h1{font-size:clamp(34px,5vw,52px);line-height:1.05;letter-spacing:-.03em;font-weight:600;margin:0 0 24px;color:var(--fg)}.post-meta{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:12px;font-family:var(--font-mono);font-size:13px;color:var(--fg-muted);margin:0 0 24px}.post-meta time{color:var(--fg);font-weight:500}.post-meta .dot{color:var(--fg-subtle)}.post-meta .author{color:var(--fg-muted)}.post-meta .author strong{color:var(--fg);font-weight:500}.post-header .tags{justify-content:center}.post-cover{margin:0 auto 56px;max-width:var(--mw-reading);padding:0 32px}.post-cover figure{margin:0;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);box-shadow:0 24px 48px -12px #0000002e,0 8px 16px -8px #00000014;background:var(--bg-muted)}[data-theme=dark] .post-cover figure{box-shadow:0 24px 48px -12px #0009,0 8px 16px -8px #0006}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .post-cover figure{box-shadow:0 24px 48px -12px #0009,0 8px 16px -8px #0006}}.post-cover img{display:block;width:100%;height:auto;aspect-ratio:16 / 5;object-fit:cover}.post-content{font-size:17px;line-height:1.75;color:var(--fg)}.post-content>p,.post-content>ul,.post-content>ol,.post-content>blockquote,.post-content>pre,.post-content section>p,.post-content section>ul,.post-content section>ol{margin:0 0 20px}.post-content p:last-child{margin-bottom:0}.post-content>p:first-of-type{font-size:20px;line-height:1.6;color:var(--fg);font-weight:400;margin:0 0 24px;padding-left:20px;border-left:2px solid var(--accent)}.post-content h2,.post-content h3,.post-content h4,.post-content h5,.post-content h6{font-weight:600;letter-spacing:-.02em;line-height:1.2;color:var(--fg);scroll-margin-top:96px}.post-content h2{font-size:30px;margin:48px 0 20px}.post-content h3{font-size:26px;margin:48px 0 20px}.post-content h4{font-size:20px;margin:32px 0 12px;letter-spacing:-.015em}.post-content h5{font-size:17px;margin:24px 0 10px}.post-content h6{font-size:15px;margin:20px 0 8px;color:var(--fg-muted)}.post-content a{color:var(--accent);text-decoration:none;border-bottom:1px solid transparent;transition:border-color var(--t-fast)}.post-content a:hover{border-bottom-color:var(--accent)}.post-content strong{color:var(--fg);font-weight:600}.post-content em{font-style:italic}.post-content ul,.post-content ol{padding-left:24px;list-style:disc}.post-content ol{list-style:decimal}.post-content li{margin:0 0 6px}.post-content li>ul,.post-content li>ol{margin:6px 0}.post-content blockquote{margin:0 0 20px;padding:12px 20px;border-left:3px solid var(--border-strong);background:var(--bg-muted);color:var(--fg-muted);border-radius:0 var(--radius) var(--radius) 0;font-style:italic}.post-content blockquote p{margin:0 0 8px}.post-content blockquote p:last-child{margin-bottom:0}.post-content code{font-family:var(--font-mono);font-size:.9em;padding:2px 6px;background:var(--bg-muted);border:1px solid var(--border);border-radius:4px;color:var(--fg)}.post-content pre{padding:16px 20px;background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--radius);overflow-x:auto;font-family:var(--font-mono);font-size:14px;line-height:1.6}.post-content pre code{padding:0;background:none;border:0;border-radius:0;font-size:inherit}.post-content hr{border:0;border-top:1px solid var(--border);margin:40px 0}.post-content figure{margin:24px 0;text-align:center}.post-content figure img{display:block;max-width:100%;height:auto;margin:0 auto;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-muted)}.post-content figure figcaption{margin-top:10px;font-family:var(--font-mono);font-size:12px;color:var(--fg-subtle);letter-spacing:.02em}.post-content figure.img-cover img{width:640px;max-width:100%;aspect-ratio:16 / 5;object-fit:cover;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.post-content figure.img-full-cover img{width:100%;aspect-ratio:16 / 5;object-fit:cover;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.post-content figure.img-thumbnail img{width:768px;max-width:100%;height:auto;padding:12px;background:var(--bg-elev)}.post-content figure.img-tiny-thumbnail img{width:384px;max-width:100%;padding:8px;background:var(--bg-elev)}.post-content a.external:after{content:"\2197";display:inline-block;margin-left:2px;font-size:.85em;color:var(--fg-subtle);transition:color var(--t-fast)}.post-content a.external:hover:after{color:var(--accent)}.video-embed{position:relative;width:100%;aspect-ratio:16 / 9;margin:20px 0 8px;background:#000;box-shadow:var(--shadow-md)}.video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}.project-card{margin:24px 0;padding:24px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.project-card .icon{font-size:40px;color:var(--accent);line-height:1}.project-card .title{font-size:18px;font-weight:600;color:var(--fg);margin:0}.project-card .description{font-size:14px;color:var(--fg-muted);margin:0;line-height:1.55}.project-card .cta{display:inline-flex;align-items:center;gap:8px;margin-top:8px;padding:10px 18px;background:var(--fg);color:var(--bg);border-radius:var(--radius);font-weight:500;font-size:14px;text-decoration:none;transition:opacity var(--t-fast)}.project-card .cta:hover{opacity:.88;color:var(--bg)}@media(max-width:900px){.post-header{padding:16px 0 40px}.post-cover{margin-bottom:40px}.post-content{font-size:16px;line-height:1.7}.post-content h2{font-size:24px}.post-content h3{font-size:22px}.post-content>p:first-of-type{font-size:18px}}@media(max-width:520px){.container-reading,.post-cover{padding:0 20px}.post{padding-top:24px;padding-bottom:24px}.post-header{padding:8px 0 32px}.post-meta{font-size:12px;gap:8px}.post-content>p:first-of-type{font-size:17px;padding-left:16px}}
