html,body{margin:0;width:100%;height:100%}:root{--bg-main: #f8f8f8;--bg-surface: rgba(194, 194, 194, .15);--bg-overlay: rgba(255, 255, 255, .78);--text-primary: #302e2e;--text-secondary: #777777;--text-muted: #5e6660;--dark-green: #223728;--light-green: #f4ffed;--accent: #00d33c;--accent-soft: #f4ffed;--border: rgba(58, 52, 52, .1);--page-padding: 32px;--timeline-shell: 852px;--timeline-column: 686px;--focus-column: 1310px;--focus-viewport-top: 0px;--focus-viewport-left: 0px;--focus-viewport-width: 100%;--focus-viewport-height: 100dvh;--card-radius: 8px;--mono: "SF Mono", "SFMono-Regular", Consolas, "Liberation Mono", monospace}*,*:before,*:after{box-sizing:border-box}body{font-family:Host Grotesk,Manrope,Avenir Next,Segoe UI,sans-serif;line-height:normal;background:var(--bg-main);color:var(--text-primary);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body.timeline-detail-open{overflow:hidden}.page{position:relative;width:100%;margin:0 auto;padding:48px var(--page-padding) 350px}.site-nav{--site-nav-ease: cubic-bezier(.22, 1, .36, 1);--site-nav-height: 60px;--site-nav-width: var(--timeline-column);--site-nav-padding: 32px;--site-nav-gap: 24px;--site-nav-glass: rgba(255, 255, 255, .46);--site-nav-glass-edge: rgba(255, 255, 255, .88);--site-nav-glass-shadow: rgba(34, 55, 40, .12);position:sticky;top:14px;z-index:10;width:min(100%,var(--site-nav-width));height:var(--site-nav-height);margin:-34px auto -26px;display:flex;align-items:center;justify-content:space-between;gap:var(--site-nav-gap);padding:0 var(--site-nav-padding);border:1px solid var(--site-nav-glass-edge);border-radius:50px;background:linear-gradient(180deg,#ffffffbd,#ffffff47),var(--site-nav-glass);box-shadow:0 18px 42px var(--site-nav-glass-shadow),inset 0 1px #ffffffeb,inset 0 -14px 24px #fff3;overflow:hidden;isolation:isolate;-webkit-backdrop-filter:blur(24px) saturate(1.55) brightness(1.08);backdrop-filter:blur(24px) saturate(1.55) brightness(1.08);transition:width .36s var(--site-nav-ease),height .32s var(--site-nav-ease),padding .36s var(--site-nav-ease),gap .32s var(--site-nav-ease),opacity .22s ease,transform .32s var(--site-nav-ease),filter .26s ease}.site-nav:before,.site-nav:after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none}.site-nav:before{z-index:0;background:radial-gradient(130% 90% at 18% 0%,rgba(255,255,255,.98) 0%,rgba(255,255,255,.36) 38%,transparent 64%),radial-gradient(100% 76% at 88% 100%,rgba(255,255,255,.42) 0%,transparent 58%);opacity:.86}.site-nav:after{z-index:1;box-shadow:inset 0 0 0 1px #ffffff85,inset 0 0 18px #ffffff57,inset 0 -1px #22372814;mix-blend-mode:screen}.site-nav.is-compact{--site-nav-height: 45px;--site-nav-width: 430px;--site-nav-padding: 20px;--site-nav-gap: 14px;--site-nav-glass: rgba(255, 255, 255, .5);--site-nav-glass-shadow: rgba(34, 55, 40, .15)}.site-nav>*{position:relative;z-index:2}.hero{--hero-light-y: 48%;min-height:469px;display:flex;align-items:center;justify-content:center;padding:64px 32px;border-radius:var(--card-radius);background:radial-gradient(ellipse 92% 118% at 100% var(--hero-light-y),#e1c5ae 0%,#a1b190 19%,#81a781 29%,#619d72 39%,#426a4d 69%,#32513b 84%,#223728 100%);text-align:center;transition:opacity .22s ease,transform .26s ease,filter .26s ease}body.timeline-detail-open .site-nav,body.timeline-detail-open .hero{opacity:var(--timeline-bg-opacity, .58);transform:scale(var(--timeline-bg-scale, .98));filter:blur(var(--timeline-bg-blur, 2px)) saturate(var(--timeline-bg-saturate, .88))}.hero-body{display:grid;justify-items:center;gap:32px;width:min(100%,980px)}.kicker{display:grid;margin:0;width:155px;min-width:155px;overflow:hidden;color:var(--dark-green);font-size:18px;letter-spacing:0;text-transform:none;transition:width .36s var(--site-nav-ease),min-width .36s var(--site-nav-ease),font-size .32s var(--site-nav-ease)}.site-nav.is-compact .kicker{width:34px;min-width:34px;font-size:16px}.kicker-full,.kicker-short{grid-area:1 / 1;transition:opacity .18s ease,transform .26s var(--site-nav-ease);white-space:nowrap}.kicker-short{opacity:0;transform:translateY(3px)}.site-nav.is-compact .kicker-full{opacity:0;transform:translateY(-3px)}.site-nav.is-compact .kicker-short{opacity:1;transform:translateY(0)}.social-links{display:flex;align-items:center;gap:4px;min-width:0}.social-link{display:inline-grid;place-items:center;width:32px;height:32px;color:var(--dark-green);transition:color .16s ease,transform .16s ease}.social-link:hover{color:var(--accent);transform:translateY(-1px)}.social-link svg{width:14px;height:14px;fill:currentColor}h1{margin:0;color:#fff;font-size:70px;font-weight:500;line-height:1;letter-spacing:0}.intro{margin:0;max-width:640px;color:var(--light-green);font-size:18px;line-height:1.2;text-wrap:pretty}.timeline-shell{width:min(100%,var(--timeline-shell));margin:78px auto 0}.timeline-filters{position:relative;display:flex;flex-wrap:wrap;gap:8px 4px;justify-content:center;align-items:flex-start;padding:8px 0 16px;isolation:isolate;transform-origin:center 45%}.timeline-filters.is-filter-blob-pending{opacity:0;transform:scale(.9)}.timeline-filters.has-filter-blob-layout{opacity:1;transform:scale(1);transition:opacity .18s ease-out,transform .52s cubic-bezier(.19,1,.22,1)}.filter-blob-layer{position:absolute;inset:0;width:100%;height:100%;z-index:0;overflow:visible;pointer-events:none}.filter-blob{--filter-active-x: 0px;--filter-active-y: 0px;fill:#fffffff5;opacity:0;transform:translate(var(--filter-active-x),var(--filter-active-y));transform-box:fill-box;transform-origin:center}.timeline-filters.is-filter-blob-animated .filter-blob{transition:fill .22s ease,opacity .16s ease,transform .44s cubic-bezier(.22,1,.36,1)}.timeline-filters.has-filter-blob-layout .filter-blob{opacity:1}.filter-button{--filter-active-x: 0px;--filter-active-y: 0px;position:relative;display:inline-flex;align-items:center;justify-content:center;min-height:27px;border:1px solid #ffffff;border-radius:20px;padding:4px 8px;background:#fff;color:var(--dark-green);font:inherit;font-size:14px;line-height:1.2;cursor:pointer;transform:translate3d(var(--filter-active-x),var(--filter-active-y),0);z-index:1}.timeline-filters.is-filter-blob-animated .filter-button{transition:background .22s ease,border-color .22s ease,color .22s ease,transform .44s cubic-bezier(.22,1,.36,1)}.timeline-filters.has-filter-blob-layout .filter-button{border-color:transparent;background:transparent}.filter-button:hover,.filter-button.is-active{background:var(--accent-soft);color:var(--text-primary)}.timeline-filters.has-filter-blob-layout .filter-button:hover,.timeline-filters.has-filter-blob-layout .filter-button.is-active{background:transparent}.filter-blob.is-active,.filter-blob.is-preview{fill:var(--accent-soft)}.filter-blob.is-popping{animation:filter-blob-pop .52s cubic-bezier(.22,1,.36,1)}.filter-button:focus-visible,.item-trigger:focus-visible,.back-link:focus-visible,.social-link:focus-visible,.primary-link:focus-visible,.link-list a:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.timeline{position:relative;width:min(100%,var(--timeline-column));margin-inline:auto;display:grid;gap:78px}.timeline.is-filtering{pointer-events:none}.year-group[hidden],.item[hidden]{display:none}.year-group{display:grid;gap:16px;align-items:start;padding:0;transition:opacity .22s ease}.year{margin:0;min-height:31px;color:var(--text-primary);font-size:14px;font-weight:400}.items{margin:0;padding:0;list-style:none;display:grid;gap:16px;min-width:0}.item{border-radius:var(--card-radius);transition:opacity .18s ease,transform .22s ease}.timeline-filter-ghost{position:fixed;z-index:10;display:block;margin:0;padding:0;border-radius:var(--card-radius);pointer-events:none;transform-origin:top center;will-change:opacity,transform}.timeline-filter-ghost .timeline-card{width:100%;height:100%}.timeline.has-focus .item,.timeline.has-focus .item.is-focused{opacity:1}.timeline.has-focus .year,.timeline.has-focus .timeline-card{opacity:var(--timeline-bg-opacity, .58);transform:scale(var(--timeline-bg-scale, .98));filter:blur(var(--timeline-bg-blur, 2px)) saturate(var(--timeline-bg-saturate, .88))}.timeline-card{position:relative;border-radius:var(--card-radius);overflow:hidden;transition:opacity .17s ease,transform .22s ease,filter .26s ease}.timeline-card-surface,.focus-surface{position:absolute;inset:0;border-radius:inherit;background:var(--bg-surface);pointer-events:none}.timeline-card-surface{overflow:hidden;transition:background .17s ease}.timeline-card-surface:before{content:"";position:absolute;inset:0;border-radius:inherit;opacity:0;transition:opacity .22s ease,background-position .56s ease}.timeline-card-surface:before{background:linear-gradient(90deg,#f4ffed 0% 30%,#fbf8ed 62%,#f8ead6);background-size:180% 100%;background-position:0% 50%}.focus-surface{border:1px solid var(--border)}.timeline-card:hover .timeline-card-surface,.timeline-card:focus-within .timeline-card-surface,.timeline-card:has(.item-trigger:focus-visible) .timeline-card-surface,.item.is-featured .timeline-card:hover .timeline-card-surface,.item.is-featured .timeline-card:focus-within .timeline-card-surface,.item.is-featured .timeline-card:has(.item-trigger:focus-visible) .timeline-card-surface{background:var(--bg-surface)}.timeline-card:hover .timeline-card-surface:before,.timeline-card:focus-within .timeline-card-surface:before,.timeline-card:has(.item-trigger:focus-visible) .timeline-card-surface:before{opacity:1}.timeline-card:hover .timeline-card-surface:before,.timeline-card:focus-within .timeline-card-surface:before,.timeline-card:has(.item-trigger:focus-visible) .timeline-card-surface:before{background-position:100% 50%}.item.is-focused .timeline-card{opacity:0;filter:none;transform:none;pointer-events:none}.item-trigger{position:relative;z-index:1;width:100%;min-height:148px;display:grid;align-content:center;gap:8px;padding:24px;border:0;background:transparent;text-align:left;color:inherit;cursor:pointer;min-width:0}.item.is-featured .item-trigger{padding:24px}.item-trigger:focus-visible{border-radius:var(--card-radius)}.meta{margin:0;display:flex;gap:.5rem;align-items:center;color:var(--text-muted);font-family:var(--mono);font-size:12px;line-height:1.35;text-transform:none;overflow-wrap:anywhere}.item h3{margin:0;color:#272727;font-size:20px;font-weight:400;line-height:1.28;overflow-wrap:anywhere}.item-highlight{display:-webkit-box;max-width:62ch;margin:2px 0 0;overflow:hidden;color:var(--text-secondary);font-size:14px;line-height:1.35;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow-wrap:anywhere}.item.is-featured .item-title{margin-top:0;font-size:20px;line-height:1.28}.subtitle,.summary{margin:0}.subtitle{color:var(--text-secondary);font-size:14px;line-height:1.35;overflow-wrap:anywhere}.focus-panel{position:fixed;top:var(--focus-viewport-top);left:var(--focus-viewport-left);right:auto;bottom:auto;width:var(--focus-viewport-width);height:var(--focus-viewport-height);z-index:20;overflow-y:auto;overscroll-behavior:contain;padding:calc(clamp(7rem,13.5vw,194px) + env(safe-area-inset-top,0px)) var(--page-padding) calc(4rem + env(safe-area-inset-bottom,0px));background:var(--bg-overlay);backdrop-filter:blur(15px);opacity:1;visibility:visible;pointer-events:auto;transition:opacity .22s ease,visibility 0s linear 0s}.focus-panel[hidden]{display:none}.focus-inner{position:relative;box-sizing:border-box;width:min(100%,var(--focus-column));margin:0 auto;transform:translateY(var(--detail-pull-offset, 0px)) scale(var(--detail-scale, 1));transform-origin:top center;transition:transform .16s ease}.focus-panel.is-pulling .focus-inner{transition:none;will-change:transform}.detail-hero{display:grid;gap:34px;min-width:0}.detail-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:19px;min-width:0}.detail-card{position:relative;min-height:448px;border-radius:var(--card-radius);overflow:hidden;min-width:0}.detail-card>:not(.focus-surface){position:relative;z-index:1}.detail-card-primary{display:flex;align-items:center;padding:48px 32px}.detail-card-primary .focus-surface{border:0;background:linear-gradient(90deg,#f1ffed,#f8ead6)}.detail-card-note{display:flex;align-items:center;justify-content:center;padding:60px;background:var(--dark-green);transform-origin:center}.item.is-focused .detail-card-note{animation:focus-note-panel-in .56s cubic-bezier(.22,1,.36,1) .18s both}.detail-main{display:grid;gap:32px;width:100%;min-width:0}.detail-heading{display:grid;gap:8px}.detail-meta{margin:0;color:var(--text-secondary);font-family:var(--mono);font-size:12px;line-height:1.35;text-transform:none;overflow-wrap:anywhere}.focus-reveal{display:grid;gap:24px;min-width:0}.detail-title{margin:0;color:#272727;font-size:28px;font-weight:400;line-height:1.2;letter-spacing:0;overflow-wrap:anywhere}.summary{max-width:68ch;color:#272727;font-size:18px;line-height:1.28;overflow-wrap:anywhere}.note{margin:0;color:var(--light-green);font-size:19px;line-height:1.25;overflow-wrap:anywhere}.tech-list,.link-list{margin:0;padding:0;list-style:none;display:flex;flex-wrap:wrap;gap:8px;min-width:0}.tech-list li{padding:4px 8px;border:1px solid rgba(34,55,40,.14);border-radius:10px;color:#272727;background:#ffffff80;font-size:14px;line-height:1.2;overflow-wrap:anywhere}.media{margin:0;border:1px solid var(--border);border-radius:var(--card-radius);overflow:hidden;background:#c2c2c224}.media img{display:block;width:100%;aspect-ratio:var(--media-aspect);object-fit:cover}.detail-actions{display:flex;flex-wrap:wrap;align-items:center;gap:14px}.primary-link{display:inline-flex;align-items:center;justify-content:center;min-height:43px;padding:12px;border-radius:4px;background:var(--dark-green);color:var(--light-green);font-size:14px;line-height:1.2;text-decoration:none}.primary-link:hover{background:#16251b}.link-list a{color:#272727;font-size:14px;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px;overflow-wrap:anywhere}.link-list a:hover{color:var(--dark-green)}.back-link{justify-self:center;width:fit-content;color:#000;font-family:var(--mono);font-size:14px;line-height:1.35;text-align:center;text-decoration:none;text-transform:uppercase;overflow-wrap:anywhere}.back-link:hover{color:var(--dark-green)}@supports (view-transition-name: none){@keyframes focus-detail-content-in{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes focus-detail-content-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-8px)}}::view-transition-group(*){animation-duration:.32s;animation-timing-function:cubic-bezier(.22,1,.36,1)}::view-transition-group(timeline-detail-content){z-index:3}::view-transition-group(timeline-detail-note){z-index:2}::view-transition-group(timeline-detail-back){z-index:4}::view-transition-new(timeline-detail-note){animation:focus-note-panel-in .56s cubic-bezier(.22,1,.36,1) .18s both;transform-origin:center}::view-transition-old(timeline-detail-note){animation:focus-note-panel-out .1s cubic-bezier(.55,0,.45,1) both;transform-origin:center}::view-transition-new(timeline-detail-back){animation:focus-detail-content-in .3s cubic-bezier(.22,1,.36,1) 20ms both}::view-transition-old(timeline-detail-back){animation:focus-detail-content-out .16s ease both}::view-transition-new(timeline-detail-content){animation:focus-detail-content-in .34s cubic-bezier(.22,1,.36,1) 40ms both}::view-transition-old(timeline-detail-content){animation:focus-detail-content-out .18s ease both}::view-transition-old(*),::view-transition-new(*){height:100%;overflow:visible}::view-transition-image-pair(*){overflow:visible}}@media(max-width:1024px){:root{--page-padding: 24px}h1{font-size:56px}.detail-grid{grid-template-columns:1fr}.detail-card{min-height:auto}.detail-card-note{padding:40px;transform-origin:center}.item.is-focused .detail-card-note{animation-name:focus-note-panel-in-stacked}@supports (view-transition-name: none){::view-transition-new(timeline-detail-note){animation-name:focus-note-panel-in-stacked;transform-origin:center}::view-transition-old(timeline-detail-note){animation-name:focus-note-panel-out-stacked;transform-origin:center}}@supports not (view-transition-name: none){.item.is-focused .detail-card-note{animation-name:focus-note-panel-in-stacked}}}@media(max-width:720px){:root{--page-padding: 16px}.page{padding-top:42px;padding-bottom:4rem}.site-nav{--site-nav-height: 56px;--site-nav-padding: 18px;--site-nav-gap: 16px;top:10px;margin-top:-32px;margin-bottom:-24px}.site-nav.is-compact{--site-nav-height: 45px;--site-nav-width: 252px;--site-nav-padding: 14px;--site-nav-gap: 8px}body.timeline-detail-open .site-nav,body.timeline-detail-open .hero{opacity:var(--timeline-bg-opacity, .38);filter:none;transform:none}.timeline.has-focus .year,.timeline.has-focus .timeline-card{opacity:0;filter:none;transform:none}.kicker{min-width:0;font-size:16px}.social-links{gap:2px}.social-link{width:32px;height:32px}.social-link svg{width:13px;height:13px}.hero{min-height:386px;padding:54px 24px}.hero-body{gap:24px}h1{font-size:42px;line-height:1.04}.intro{font-size:16px;line-height:1.32}.timeline-shell{margin-top:54px}.timeline{gap:56px}.item-trigger{min-height:138px;padding:20px}.item.is-featured .item-trigger{padding:20px}.item h3,.item.is-featured .item-title{font-size:19px}.item-highlight{max-width:none;font-size:13px}.focus-panel{padding:calc(1rem + env(safe-area-inset-top,0px)) 1rem calc(1rem + env(safe-area-inset-bottom,0px));background:#f8f8f8f5}.focus-inner{width:100%}.item.is-focused .focus-panel{animation:mobile-focus-panel-in .18s ease both}.item.is-focused .detail-card-primary{animation:mobile-focus-card-in .28s cubic-bezier(.22,1,.36,1) 20ms both}.item.is-focused .detail-card-note{animation-duration:.34s;animation-delay:90ms}.item.is-focused .back-link{animation:mobile-focus-card-in .24s cubic-bezier(.22,1,.36,1) .12s both}.detail-hero{gap:22px}.detail-grid{gap:12px}.detail-card-primary,.detail-card-note{padding:24px}.detail-main{gap:24px}.detail-title{font-size:26px}.summary,.note{font-size:16px;line-height:1.35}}@media(max-width:430px){.site-nav{--site-nav-padding: 14px}.site-nav.is-compact{--site-nav-width: 236px;--site-nav-padding: 12px}.kicker{font-size:15px}.social-links{gap:13px}h1{font-size:38px}}@media(prefers-reduced-motion:reduce){html:focus-within{scroll-behavior:auto}.item,.timeline-filter-ghost,.site-nav,.timeline-filters,.filter-blob,.filter-button,.kicker,.kicker-full,.kicker-short,.hero,.year,.timeline-card,.timeline-card-surface:before,.detail-card-note,.detail-card-primary,.back-link,.focus-panel,.focus-inner,::view-transition-group(*),::view-transition-old(*),::view-transition-new(*){transition:none!important;animation-duration:1ms!important}.hero{--hero-light-y: 48% !important}.timeline-card:hover,.focus-inner,body.timeline-detail-open .site-nav,body.timeline-detail-open .hero,.timeline.has-focus .year,.timeline.has-focus .timeline-card{transform:none;filter:none}}@keyframes filter-blob-pop{0%{transform:translate(var(--filter-active-x),var(--filter-active-y)) scale(.94)}52%{transform:translate(var(--filter-active-x),var(--filter-active-y)) scale(1.08)}76%{transform:translate(var(--filter-active-x),var(--filter-active-y)) scale(.985)}to{transform:translate(var(--filter-active-x),var(--filter-active-y)) scale(1)}}@keyframes focus-note-panel-in{0%{opacity:0;clip-path:inset(14% 10% round var(--card-radius));transform:scale(.94)}60%{opacity:1}to{opacity:1;clip-path:inset(0 0 0 0 round var(--card-radius));transform:scale(1)}}@keyframes focus-note-panel-out{0%{opacity:1;clip-path:inset(0 0 0 0 round var(--card-radius));filter:brightness(1) saturate(1);transform:scale(1)}35%{opacity:.12;filter:brightness(1.55) saturate(.65)}to{opacity:0;clip-path:inset(10% 8% round var(--card-radius));filter:brightness(1.85) saturate(.45);transform:scale(.98)}}@keyframes mobile-focus-panel-in{0%{opacity:0}to{opacity:1}}@keyframes mobile-focus-card-in{0%{opacity:0;transform:translateY(14px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes focus-note-panel-in-stacked{0%{opacity:0;clip-path:inset(14% 10% round var(--card-radius));transform:scale(.94)}60%{opacity:1}to{opacity:1;clip-path:inset(0 0 0 0 round var(--card-radius));transform:scale(1)}}@keyframes focus-note-panel-out-stacked{0%{opacity:1;clip-path:inset(0 0 0 0 round var(--card-radius));filter:brightness(1) saturate(1);transform:scale(1)}35%{opacity:.12;filter:brightness(1.55) saturate(.65)}to{opacity:0;clip-path:inset(10% 8% round var(--card-radius));filter:brightness(1.85) saturate(.45);transform:scale(.98)}}
