:root{--bg: #ffffff;--bg-alt: #fafafa;--surface: #f4f4f5;--text: #0f0f14;--text-muted: #6b6b76;--text-dim: #a0a0ab;--border: #e4e4e7;--border-strong: #d4d4d8;--accent: #5e6ad2;--accent-hover: #4d59c0;--accent-soft: #8a93e0;--serif: "Newsreader", ui-serif, Georgia, serif;--sans: "Geist", ui-sans-serif, system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif;--mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;--section-gap: 72px;--bullet-gap: 8px}html[data-theme=dark]{--bg: #0f0f14;--bg-alt: #14141a;--surface: #1a1a20;--text: #f5f5f5;--text-muted: #9b9ba6;--text-dim: #6b6b76;--border: #26262d;--border-strong: #33333c}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--text)}body{font-family:var(--sans);font-size:15px;line-height:1.55;font-feature-settings:"ss01","cv11";-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}::selection{background:var(--accent);color:#fff}.page{max-width:980px;margin:0 auto;padding:16px 56px 120px}.topbar{display:flex;justify-content:space-between;align-items:center;padding-bottom:24px;border-bottom:1px solid var(--border);margin-bottom:40px;font-family:var(--mono);font-size:11px;color:var(--text-dim);letter-spacing:.02em}.topbar .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent);vertical-align:1px}.topbar a{color:inherit;text-decoration:none}.topbar a:hover{color:var(--text)}.topbar-left{display:flex;align-items:center;gap:12px}.topbar-right{display:flex;align-items:center;gap:16px}.theme-toggle{background:none;border:none;cursor:pointer;color:var(--text-dim);padding:0;display:flex;align-items:center;transition:color .2s ease;font-family:var(--mono);font-size:11px;letter-spacing:.02em}.theme-toggle:hover{color:var(--text)}.theme-toggle svg{width:13px;height:13px}.icon-sun{display:none}.icon-moon,html[data-theme=dark] .icon-sun{display:block}html[data-theme=dark] .icon-moon{display:none}.hero{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:end;padding-bottom:56px;border-bottom:1px solid var(--border)}.hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(48px,7vw,84px);line-height:.98;letter-spacing:-.02em;margin:0;color:var(--text)}.hero h1 .terra{color:var(--accent)}.hero .role{font-family:var(--serif);font-style:italic;font-weight:400;font-size:22px;line-height:1.3;color:var(--text-muted);margin:24px 0 0}.hero-meta{display:flex;flex-direction:column;gap:10px;font-size:13px;color:var(--text-muted);padding-bottom:6px}.hero-meta .label{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);display:block;margin-bottom:2px}.hero-meta a{color:var(--text);text-decoration:none;border-bottom:1px solid var(--border);padding-bottom:1px}.hero-meta a:hover{color:var(--accent);border-color:var(--accent-soft)}section{padding-top:var(--section-gap)}.sec-head{display:flex;flex-direction:column;gap:14px;margin-bottom:40px}.sec-head .line{display:block;width:0;height:1px;background:var(--accent);transition:width .9s cubic-bezier(.2,.7,.2,1) .12s}.sec-head.in-view .line{width:72px}.sec-title{font-family:var(--serif);font-weight:500;font-size:36px;line-height:1;letter-spacing:-.01em;margin:0;opacity:0;transform:translateY(6px);transition:opacity .7s cubic-bezier(.2,.7,.2,1) 80ms,transform .7s cubic-bezier(.2,.7,.2,1) 80ms}.sec-head.in-view .sec-title{opacity:1;transform:none}.prose{max-width:680px;font-family:var(--serif);font-size:19px;line-height:1.55;color:var(--text);text-wrap:pretty}.prose p{margin:0}.prose p+p{margin-top:18px}.prose em{color:var(--accent);font-style:italic;font-weight:500}.roles{display:flex;flex-direction:column}.role-row{display:block;padding:32px 0;border-top:1px solid var(--border)}.role-row:first-child{border-top:none;padding-top:0}.role-head{display:flex;justify-content:space-between;align-items:baseline;gap:24px;margin-bottom:4px}.role-head h3{margin:0}.kbd{display:inline-block;font-family:var(--mono);font-size:11px;line-height:1;padding:5px 7px;background:var(--surface);border:1px solid var(--border);border-radius:4px;color:var(--text-muted);letter-spacing:.01em;white-space:nowrap;flex-shrink:0}.role-body h3{font-family:var(--serif);font-weight:500;font-size:26px;line-height:1.15;letter-spacing:-.005em;margin:0 0 4px;color:var(--text)}.role-body .title{font-size:14px;color:var(--text-muted);margin:0 0 18px;display:flex;align-items:center;gap:8px}.role-body .title .at{color:var(--text-dim)}.role-body .title .position{color:var(--text);font-weight:500}.role-body ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:var(--bullet-gap)}.role-body li{position:relative;padding-left:18px;font-size:14.5px;line-height:1.6;color:var(--text);max-width:620px}.role-body li:before{content:"";position:absolute;left:0;top:.7em;width:8px;height:1px;background:var(--border-strong)}.role-body li b{font-weight:600;color:var(--text);background-image:linear-gradient(transparent 65%,color-mix(in oklab,var(--accent) 24%,transparent) 65%);background-repeat:no-repeat;background-position:left bottom;background-size:0% 100%;padding:0 1px;transition:background-size .72s cubic-bezier(.2,.7,.2,1)}.role-row.in-view .role-body li b{background-size:100% 100%}.role-row.in-view .role-body li:nth-child(1) b{transition-delay:.18s}.role-row.in-view .role-body li:nth-child(2) b{transition-delay:.28s}.role-row.in-view .role-body li:nth-child(3) b{transition-delay:.38s}.role-row.in-view .role-body li:nth-child(4) b{transition-delay:.48s}.role-row.in-view .role-body li:nth-child(5) b{transition-delay:.58s}.role-row.in-view .role-body li:nth-child(6) b{transition-delay:.68s}.skills-table{display:flex;flex-direction:column;border-top:1px solid var(--border)}.skills-row{display:grid;grid-template-columns:180px 1fr;gap:24px;padding:14px 0;border-bottom:1px solid var(--border);align-items:baseline}.skills-row .k{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim)}.skills-row .v{font-size:14.5px;color:var(--text);line-height:1.5;display:flex;flex-wrap:wrap;gap:6px 0}.skills-row .v .s{position:relative;padding-right:14px}.skills-row .v .s:after{content:"";position:absolute;right:6px;top:50%;width:2px;height:2px;border-radius:50%;background:var(--text-dim);transform:translateY(-50%)}.skills-row .v .s:last-child{padding-right:0}.skills-row .v .s:last-child:after{display:none}.skills-row .v .s.star{color:var(--accent);font-weight:500}.edu-list{display:flex;flex-direction:column}.edu-row{display:grid;grid-template-columns:1fr auto;gap:24px;padding:18px 0;border-top:1px solid var(--border);align-items:baseline}.edu-row:first-child{border-top:none}.edu-row h4{font-family:var(--serif);font-weight:500;font-size:20px;line-height:1.2;margin:0 0 4px}.edu-row .sub{font-size:13.5px;color:var(--text-muted)}.edu-row .when{font-family:var(--mono);font-size:11px;color:var(--text-dim);letter-spacing:.03em;white-space:nowrap}.foot{margin-top:var(--section-gap);padding-top:32px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim)}.foot a{color:var(--text-muted);text-decoration:none}.foot a:hover{color:var(--accent)}.page-hero{padding-bottom:56px;border-bottom:1px solid var(--border)}.page-hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(40px,6vw,72px);line-height:.98;letter-spacing:-.02em;margin:0;color:var(--text)}.page-hero h1 .terra{color:var(--accent)}.page-hero p{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--text-muted);margin:20px 0 0}.proj-list{display:flex;flex-direction:column}.proj-row{padding:28px 0;border-top:1px solid var(--border);opacity:0;transform:translateY(8px);transition:opacity .6s cubic-bezier(.2,.7,.2,1),transform .6s cubic-bezier(.2,.7,.2,1)}.proj-row:first-child{border-top:none;padding-top:0}.proj-row.in-view{opacity:1;transform:none}.proj-row:nth-child(1){transition-delay:40ms}.proj-row:nth-child(2){transition-delay:90ms}.proj-row:nth-child(3){transition-delay:.14s}.proj-row:nth-child(4){transition-delay:.19s}.proj-row:nth-child(5){transition-delay:.24s}.proj-row:nth-child(6){transition-delay:.29s}.proj-row:nth-child(n+7){transition-delay:.34s}.proj-head{display:flex;justify-content:space-between;align-items:baseline;gap:24px;margin-bottom:8px}.proj-name{font-family:var(--serif);font-weight:500;font-size:22px;line-height:1.15;letter-spacing:-.005em;margin:0;color:var(--text)}.proj-lang{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim)}.proj-desc{font-size:14.5px;line-height:1.6;color:var(--text-muted);max-width:620px;margin:0 0 12px}.proj-links{display:flex;gap:16px}.proj-links a{font-family:var(--mono);font-size:11px;color:var(--text-dim);text-decoration:none;letter-spacing:.02em;transition:color .2s ease}.proj-links a:hover{color:var(--accent)}.proj-empty{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--text-muted);padding:48px 0}.term{font-family:var(--mono);font-size:12.5px;line-height:1.7;cursor:default}.term-line{display:flex;gap:8px;align-items:baseline}.term-prompt{color:var(--accent);flex-shrink:0;user-select:none}.term-cmd{color:var(--text);letter-spacing:-.01em}.term-cursor{color:var(--accent)}.term-out{padding-left:16px;color:var(--text-dim);font-size:12px;opacity:0;transition:opacity .25s ease;min-height:1.7em}.topbar{opacity:0;animation:fadeIn .5s ease forwards;animation-delay:0ms}.hero h1,.hero .role,.hero-meta>div,.page-hero h1,.page-hero p{opacity:0;transform:translateY(8px);animation:eIn .7s cubic-bezier(.2,.7,.2,1) forwards}.hero h1{animation-delay:.12s}.hero .role{animation-delay:.32s}.hero-meta>div:nth-child(1){animation-delay:.44s}.hero-meta>div:nth-child(2){animation-delay:.5s}.hero-meta>div:nth-child(3){animation-delay:.56s}.hero-meta>div:nth-child(4){animation-delay:.62s}.page-hero h1{animation-delay:.12s}.page-hero p{animation-delay:.28s}@keyframes eIn{to{opacity:1;transform:none}}@keyframes fadeIn{to{opacity:1}}.hero h1 .terra{display:inline-block;opacity:0;transform:scale(.2);animation:terraIn .6s cubic-bezier(.34,1.56,.64,1) .82s forwards}.page-hero h1 .terra{display:inline-block;opacity:0;transform:scale(.2);animation:terraIn .6s cubic-bezier(.34,1.56,.64,1) .48s forwards}@keyframes terraIn{to{opacity:1;transform:scale(1)}}@media(prefers-reduced-motion:reduce){.topbar,.hero h1,.hero .role,.hero-meta>div,.hero h1 .terra,.page-hero h1,.page-hero h1 .terra,.page-hero p{animation:none;opacity:1;transform:none}.sec-title{opacity:1;transform:none;transition:none}.sec-head .line{width:72px;transition:none}.role-body li b{background-size:100% 100%;transition:none}.proj-row{opacity:1;transform:none;transition:none}}@media(max-width:760px){.page{padding:12px 24px 80px}.hero{grid-template-columns:1fr;gap:32px}.hero-meta{padding-bottom:0}.role-head{flex-wrap:wrap;gap:6px 16px}.role-row{padding:24px 0}.skills-row{grid-template-columns:1fr;gap:6px}.topbar{font-size:10px;flex-wrap:wrap;gap:8px}.proj-head{flex-wrap:wrap;gap:4px 16px}}@media print{.page{padding:24px 0;max-width:none}section{padding-top:36px;break-inside:avoid}.role-row{break-inside:avoid}body{font-size:11pt}.hero h1{font-size:48pt}.sec-title{font-size:22pt}.role-body h3{font-size:14pt}a{color:inherit!important;border:none!important}.theme-toggle,.topbar-left a[href="/projects"]{display:none}}
