*,:before,:after{box-sizing:border-box}:root{--bg-color:#000;--text-color:#fff;--border-color:#333;--avatar-border-color:#333;--theme-toggle-color:#fff}body.light-mode{--bg-color:#ede8d5;--text-color:#1a1a1a;--border-color:#c5bfa8;--avatar-border-color:#aaa;--theme-toggle-color:#c8921a}body{background-color:var(--bg-color);color:var(--text-color);font-family:Space Mono,monospace;transition:background-color .3s,color .3s}.page-wrapper{max-width:860px;margin:0 auto;padding:2rem}h1{white-space:nowrap;letter-spacing:.1em;width:fit-content;margin-bottom:2rem;font-size:3rem;font-weight:700;line-height:1.2;display:block;position:relative}.typing:after{content:"|";margin-left:.05em;animation:.7s step-end infinite ti-cursor-blink}h2{opacity:0;width:fit-content;max-height:0;margin-bottom:1rem;font-size:2rem;font-weight:700;transition:max-height .4s cubic-bezier(0,1,0,1),opacity .4s ease-out;display:block;position:relative;overflow:hidden}h2.expanded{opacity:1;max-height:100px;transition:max-height .4s ease-in-out,opacity .4s ease-in;overflow:visible}h2.highlighted{background-color:var(--selection-bg,#39f);color:var(--selection-text,#fff)}h2.underlined{text-underline-offset:4px;text-decoration:underline;overflow:visible}.stagger-item{opacity:0;pointer-events:none;transition:opacity .35s,transform .35s;transform:translateY(6px)}.stagger-item.printed{opacity:1;pointer-events:auto;transform:translateY(0)}@keyframes ti-cursor-blink{0%,to{opacity:1}50%{opacity:0}}.cta{width:fit-content;margin-top:1rem;position:relative}nav{justify-content:space-between;align-items:center;margin-bottom:3rem;display:flex}.nav-links{align-items:center;gap:2rem;margin:0;padding:0;list-style:none;display:flex}.nav-link{color:var(--text-color);letter-spacing:.05em;font-size:.95rem;text-decoration:none;transition:opacity .2s}.nav-link:hover{text-underline-offset:3px;text-decoration:underline}.theme-toggle{color:var(--theme-toggle-color);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:32px;height:32px;padding:0;line-height:1;transition:color .3s,font-size .3s;display:flex}.avatar{border:.5px solid var(--avatar-border-color);object-fit:cover;border-radius:50%;width:90px;height:90px;transition:filter .3s,border-color .3s}body.light-mode .avatar{filter:invert()}footer{border-top:1px solid var(--border-color);opacity:0;pointer-events:none;gap:1.5rem;margin-top:.75rem;padding-top:1.5rem;transition:opacity .5s ease-in-out,border-color .3s;display:flex}footer.revealed{opacity:1;pointer-events:auto}.footer-link{color:var(--text-color);opacity:.75;transition:opacity .3s}.footer-link:hover{opacity:1}.about-items{border-left:1px solid #0000;padding-left:1.25rem;transition:border-color .35s}.about-items.revealed{border-color:var(--border-color)}.about-item{margin-bottom:.25rem}.notes-list{flex-direction:column;display:flex}.note-row{border-bottom:1px solid var(--border-color);color:var(--text-color);align-items:baseline;gap:1.5rem;padding:.5rem 0;text-decoration:none;transition:opacity .2s;display:flex}.note-row:first-child{border-top:1px solid var(--border-color)}.note-row:hover .note-title{text-underline-offset:3px;text-decoration:underline}.note-date{opacity:.45;letter-spacing:.03em;flex-shrink:0;font-size:.8rem}.note-title{flex:1}.note-tag{opacity:.45;letter-spacing:.05em;flex-shrink:0;font-size:.75rem}.page-section{margin-bottom:2rem}.project-card{border:1px solid var(--text-color);flex-direction:column;gap:.5rem;margin-top:1.25rem;padding:1.25rem 1.5rem;display:flex}.project-header{justify-content:space-between;align-items:baseline;display:flex}.project-name{font-weight:700}.project-year{opacity:.5;font-size:.8rem}.project-desc{opacity:.8;margin:0}.project-tags{flex-wrap:wrap;gap:.5rem;display:flex}.tag{border:1px solid var(--text-color);opacity:.6;padding:.1rem .4rem;font-size:.75rem}.project-link{color:var(--text-color);margin-top:.25rem;font-size:.85rem;text-decoration:none}.project-link:hover{text-decoration:underline}@media (width<=600px){h1{font-size:2rem}.avatar{width:70px;height:70px}nav{margin-bottom:1.5rem}.nav-links{gap:1.25rem}.page-wrapper{padding:1rem}nav{flex-direction:row}}@media (width<=400px){nav{flex-direction:column;align-items:flex-start;gap:1rem}}
