:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#fff;--surface:#fff;--surface-2:#f8f8f8;--surface-3:#efefef;--text:#0a0a0a;--text-strong:#111;--muted:#3f3f46;--subtle:#737373;--line:#00000012;--line-strong:#0000001f;--grid-line:#00000008;--button-bg:#fff;--button-text:#171717;--button-border:#d8d8d8;--button-primary-bg:#111;--button-primary-text:#fff;--tag-bg:#2d2d2d;--tag-text:#f4f4f5;--media-bg:#fff;--heat-0:#f1f1f1;--heat-1:#dcdcdf;--heat-2:#bdbdc4;--heat-3:#92929c;--heat-4:#64646d;--radius-lg:18px;--radius-md:12px;--shadow:none;--content-width:900px;--content-gutter:48px;--about-rail-width:var(--content-width)}:root[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#090a0c;--surface:#111216;--surface-2:#17191f;--surface-3:#20232b;--text:#f4f4f5;--text-strong:#fff;--muted:#d0d3dc;--subtle:#8d93a0;--line:#ffffff17;--line-strong:#ffffff2e;--grid-line:#ffffff0b;--button-bg:#17191f;--button-text:#f4f4f5;--button-border:#ffffff24;--button-primary-bg:#f4f4f5;--button-primary-text:#090a0c;--tag-bg:#f4f4f5;--tag-text:#111216;--media-bg:#f8fafc;--heat-0:#181a20;--heat-1:#26352f;--heat-2:#2f6a52;--heat-3:#35a872;--heat-4:#5ee6a3}*{box-sizing:border-box}html{background:linear-gradient(var(--grid-line) 1px, transparent 1px), linear-gradient(90deg, var(--grid-line) 1px, transparent 1px), var(--bg);background-size:70px 70px}body{color:var(--text);letter-spacing:0;background:0 0;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow-x:clip}a{color:inherit;text-decoration:none}button{font:inherit}.topbar{z-index:20;width:min(var(--content-width), calc(100% - var(--content-gutter)));justify-content:space-between;align-items:center;margin:25px auto 0;display:flex;position:static}.floating-nav{box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;background:0 0;border:0;border-radius:0;gap:26px;padding:0;display:flex}.floating-nav a{min-width:0;color:var(--text-strong);text-align:center;border-radius:0;padding:0;font-size:14px;font-weight:400}.floating-nav a:hover{color:var(--text);background:0 0}.theme-button{width:30px;height:30px;color:var(--text-strong);cursor:pointer;background:0 0;border:0;place-items:center;display:grid}.shell{width:min(var(--content-width), calc(100% - var(--content-gutter)));margin:0 auto;padding:72px 0 48px}.page-shell{padding-top:112px}.about-page{padding-top:72px}.about-page>section{width:min(100%, var(--about-rail-width))}.hero-card,.contribution-card,.project-card,.contact-section,.message-panel,.about-hero,.catalog-hero,.build-band,.connect-band{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:none}.hero-card{text-align:left;background:0 0;border:0;padding:0;display:block}.identity-row{align-items:center;gap:16px;display:flex}.title-stack{min-width:0}.avatar-image{border:1px solid var(--line-strong);background:var(--surface);object-fit:cover;border-radius:10px;width:64px;height:64px}.avatar{border:1px solid var(--line-strong);background:#f8f8f8;border-radius:50%;place-items:center;width:54px;height:54px;display:grid}.avatar span{color:var(--text-strong);font-size:22px;font-weight:650}.avatar.small{width:54px;height:54px}.avatar.small span{font-size:22px}h1,h2,h3,p{margin:0}h1{margin-top:0;font-size:32px;font-weight:760;line-height:1.08}.subtitle-rotator{min-width:20ch;color:var(--subtle);margin-top:5px;font-size:16px;font-weight:600;line-height:1.35;display:inline-grid;position:relative;overflow:hidden}.subtitle-static{color:var(--subtle);margin-top:5px;font-size:16px;font-weight:600;line-height:1.35}.subtitle-rotator:after{z-index:3;pointer-events:none;content:"";opacity:0;filter:blur(9px);background:linear-gradient(90deg,#0000 0%,#fff6 40%,#ffffff24 58%,#0000 76%);position:absolute;inset:-4px -8px;transform:translate(-115%)}.subtitle-rotator.is-transitioning:after{animation:1.04s cubic-bezier(.22,1,.36,1) subtitle-wipe}.subtitle-word{white-space:nowrap;grid-area:1/1;display:block}@keyframes subtitle-wipe{0%{opacity:0;transform:translate(-115%)}28%{opacity:.42}to{opacity:0;transform:translate(115%)}}.subtitle-word{z-index:1;opacity:1}.subtitle-word-enter{z-index:2}.subtitle-word-exit{z-index:1}.subtitle-letter{white-space:pre;transition-property:opacity,filter,transform;transition-duration:.86s;transition-timing-function:cubic-bezier(.22,1,.36,1);transition-delay:var(--letter-delay);will-change:opacity, filter, transform;display:inline-block}.subtitle-word-enter .subtitle-letter{opacity:0;filter:blur(9px);transform:translate(-.16em)}.subtitle-word-enter.is-visible .subtitle-letter,.subtitle-word-ready .subtitle-letter{opacity:1;filter:none;transform:none}.subtitle-word-exit .subtitle-letter{opacity:1;filter:blur();transition-duration:.68s;transform:translate(0)}.subtitle-word-exit.is-hiding .subtitle-letter{opacity:0;filter:blur(10px);transform:translate(.14em)}@media (prefers-reduced-motion:reduce){.subtitle-letter{transition:none}.subtitle-word-enter .subtitle-letter{opacity:1;filter:none;transform:none}.subtitle-word-exit{display:none}}h2{font-size:22px;font-weight:650}h3{font-size:17px;font-weight:650}.meta-grid{text-align:left;background:0 0;border:0;border-radius:0;grid-template-columns:repeat(3,minmax(0,1fr));gap:42px;width:100%;margin-top:43px;display:grid;overflow:hidden}.meta-grid div{background:0 0;padding:0}.meta-grid span,.date,.place,.kicker{color:var(--subtle);letter-spacing:.16em;text-transform:uppercase;font-size:11px;display:block}.meta-grid strong{color:var(--muted);align-items:center;gap:7px;margin-top:10px;font-size:14px;font-weight:400;display:flex}.intro-copy{max-width:100%;color:var(--muted);margin-top:31px;font-size:16px;line-height:1.72}.intro-copy a{color:var(--text-strong);font-weight:650;text-decoration:none}.intro-actions{flex-wrap:wrap;gap:10px;margin-top:24px;display:flex}.action-button{border:1px solid var(--button-border);background:var(--button-bg);min-height:38px;color:var(--button-text);border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:0 14px;font-size:13px;font-weight:560;line-height:1;display:inline-flex}.action-button-primary{border-color:var(--button-primary-bg);background:var(--button-primary-bg);color:var(--button-primary-text)}.social-row,.tag-row,.hero-actions,.contact-links{flex-wrap:wrap;gap:8px;display:flex}.social-row{justify-content:flex-start;gap:18px;margin-top:28px}.social-row a,.tag-row span,.hero-actions a,.contact-links a,.build-band a,.connect-band a{color:#777;background:0 0;border:0;border-radius:0;justify-content:center;align-items:center;gap:0;font-size:13px;line-height:1;display:inline-flex}.social-row a,.hero-actions a,.contact-links a,.build-band a,.connect-band a{padding:0}.contribution-card{background:0 0;border:0;margin-top:40px;padding:0}.months,.heatmap-caption{color:var(--subtle);letter-spacing:.12em;text-transform:uppercase;justify-content:space-between;font-size:11px;display:flex}.heatmap{grid-template-rows:repeat(7,1fr);grid-template-columns:repeat(53,1fr);grid-auto-flow:column;gap:4px;margin:10px 0 21px;display:grid}.heatmap span,.heatmap-caption i{aspect-ratio:1;background:var(--heat-0);width:auto;height:auto;box-shadow:none;border-radius:2px;display:block}.heatmap span.level-1,.heatmap-caption i.level-1{background:var(--heat-1)}.heatmap span.level-2,.heatmap-caption i.level-2{background:var(--heat-2)}.heatmap span.level-3,.heatmap-caption i.level-3{background:var(--heat-3)}.heatmap span.level-4,.heatmap-caption i.level-4{background:var(--heat-4)}.heatmap-caption span:last-child{align-items:center;gap:5px;display:inline-flex}.heatmap-caption i{width:10px;height:10px}.section{margin-top:42px}.section h2{margin-bottom:18px}.tech-section{margin-top:41px}.tech-section h2{color:var(--subtle);letter-spacing:0;text-transform:uppercase;margin-bottom:30px;font-size:12px;font-weight:400}.tech-grid{grid-template-columns:repeat(8,42px);justify-content:space-between;align-items:center;gap:24px 0;display:grid}.tech-tile{justify-content:center;align-items:center;width:42px;height:42px;display:flex}.tech-tile img{object-fit:contain;width:40px;height:40px}.tech-logo{display:block}.tech-initials{background:var(--text-strong);width:40px;height:40px;color:var(--bg);letter-spacing:0;border-radius:10px;justify-content:center;align-items:center;font-size:11px;font-weight:720;display:inline-flex}.project-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.project-card{flex-direction:column;min-height:482px;padding:12px 12px 16px;display:flex}.project-media{aspect-ratio:13/7.2;border:1px solid var(--line);background:var(--media-bg);border-radius:11px;height:auto;overflow:hidden}.project-media img{object-fit:cover;width:100%;height:100%;display:block}.project-media div{border:1px solid var(--line);background:linear-gradient(var(--surface-3), var(--surface-2));border-radius:11px 11px 0 0;width:68%;height:70%;margin:24px auto 0}.project-head{justify-content:space-between;align-items:flex-start;gap:12px;margin-top:18px;display:flex}.project-head h3{min-width:0;max-width:none;color:var(--text-strong);text-overflow:ellipsis;white-space:nowrap;flex:auto;font-size:19px;font-weight:650;line-height:1.1;overflow:hidden}.project-links{flex:none;justify-content:flex-end;align-items:center;gap:14px;display:flex}.project-links a{width:28px;height:28px;color:var(--subtle);background:0 0;border:0;border-radius:0;justify-content:center;align-items:center;padding:0;line-height:1;transition:color .15s ease-out,transform .15s ease-out;display:inline-flex}.project-links a:hover{color:var(--text-strong);transform:translateY(-1px)}.project-card p,.timeline-body>p,.catalog-hero p,.about-hero p,.prose-section p,.principle-grid p,.service-grid p,.build-band p,.connect-band p,.message-panel p{color:var(--muted);max-width:58ch;font-size:15px;line-height:1.65}.project-card>p{color:var(--subtle);-webkit-line-clamp:3;-webkit-box-orient:vertical;min-height:4.65em;margin-top:14px;font-size:14px;line-height:1.55;display:-webkit-box;overflow:hidden}.project-card h4{color:var(--muted);margin:18px 0 0;font-size:15px;font-weight:650;line-height:1.2}.tag-row{margin-top:10px;padding-top:0}.tag-row span{background:var(--tag-bg);color:var(--tag-text);border-radius:7px;padding:6px 8px;font-size:12px;line-height:1}.experience-section{margin-top:72px}.experience-section h2{color:var(--subtle);letter-spacing:0;text-transform:uppercase;margin-bottom:18px;font-size:12px;font-weight:500}.timeline{gap:28px;display:grid;position:relative}.timeline:before{background:var(--line-strong);content:"";width:1px;position:absolute;top:8px;bottom:8px;left:3px}.timeline-item{padding-left:28px;position:relative}.timeline-dot{background:var(--subtle);border-radius:999px;width:7px;height:7px;position:absolute;top:7px;left:0}.timeline-dot.active{background:#34d399;animation:2.6s ease-in-out infinite timeline-dot-pulse;box-shadow:0 0 0 4px #34d39924}.timeline-dot.active:after{border-radius:inherit;content:"";opacity:0;background:#34d39924;animation:2.6s ease-out infinite timeline-dot-ring;position:absolute;inset:-7px;transform:scale(.55)}.timeline-head{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:4px 16px;display:flex}.role-line{flex-wrap:wrap;align-items:baseline;gap:8px;display:flex}.timeline-body h3{color:var(--text-strong);letter-spacing:0;font-size:15px;font-weight:500;line-height:1.25}.separator{color:var(--subtle)}.company{color:var(--subtle);font-size:13.5px;font-weight:450}.company.confidential{cursor:not-allowed;filter:blur(5px);-webkit-user-select:none;user-select:none}.date{color:var(--text-strong);letter-spacing:0;text-transform:none;white-space:nowrap;font-size:12px;font-weight:500}.place{color:var(--subtle);letter-spacing:0;text-transform:none;margin-top:1px;font-size:12.5px}.timeline-body>p:not(.place){color:var(--subtle);margin-top:8px;font-size:14px;font-weight:450;line-height:1.55}.timeline-body ul{gap:3px;margin:6px 0 0;padding:0;list-style:none;display:grid}.timeline-body li{max-width:58ch;color:var(--subtle);align-items:flex-start;gap:10px;font-size:13.5px;font-weight:450;line-height:1.5;display:flex}.timeline-body li>span{background:var(--subtle);border-radius:999px;flex:none;width:3px;height:3px;margin-top:8.5px}.experience-tags{flex-wrap:wrap;align-items:center;gap:8px;margin-top:10px;display:flex}.experience-tags img{object-fit:contain;width:20px;height:20px;transition:transform .15s ease-out}.experience-tags img:hover{transform:scale(1.1)}.contact-section{grid-template-columns:1fr .9fr;gap:18px;margin-top:48px;padding:22px;display:grid}.contact-section h2{margin-bottom:22px}.contact-section h3,.message-panel h3{margin-bottom:8px}.contact-links{margin-top:18px}.message-panel{box-shadow:none;background:0 0;border:0;padding:18px}.message-panel button{background:var(--surface-2);width:100%;color:var(--text-strong);border:0;border-radius:999px;margin-top:18px;padding:12px 14px;font-weight:650}.footer{border-top:1px solid var(--line);color:var(--subtle);text-align:center;gap:12px;padding-top:24px;font-size:13px;display:grid}.footer div{justify-content:center;gap:16px;display:flex}.about-hero,.catalog-hero{padding:36px}.about-page .about-hero{background:0 0;border:0;border-radius:0;padding:0}.about-hero h1,.catalog-hero h1{letter-spacing:0;margin-top:0;font-size:52px;line-height:1}.about-page .about-hero h1{max-width:100%;font-size:36px;font-weight:720;line-height:1.08}.about-page .about-hero h1 span{color:var(--subtle);font-weight:650;display:block}.about-hero p,.catalog-hero p{max-width:680px;color:var(--muted);margin-top:22px;font-size:18px;line-height:1.55}.about-page .about-hero p{max-width:100%;color:var(--muted);margin-top:22px;font-size:14.5px;line-height:1.75}.about-hero blockquote{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface-2);max-width:690px;color:var(--muted);margin:28px 0 0;padding:18px 20px;font-size:17px;font-weight:500;line-height:1.55}.about-page .about-hero blockquote{max-width:100%;color:var(--subtle);background:0 0;border:0;border-radius:0;margin:20px 0 0;padding:0;font-size:14.5px;font-style:italic;font-weight:450;line-height:1.65}.word-row,.fact-strip{flex-wrap:wrap;gap:8px;margin-top:24px;display:flex}.word-row span{border:1px solid var(--line);background:var(--surface-2);color:var(--muted);letter-spacing:0;border-radius:999px;padding:7px 10px;font-size:12px;font-weight:650}.about-page .word-row{gap:6px;margin-top:18px}.about-page .word-row span{border:0;border-radius:5px;padding:6px 8px;font-size:11px;font-weight:600}.about-page .word-row span:first-child{color:#16805b;background:#dff7ef}.about-page .word-row span:nth-child(2){color:#4f63c6;background:#eef2ff}.about-page .word-row span:nth-child(3){color:#7650b8;background:#f2e8ff}.fact-strip{border-top:1px solid var(--line);grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;padding-top:18px;display:grid}.about-page .fact-strip{border-top:0;gap:18px;margin-top:18px;padding-top:0;display:flex}.fact-strip span{gap:4px;min-width:0;display:grid}.about-page .fact-strip span{align-items:baseline;gap:6px;display:inline-flex}.fact-strip small{color:var(--subtle);text-transform:uppercase;font-size:11px;font-weight:650}.about-page .fact-strip small{letter-spacing:0;font-size:10px}.fact-strip strong{color:var(--muted);font-size:14px;font-weight:550}.about-page .fact-strip strong{color:var(--muted);font-size:12px;font-weight:500}.prose-section{margin-top:36px}.about-page .prose-section,.about-page .section,.about-page .connect-band{margin-top:50px}.prose-section h2,.split-prose h3{margin-bottom:14px}.prose-section h2{font-size:28px;line-height:1.1}.about-page .prose-section h2,.about-page .section h2,.about-page .connect-band h2{color:var(--text-strong);margin-bottom:16px;font-size:20px;font-weight:700;line-height:1.2}.prose-section p{color:var(--muted);font-size:17px;line-height:1.65}.about-page .prose-section p,.about-page .principle-grid p,.about-page .connect-band p{max-width:100%;color:var(--muted);font-size:14.5px;line-height:1.75}.prose-section p+p{margin-top:12px}.about-page .prose-section p+p{margin-top:18px}.principle-grid,.service-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.principle-grid article,.service-grid article{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface);padding:18px}.about-page .principle-grid article{background:color-mix(in srgb, var(--surface) 78%, transparent);padding:16px}.principle-grid h3,.service-grid h2{margin-bottom:8px;font-size:16px}.about-page .principle-grid h3{font-size:14px}.split-prose{grid-template-columns:1fr 1fr;gap:24px;display:grid}.about-page .split-prose{border:1px solid var(--line);border-radius:var(--radius-md);background:color-mix(in srgb, var(--surface) 78%, transparent);gap:14px;padding:18px}.about-page .split-prose h3{color:var(--muted);margin-bottom:8px;font-size:13px;font-weight:650}.connect-band,.build-band{margin-top:46px;padding:28px}.about-page .connect-band{background:0 0;border:0;border-radius:0;padding:0}.connect-band p,.build-band p{max-width:610px;margin-top:12px}.connect-band div,.build-band div{flex-wrap:wrap;gap:8px;margin-top:18px;display:flex}.catalog-hero{text-align:left}.hero-actions{margin-top:22px}.service-grid{margin-top:18px}.service-grid svg{color:var(--surface-3);margin-bottom:18px}:root[data-theme=dark] .project-card,:root[data-theme=dark] .catalog-hero,:root[data-theme=dark] .build-band,:root[data-theme=dark] .contact-section{background:#111216d1}:root[data-theme=dark] .project-media{box-shadow:none;background:#ffffff06;border-color:#ffffff0e}:root[data-theme=dark] .project-media.is-dark-media{background:#111;border-color:#ffffff0a}:root[data-theme=dark] .project-media.is-dark-media img{filter:saturate(.96)contrast(.98)}:root[data-theme=dark] .project-card>p{color:#c9ced8;font-weight:450}:root[data-theme=dark] .tech-tile{background:0 0;border:0;border-radius:0}:root[data-theme=dark] .tech-logo.monochrome-icon{filter:invert()brightness(1.05)}:root[data-theme=dark] .tech-initials{color:#f8fafc;background:#111216}:root[data-theme=dark] .social-row a,:root[data-theme=dark] .hero-actions a,:root[data-theme=dark] .contact-links a,:root[data-theme=dark] .build-band a,:root[data-theme=dark] .connect-band a{color:var(--subtle)}:root[data-theme=dark] .github-logo,:root[data-theme=dark] .project-links a{color:#f4f4f5}:root[data-theme=dark] .about-page .word-row span:first-child{color:#8ef2c6;background:#34d39929}:root[data-theme=dark] .about-page .word-row span:nth-child(2){color:#b8c0ff;background:#6366f12b}:root[data-theme=dark] .about-page .word-row span:nth-child(3){color:#d8b4fe;background:#a855f729}:root[data-theme=dark] .about-page .principle-grid article,:root[data-theme=dark] .about-page .split-prose{background:#111216b8}@keyframes timeline-dot-pulse{0%,to{box-shadow:0 0 0 4px #34d39924}50%{box-shadow:0 0 0 7px #34d39914}}@keyframes timeline-dot-ring{0%{opacity:.32;transform:scale(.55)}70%,to{opacity:0;transform:scale(1.6)}}@media (prefers-reduced-motion:reduce){.timeline-dot.active,.timeline-dot.active:after{animation:none}}@media (max-width:900px){.about-hero h1,.catalog-hero h1{font-size:44px}}@media (max-width:700px){.shell,.page-shell{width:min(100% - 22px, var(--content-width));padding-top:64px}.topbar{width:min(100% - 22px, var(--content-width));margin-top:18px}.floating-nav{flex:1;justify-content:flex-start;width:auto}.floating-nav a{flex:none;min-width:0;padding-left:0;padding-right:0;font-size:15px}.hero-card{padding:0}.about-hero,.catalog-hero{padding:28px 18px}.about-hero h1,.catalog-hero h1{font-size:40px;line-height:1.02}.about-hero p,.catalog-hero p{font-size:16px}.about-hero blockquote{padding:15px 16px;font-size:15px}.fact-strip{grid-template-columns:1fr}.about-page .fact-strip{grid-template-columns:1fr;gap:8px;display:grid}.meta-grid,.project-grid,.contact-section,.principle-grid,.service-grid,.split-prose{grid-template-columns:1fr}.meta-grid{gap:24px;margin-top:34px;overflow:visible}.meta-grid strong{margin-top:8px}.intro-copy{margin-top:30px;font-size:15.5px;line-height:1.66}.intro-actions{margin-top:22px}.social-row{margin-top:26px}.contribution-card{margin-top:34px}.months{letter-spacing:0;justify-content:flex-start;gap:8px;font-size:10px;overflow:hidden}.heatmap{grid-template-columns:repeat(53,minmax(0,1fr));gap:1px}.heatmap-caption{letter-spacing:0;flex-wrap:wrap;gap:8px 12px}.tech-grid{grid-template-columns:repeat(4,minmax(0,1fr));justify-content:stretch;gap:20px 14px;max-width:100%}.tech-tile{justify-self:center;width:38px;height:38px}.tech-tile img{width:37px;height:37px}.tech-initials{width:37px;height:37px;font-size:10px}.project-media{aspect-ratio:13/7.2;height:auto}.project-card{min-height:0}.project-card>p{-webkit-line-clamp:unset;min-height:0;display:block;overflow:visible}.project-head h3{text-overflow:clip;white-space:normal;overflow:visible}}
