:root{--bg: #f5f4ed;--surface: #faf9f5;--fg: #141413;--muted: #504e49;--stone: #6b6a64;--border: #e8e6dc;--accent: #1B365D;--warm-sand: #e8e6dc;--ink: var(--fg);--soft: var(--stone);--line: var(--border);--box: var(--surface)}*{box-sizing:border-box}html{background:var(--bg)}body{margin:0;min-height:100vh;background:var(--bg);color:var(--fg);font-family:Charter,Georgia,Iowan Old Style,Palatino Linotype,Palatino,serif;font-size:19px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}strong{font-weight:500}a{color:var(--accent);text-decoration-thickness:1px;text-underline-offset:.13em}a:hover{color:var(--fg)}.page{width:min(100% - 120px,904px);margin:0 auto;padding:68px 0 76px}.intro h1{margin:0;color:var(--fg);font-size:clamp(3.25rem,6.1vw,4.1rem);font-weight:500;line-height:.95;letter-spacing:0}.intro-copy{max-width:670px;margin:28px 0 0;color:var(--muted);font-size:clamp(1.35rem,2.25vw,1.55rem);line-height:1.42}.contact-links{display:flex;flex-wrap:wrap;gap:18px;align-items:center;margin-top:44px;color:var(--stone)}.contact-links a{display:inline-flex;width:22px;height:22px;color:var(--stone);text-decoration:none}.contact-links svg{display:block;width:100%;height:100%;fill:currentColor}.contact-links a:hover{color:var(--accent)}.contact-links a:focus-visible{outline:1px solid var(--accent);outline-offset:5px}.section h2{margin:0;color:var(--soft);font-size:1.08rem;font-weight:400;line-height:1;letter-spacing:.12em}.timeline-section{margin-top:72px}.timeline{position:relative;margin-top:34px}.timeline:before{content:"";position:absolute;top:104px;bottom:104px;left:52px;width:1px;background:var(--line)}.timeline-entry{position:relative;display:grid;grid-template-columns:104px minmax(0,1fr);column-gap:58px;align-items:center;min-height:104px}.timeline-entry+.timeline-entry{margin-top:42px}.logo-box{position:relative;z-index:1;display:grid;place-items:center;width:104px;height:104px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:inherit;text-decoration:none;transition:box-shadow .2s}.logo-box:hover{box-shadow:0 4px 24px #0000000d}.logo-box:focus-visible{outline:1px solid var(--accent);outline-offset:5px}.logo-box img{display:block;max-width:78px;max-height:72px;object-fit:contain}.logo-box img[src*=clsa]{max-width:84px;max-height:42px}.logo-box img[src*=hktv]{max-width:78px;max-height:54px}.logo-box img[src*=manchester]{max-width:88px;max-height:44px}.logo-box img[src*=hkust]{max-width:54px;max-height:76px}.entry-copy{padding-top:2px}.years{margin:0 0 7px;color:var(--muted);font-size:1.2rem;line-height:1.15}.entry-copy h3{margin:0;color:var(--fg);font-size:1.125rem;font-weight:500;line-height:1.3}.entry-copy h3 .entry-company{display:block;color:var(--muted);font-size:1rem;font-weight:400;margin-top:1px}.entry-copy h3 .entry-school{color:var(--muted);font-size:1rem;font-weight:400;white-space:nowrap}.entry-copy h3 .entry-sep{color:var(--stone);font-size:.875rem;font-weight:400}.entry-copy h3 .entry-meta{display:inline;color:var(--muted);font-size:.875rem;font-weight:400}.entry-copy p:not(.years){max-width:690px;margin:10px 0 0;color:var(--muted);font-size:1rem;line-height:1.55}.projects-section{margin-top:72px}.projects{margin:28px 0 0}.projects>div{display:grid;grid-template-columns:220px minmax(0,1fr);column-gap:30px;align-items:baseline;padding:12px 0;border-bottom:1px solid var(--border)}.projects>div:first-child{border-top:1px solid var(--border)}.projects dt,.projects dd{margin:0}.projects dt{color:var(--fg);font-size:1rem;font-weight:500;line-height:1.35}.projects dd{color:var(--muted);font-size:.9rem;line-height:1.45}@media(max-width:760px){.page{width:min(100% - 44px,904px);padding-top:44px}.contact-links{gap:0 14px}.timeline:before{left:38px}.timeline-entry{grid-template-columns:76px minmax(0,1fr);column-gap:26px}.logo-box{width:76px;height:76px;border-radius:8px}.logo-box img{max-width:58px;max-height:52px}.logo-box img[src*=clsa]{max-width:60px;max-height:30px}.logo-box img[src*=hktv]{max-width:58px;max-height:40px}.logo-box img[src*=manchester]{max-width:62px}.logo-box img[src*=hkust]{max-height:54px}.timeline-entry+.timeline-entry{margin-top:36px}.entry-copy h3{font-size:1.125rem}.entry-copy p:not(.years),.years{font-size:1rem}.projects div{grid-template-columns:1fr;row-gap:4px}}@media(max-width:500px){body{font-size:17px}.intro-copy{font-size:1.2rem}.timeline-section{margin-top:58px}.timeline{margin-top:30px}.timeline-entry{align-items:start}}
