:root{color-scheme:light;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html{scroll-behavior:smooth}body{margin:0;background:#fff;color:#1a1b1e}main{max-width:900px;margin:0 auto;padding:20px;line-height:1.6}nav{position:sticky;top:0;background:#fff;border-bottom:1px solid #e5e7eb;padding:.75rem 0;margin-bottom:1rem;z-index:10}h1,h2,h3{margin-top:.5rem}h1{font-size:2rem;line-height:1.2}h2{font-size:1.5rem}h3{font-size:1.1rem}p,li{color:#1a1b1e}a{font-weight:500;color:#2b6af3;text-decoration:none}a:hover{text-decoration:underline}a[target=_blank]:after{content:" ↗"}header,section{margin-bottom:2rem}article{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1rem;margin-bottom:1rem;box-shadow:0 2px 4px #0000000a}article:hover{box-shadow:0 4px 10px #0000000f}html.dark body{background:#0b0b0c;color:#e7e7ea}html.dark nav{background:#121214;border-bottom-color:#2a2a2e}html.dark p,html.dark li,html.dark h1,html.dark h2,html.dark h3{color:#e7e7ea}html.dark a{color:#9ecbff}html.dark article{background:#121214;border-color:#2a2a2e}html.dark article:hover{box-shadow:0 4px 10px #00000040}header.intro{text-align:center;margin-bottom:2rem}header.intro img{display:block;margin:0 auto .75rem;width:210px;height:210px;border-radius:50%;object-fit:cover;border:1px solid #e5e7eb;box-shadow:0 1px 2px #0000000f}html.dark header.intro img,html.dark header.intro .avatar{border-color:#2a2a2e;box-shadow:0 1px 2px #0000004d}header.intro h1{margin:0 0 .25rem}header.intro p{margin:.1rem 0}.muted{color:#6b7280}html.dark .muted{color:#a1a1aa}.site-footer{margin-top:2rem;font-size:.9rem;color:#6b7280}html.dark .site-footer{color:#a1a1aa}html,body,nav,article{transition:background-color .2s,color .2s,border-color .2s}@media (max-width: 640px){header.intro img{width:144px;height:144px}main{padding:16px}}video::-webkit-media-controls-start-playback-button{display:none!important}figure.clips{margin:0}.media-wrap{margin:.75rem 0 .5rem}.media{display:block;width:100%;max-width:100%;aspect-ratio:16 / 9;object-fit:cover;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 4px #0000000a;background:#000}#data-projects .dp-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:.5rem 0 1rem}#data-projects .media{aspect-ratio:auto;height:auto;object-fit:contain}#data-projects .dp-grid img{width:100%;height:auto;display:block;border-radius:12px;border:1px solid #e5e7eb}html.dark #data-projects .dp-grid img{border-color:#2a2a2e}#data-projects .dp-grid img:last-child{grid-column:1 / -1}@media (max-width: 640px){#data-projects .dp-grid{grid-template-columns:1fr}}#data-projects .dp-zoom{cursor:zoom-in}.dp-lightbox{position:fixed;inset:0;background:#000000bf;display:grid;place-items:center;z-index:1000}.dp-lightbox-inner{max-width:92vw;max-height:92vh;position:relative}.dp-lightbox-inner img{display:block;max-width:92vw;max-height:92vh;width:auto;height:auto;border-radius:12px;border:1px solid #e5e7eb;background:#fff}html.dark #data-projects .dp-lightbox-inner img,.dp-lightbox-inner video{display:block;max-width:92vw;max-height:92vh;width:auto;height:auto;border-radius:12px;border:1px solid #e5e7eb;background:#fff;border-color:#2a2a2e;background:#121214}.dp-lightbox-inner video{width:100%;height:auto}html.dark .dp-lightbox-inner img,html.dark .dp-lightbox-inner video{border-color:#2a2a2e;background:#121214}.dp-lightbox-close{position:absolute;top:-10px;right:-10px;width:28px;height:28px;border-radius:999px;border:1px solid #e5e7eb;background:#fff;color:#111;font-size:20px;line-height:1;cursor:pointer}html.dark .dp-lightbox-close{background:#121214;color:#e7e7ea;border-color:#2a2a2e}:root{--border: #e5e7eb;--bg-subtle: #f8fafc;--fg-muted: #475569}html.dark:root{--border: #2a2a2e;--bg-subtle: #121214;--fg-muted: #a1a1aa}.badge{display:inline-flex;align-items:center;gap:.4rem;padding:.25rem .6rem;border-radius:999px;border:1px solid var(--border);background:var(--bg-subtle);color:var(--fg-muted);font-size:.8rem;line-height:1}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem .9rem;border-radius:.6rem;border:1px solid var(--border);background:var(--bg-subtle);color:var(--fg-muted);text-decoration:none;transition:box-shadow .15s ease,transform .05s ease}.btn:hover{box-shadow:0 2px 8px #0000000f}.btn:active{transform:translateY(1px)}.btn[disabled],.btn.is-disabled{opacity:.65;cursor:not-allowed;box-shadow:none}a:focus-visible,button:focus-visible{outline:2px solid #93c5fd;outline-offset:2px}nav{box-shadow:0 0 #0000;transition:box-shadow .2s}@supports (position: sticky){body:has(nav) nav{box-shadow:0 1px 0 var(--border)}}.cta-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:10px}.cta-row a{padding:.5rem .75rem;border:1px solid var(--border, #e5e7eb);border-radius:10px;text-decoration:none}.cta-row a:hover{box-shadow:0 2px 10px #00000026}.clip-grid{display:grid;grid-template-columns:1fr;gap:12px;margin:.5rem 0 1rem}@media (min-width: 760px){.clip-grid{grid-template-columns:repeat(2,1fr)}}.clip .media{cursor:zoom-in}.clip figcaption{margin-top:.4rem;font-size:.9rem;color:var(--fg-muted)}.lb-nav{position:absolute;top:50%;transform:translateY(-50%);border:0;width:40px;height:40px;border-radius:10px;background:#0000008c;color:#fff;font-size:26px;line-height:1;cursor:pointer;display:grid;place-items:center}.lb-prev{left:-52px}.lb-next{right:-52px}@media (max-width: 640px){.lb-prev{left:6px}.lb-next{right:6px}}.dp-lightbox-inner{position:relative}.clip-controls{display:flex;align-items:center;gap:10px;margin-top:.5rem}.clip-controls button{padding:.4rem .7rem;border:1px solid var(--border, #e5e7eb);border-radius:10px;background:var(--bg-subtle, #f8fafc);cursor:pointer}.clip-controls .clip-count{font-size:.9rem;color:var(--fg-muted, #475569)}.clip-dots{display:flex;justify-content:center;gap:6px;margin-top:.4rem}.dot{border:none;background:transparent;cursor:pointer;font-size:1.5rem;line-height:1;padding:0;color:var(--fg-muted, #475569)}.dot.is-active{transform:scale(1.3);color:#2b6af3}html.dark .dot.is-active{color:#9ecbff}.clip{max-width:520px;margin:0 auto}
