*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fff;--fg:#1a1a1a;--muted:#777;--border:#e0e0e0;--max-w:680px}html{color:var(--fg);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,Helvetica,Arial,sans-serif;font-size:17px;line-height:1.6}body,#root{min-height:100vh}.st-header{align-items:baseline;gap:.75rem;margin-bottom:.75rem;display:flex}.st-title{color:var(--fg);font-size:.875rem;font-weight:500}.st-sub{color:var(--muted);font-size:.78rem}.st-wrap{flex-direction:column;gap:2px;display:flex}.st-months{align-items:flex-end;display:flex}.st-dow-spacer{flex-shrink:0;width:16px}.st-month-row{gap:1px;display:flex}.st-month-cell{width:9px;color:var(--muted);white-space:nowrap;font-size:.55rem;overflow:visible}.st-grid-row{gap:4px;display:flex}.st-dow-col{flex-direction:column;flex-shrink:0;gap:2px;width:12px;display:flex}.st-dow-label{height:9px;color:var(--muted);text-align:right;font-size:.55rem;line-height:9px}.st-grid{gap:1px;display:flex}.st-col{flex-direction:column;gap:1px;display:flex}.st-cell{cursor:default;border-radius:2px;width:9px;height:9px;transition:opacity .15s}.st-cell:hover{opacity:.7}.st-legend{align-items:center;gap:3px;margin-top:4px;display:flex}.st-legend-label{color:var(--muted);margin:0 2px;font-size:.58rem}.st-tooltip{z-index:100;pointer-events:none;background:var(--fg);color:var(--bg);white-space:nowrap;border-radius:3px;padding:.25rem .55rem;font-size:.72rem}.page{grid-template-columns:200px 1fr;align-items:start;gap:0 4rem;max-width:860px;margin:0 auto;padding:4rem 1.5rem 8rem;display:grid}.sidebar{flex-direction:column;gap:1.5rem;display:flex;position:sticky;top:4rem}.sidebar-photo{aspect-ratio:1;background:#f0f0f0;border-radius:4px;justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.sidebar-photo img{object-fit:cover;width:100%;height:100%;display:block;transform:scale(1.2)}.sidebar-photo-placeholder{color:#aaa;letter-spacing:.06em;-webkit-user-select:none;user-select:none;font-size:.72rem}.sidebar-name{flex-direction:column;gap:.25rem;display:flex}.page-name{letter-spacing:-.02em;font-size:1.1rem;font-weight:600;line-height:1.3}.page-subtitle{color:var(--muted);font-size:.8rem;line-height:1.5}.page-nav{flex-direction:column;gap:.3rem;display:flex}.page-nav a{color:var(--muted);width:fit-content;font-size:.875rem;text-decoration:none}.page-nav a:hover{color:var(--fg)}.main{min-width:0}.section-rule{border:none;border-top:1px solid var(--border);margin-bottom:2.5rem}.section{margin-bottom:2.5rem;scroll-margin-top:2rem}.section-heading{letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem;font-size:.7rem;font-weight:600}.bio{color:var(--fg);font-size:.9375rem;line-height:1.7}.news-list{flex-direction:column;gap:1.4rem;display:flex;position:relative}.news-list:before{content:"";background:var(--border);width:1px;position:absolute;top:.45em;bottom:.45em;left:6.35rem}.news-row{grid-template-columns:2rem 2.75rem 1.2rem 1fr;align-items:center;column-gap:.5rem;display:grid;position:relative}.news-logo-cell{justify-content:center;align-items:center;height:22px;display:flex}.news-logo{object-fit:contain;opacity:.85;width:auto;max-width:2rem;max-height:22px}.news-year{color:var(--muted);text-align:right;padding-right:.4rem;font-size:.75rem;line-height:1}.news-dot{z-index:1;justify-content:center;display:flex;position:relative}.news-dot:after{content:"";border:1.5px solid var(--muted);background:#fff;border-radius:50%;flex-shrink:0;width:7px;height:7px}.news-text{color:var(--fg);padding-left:.5rem;font-size:.875rem;line-height:1.6}.under-construction{align-items:center;gap:.6rem;display:flex}.crane-logo{object-fit:contain;opacity:.7;width:auto;height:18px}.crane-placeholder{font-size:1rem;line-height:1}.under-construction-text{color:var(--muted);font-size:.875rem}.project-list{flex-direction:column;display:flex}.project-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:baseline;gap:1.5rem;padding:.7rem 0;display:flex}.project-row:first-child{border-top:1px solid var(--border)}.project-left{flex-direction:column;gap:.15rem;min-width:0;display:flex}.project-name{color:var(--fg);font-size:.9rem}.project-name a{color:var(--fg);text-underline-offset:2px;text-decoration:underline;-webkit-text-decoration-color:var(--border);text-decoration-color:var(--border);transition:text-decoration-color .15s}.project-name a:hover{-webkit-text-decoration-color:var(--fg);text-decoration-color:var(--fg)}.project-role{color:var(--muted);font-size:.78rem}.project-year{color:var(--muted);white-space:nowrap;flex-shrink:0;font-size:.8rem}.blog-list{flex-direction:column;gap:.5rem;list-style:none;display:flex}.blog-entry{align-items:baseline;gap:.75rem;display:flex}.blog-date{color:var(--muted);white-space:nowrap;min-width:5.5rem;font-size:.8rem}.blog-title-btn{cursor:pointer;color:var(--fg);text-underline-offset:2px;text-decoration:underline;-webkit-text-decoration-color:var(--border);text-decoration-color:var(--border);background:0 0;border:none;padding:0;font-family:inherit;font-size:.875rem}.blog-title-btn:hover{-webkit-text-decoration-color:var(--fg);text-decoration-color:var(--fg)}.blog-post-view{flex-direction:column;gap:1rem;display:flex}.blog-back-btn{cursor:pointer;color:var(--muted);background:0 0;border:none;padding:0;font-family:inherit;font-size:.8rem}.blog-back-btn:hover{color:var(--fg)}.blog-post-title{font-size:1rem;font-weight:600}.blog-post-body{white-space:pre-wrap;font-size:.875rem;line-height:1.75}.contact-section{flex-direction:column;gap:.75rem;display:flex}.contact-email{color:var(--fg);text-underline-offset:2px;text-decoration:underline;-webkit-text-decoration-color:var(--border);text-decoration-color:var(--border);font-size:.9375rem}.contact-email:hover{-webkit-text-decoration-color:var(--fg);text-decoration-color:var(--fg)}.contact-links{flex-wrap:wrap;gap:1.25rem;display:flex}.contact-links a{color:var(--muted);font-size:.875rem;text-decoration:none}.contact-links a:hover{color:var(--fg);text-underline-offset:2px;text-decoration:underline}@media (width<=600px){.page{grid-template-columns:1fr;gap:2.5rem 0;padding:2.5rem 1.25rem 6rem}.sidebar{flex-flow:wrap;align-items:flex-start;gap:1.25rem;position:static}.sidebar-photo{aspect-ratio:1;flex-shrink:0;width:80px}.sidebar-name{flex:1;min-width:140px}.page-nav{flex-flow:wrap;gap:.4rem 1rem;width:100%}}
