@import "https://fonts.googleapis.com/css2?family=Fragment+Mono:wght@400&display=swap";*{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#0f0f0f;--bg-secondary:#0b0b0b;--bg-tertiary:#0a0a0a;--bg-elevated:#101010;--bg-inset:#111;--text-primary:#f0f0f0;--text-secondary:#ccc;--text-muted:var(--text-faint);--text-faint:#666;--text-subtle:#555;--accent:#6b8e23;--accent-dim:#6b8e2326;--accent-subtle:#6b8e2314;--border:#222;--border-subtle:#1a1a1a;--bg:var(--bg-primary);--text:var(--text-primary)}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:Fragment Mono,monospace;overflow-x:hidden}.container{grid-template-columns:1fr 1fr;min-height:100vh;display:grid}.progress-bar{background:var(--accent);z-index:1000;height:3px;transition:width .1s ease-out;position:fixed;top:0;left:0}.sidebar-left{border-right:1px solid var(--border);flex-direction:column;justify-content:space-between;height:100vh;padding:48px;display:flex;position:sticky;top:0}.content-right{padding:48px}.profile-header{margin-bottom:24px}.right{padding:48px}.name{letter-spacing:-.04em;margin-bottom:24px;font-size:clamp(48px,10vw,120px);line-height:.85}.name span{opacity:0;animation:.8s forwards fadeInUp;display:block;transform:translateY(20px)}.name span:first-child{animation-delay:.2s}.name span:nth-child(2){animation-delay:.4s}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}.name .accent{color:var(--accent)}.meta{color:var(--text-muted);opacity:0;font-size:14px;line-height:1.8;animation:.8s .6s forwards fadeInUp;transform:translateY(20px)}.meta span{margin-top:8px;display:block}.nav{opacity:0;margin-top:16px;animation:.8s .8s forwards fadeInUp}.nav a,.nav button{color:var(--text);border-bottom:1px solid var(--border);cursor:pointer;width:100%;font-family:inherit;font-size:16px;font-size:inherit;background:0 0;border-top:none;border-left:none;border-right:none;align-items:center;gap:12px;padding:16px 0;text-decoration:none;transition:all .3s;display:flex;position:relative;overflow:hidden}.nav a:before,.nav button:before{content:"";background:var(--accent);width:4px;height:100%;transition:transform .3s;position:absolute;top:0;left:0;transform:scaleY(0)}.nav a:hover,.nav button:hover{color:var(--accent);padding-left:16px}.nav a:hover:before,.nav button:hover:before{transform:scaleY(1)}.nav-number{color:var(--text-subtle);min-width:20px;font-size:12px}.nav a:hover .nav-number,.nav button:hover .nav-number{color:var(--accent)}.section{opacity:1;margin-bottom:80px;transition:opacity .6s,transform .6s;transform:none}.section.visible{opacity:1;transform:translateY(0)}.section:last-child{margin-bottom:0}.section-header{align-items:center;gap:16px;margin-bottom:32px;display:flex}.section-title{color:var(--accent);letter-spacing:.1em;font-size:12px}.section-line{background:var(--border);flex:1;height:1px}.work-item{border:1px solid var(--border);margin-bottom:48px;padding:24px;transition:all .3s}.work-item:hover{border-color:var(--accent);background:var(--accent-dim);transform:translate(8px)}.work-item h3{align-items:center;gap:12px;margin-bottom:12px;font-size:28px;font-weight:400;display:flex}.work-item h3 a{color:var(--text);text-decoration:none;transition:color .2s}.work-item h3 a:hover{color:var(--accent)}.work-item h3:after{content:"↗";color:var(--accent);opacity:0;font-size:16px;transition:all .3s;transform:translate(-8px,8px)}.work-item:hover h3:after{opacity:1;transform:translate(0)}.work-item p{color:var(--text-muted);margin-bottom:12px;font-size:14px}.work-item .tech{color:var(--accent);flex-wrap:wrap;gap:8px;margin:0;padding:0;font-size:12px;list-style:none;display:flex}.work-item .tech li:not(:last-child):after{content:"·";color:var(--border);margin-left:8px}.work-collapsible{border:1px solid var(--border);margin-top:24px;transition:border-color .3s}.work-collapsible:hover{border-color:var(--accent)}.work-collapsible-content .work-item{margin-bottom:12px;padding:16px 24px}.work-collapsible-content .work-item:last-child,.work-collapsible-content .work-item h3{margin-bottom:0}.work-tooltip{background:var(--bg-elevated);border:1px solid var(--border);z-index:100;opacity:0;visibility:hidden;pointer-events:none;width:320px;padding:16px;transition:opacity .2s,visibility .2s;position:fixed;box-shadow:0 8px 32px #0006}.work-tooltip.visible{opacity:1;visibility:visible}.work-tooltip-image{aspect-ratio:16/10;background:linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);border:1px dashed var(--border);justify-content:center;align-items:center;width:100%;margin-bottom:12px;display:flex}img.work-tooltip-image{object-fit:cover;border:none;display:block}.work-tooltip-image span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-size:12px}.work-tooltip-title{color:var(--text);font-size:14px;display:block}.work-summary{cursor:pointer;color:var(--text);align-items:center;gap:12px;padding:24px;font-size:14px;list-style:none;transition:background .3s;display:flex}.work-summary::-webkit-details-marker{display:none}.work-summary:before{content:"▶";color:var(--accent);font-size:10px;transition:transform .3s}.work-collapsible[open] .work-summary:before{transform:rotate(90deg)}.work-collapsible-content{padding:0 24px 24px}.skills-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin:0;padding:0;list-style:none;display:grid}.skill{border:1px solid var(--border);cursor:default;flex-direction:column;gap:4px;padding:20px;font-size:14px;transition:all .3s;display:flex;position:relative;overflow:hidden}.skill:before{content:"";background:var(--accent);opacity:0;z-index:-1;width:100%;height:100%;transition:all .3s;position:absolute;top:0;left:0;transform:translateY(100%)}.skill:hover{border-color:var(--accent);color:var(--bg)}.skill:hover:before{opacity:1;transform:translateY(0)}.skill-name{margin-bottom:4px;font-weight:600}.skill-desc{color:var(--text-muted);font-size:11px}.skill:hover .skill-desc{color:#0009}.about-text{border:1px solid var(--border);padding:24px;font-size:22px;line-height:1.7;transition:all .3s}.about-text:hover{border-color:var(--accent)}.about-text strong{color:var(--accent);font-weight:400}.contact-list{flex-direction:column;gap:8px;display:flex}.contact-item{color:var(--text);align-items:center;gap:12px;padding:16px 0;font-size:24px;text-decoration:none;transition:all .3s;display:inline-flex}.contact-item:before{content:"→";color:var(--accent);opacity:0;transition:all .3s;transform:translate(-8px)}.contact-item:hover{color:var(--accent);padding-left:8px}.contact-item:hover:before{opacity:1;transform:translate(0)}.footer{border-top:1px solid var(--border);color:var(--text-muted);gap:24px;margin-top:80px;padding-top:24px;font-size:12px;display:flex}.links{flex-direction:column;gap:8px;margin-top:16px;display:flex}.links-link{color:var(--text);border:1px solid var(--border);align-items:center;gap:12px;padding:16px 20px;font-size:14px;text-decoration:none;transition:all .3s;display:flex;position:relative;overflow:hidden}.links-icon{background:var(--border);width:32px;height:32px;color:var(--text);justify-content:center;align-items:center;font-size:10px;font-weight:600;transition:all .3s;display:flex}.links-link:before{content:"";background:var(--accent);width:4px;height:100%;transition:transform .3s;position:absolute;top:0;left:0;transform:scaleY(0)}.links-link:hover{border-color:var(--accent);background:var(--accent-dim);padding-left:28px}.links-link:hover:before{transform:scaleY(1)}.links-link:hover .links-icon{background:var(--accent);color:var(--bg)}.links-container{flex-direction:column;justify-content:center;align-items:center;max-width:400px;min-height:100vh;margin:0 auto;padding:48px;display:flex}.links-header{text-align:center;margin-bottom:48px}.links-header .name{margin-bottom:16px;font-size:clamp(32px,8vw,64px)}.links-header .meta{opacity:1;animation:none;transform:none}.back-link{color:var(--text-muted);margin-top:48px;font-size:14px;text-decoration:none;transition:color .3s}.back-link:hover{color:var(--accent)}@media (width<=900px){.container{grid-template-columns:1fr}.sidebar-left{border-right:none;border-bottom:1px solid var(--border);height:auto;padding:32px;position:relative}.content-right{padding:32px}.skills-grid{grid-template-columns:1fr}.about-text{font-size:18px}.work-item h3{font-size:24px}.contact-item{font-size:20px}}@media (width<=500px){.sidebar-left,.content-right{padding:24px}.skills-grid{grid-template-columns:1fr}.links-container{padding:24px}.name{font-size:clamp(36px,12vw,64px)}.about-text{padding:16px;font-size:16px}.work-item{padding:16px}.work-item h3{font-size:20px}.contact-item{font-size:16px}.section{margin-bottom:48px}.footer{flex-direction:column;gap:12px}}.notes-container{flex-direction:column;justify-content:center;align-items:center;max-width:600px;min-height:100vh;margin:0 auto;padding:48px;display:flex}.notes-header{text-align:center;margin-bottom:48px}.notes-header .name{margin-bottom:16px;font-size:clamp(32px,8vw,64px)}.notes-header .meta{opacity:1;animation:none;transform:none}.notes-list{flex-direction:column;gap:12px;width:100%;display:flex}.note-card{border:1px solid var(--border);color:var(--text);align-items:center;gap:16px;padding:20px 24px;text-decoration:none;transition:all .3s;display:flex;position:relative;overflow:hidden}.note-card-content{flex-direction:column;flex:1;gap:4px;display:flex}.note-card:before{content:"";background:var(--accent);width:4px;height:100%;transition:transform .3s;position:absolute;top:0;left:0;transform:scaleY(0)}.note-card:hover{border-color:var(--accent);background:var(--accent-dim);padding-left:32px}.note-card:hover:before{transform:scaleY(1)}.note-card-date{color:var(--text-muted);white-space:nowrap;font-size:12px}.note-card-title{margin:0;font-size:16px;font-weight:400}.note-card-arrow{color:var(--accent);opacity:0;transition:all .3s;transform:translate(-8px)}.note-card:hover .note-card-arrow{opacity:1;transform:translate(0)}.notes-empty{color:var(--text-muted);text-align:center;padding:64px 0;font-size:14px}.notes-reader{flex-direction:column;max-width:720px;min-height:100vh;margin:0 auto;padding:48px;display:flex}.notes-back{color:var(--text-muted);margin-bottom:48px;font-size:14px;text-decoration:none;transition:color .3s}.notes-back:hover{color:var(--accent)}.notes-back-bottom{margin-top:64px;margin-bottom:0}.notes-article{flex:1}.notes-article-date{color:var(--accent);letter-spacing:.1em;text-transform:uppercase;margin-bottom:32px;font-size:12px;display:block}.notes-article-content{color:var(--text);font-size:16px;line-height:1.8}.notes-article-content h1{margin:0 0 24px;font-size:32px;font-weight:400;line-height:1.2}.notes-article-content h2{color:var(--text-secondary);margin:48px 0 16px;font-size:24px;font-weight:400;line-height:1.3}.notes-article-content h3{color:var(--text-secondary);margin:32px 0 12px;font-size:20px;font-weight:400}.notes-article-content p{margin:0 0 16px}.notes-article-content ul,.notes-article-content ol{margin:0 0 16px;padding-left:24px}.notes-article-content li{margin-bottom:8px}.notes-article-content blockquote{border-left:3px solid var(--accent);color:var(--text-secondary);margin:24px 0;padding:12px 0 12px 24px;font-style:italic}.notes-article-content code{background:var(--bg-elevated);color:var(--accent);padding:2px 6px;font-family:Fragment Mono,monospace;font-size:14px}.notes-article-content pre{background:var(--bg-elevated);border:1px solid var(--border);margin:24px 0;padding:24px;overflow-x:auto}.notes-article-content pre code{color:var(--text);background:0 0;padding:0;font-size:14px}.notes-article-content hr{border:none;border-top:1px solid var(--border);margin:32px 0}.notes-article-content strong{color:var(--accent);font-weight:400}.notes-article-content a{color:var(--accent);text-decoration:none;transition:opacity .2s}.notes-article-content a:hover{opacity:.8}.notes-article-content img{max-width:100%;height:auto}@media (width<=500px){.notes-container,.notes-reader{padding:24px}.note-card{padding:16px}.note-card:hover{padding-left:24px}.note-card-title{font-size:14px}.notes-article-content h1{font-size:24px}.notes-article-content h2{font-size:20px}}
