@font-face{font-family:GeistPixelGrid;src:url(/fonts/GeistPixel-Grid.woff2)format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:GeistPixelSquare;src:url(/fonts/GeistPixel-Square.woff2)format("woff2");font-weight:400;font-style:normal;font-display:swap}:root{--bg-primary:#fff;--bg-secondary:#f8f8f8;--bg-card:#fff;--text-primary:#1a1a1a;--text-secondary:#666;--text-muted:#999;--border-color:#e5e5e5;--border-light:#f0f0f0;--accent-color:#3b82f6;--nav-bg:#ffffffd9;--pattern-color:#0000000d;--stripe-color:#00000008;--tag-bg:transparent;--tag-border:#d4d4d4;--hover-bg:#f5f5f5;--shadow-card:0 1px 3px #0000000f;--section-heading:#1a1a1a;--verified-color:#3b82f6;--link-hover:#111;--code-icon-bg:#f0f0f0}[data-theme=dark]{--bg-primary:#040404;--bg-secondary:#0a0a0a;--bg-card:#0e0e0e;--text-primary:#e5e5e5;--text-secondary:#a0a0a0;--text-muted:#666;--border-color:#1e1e1e;--border-light:#151515;--accent-color:#6090e0;--nav-bg:#040404e6;--pattern-color:#ffffff08;--stripe-color:#ffffff05;--tag-bg:transparent;--tag-border:#333;--hover-bg:#1a1a1a;--shadow-card:0 1px 3px #0000004d;--section-heading:#e5e5e5;--verified-color:#6090e0;--link-hover:#fff;--code-icon-bg:#1a1a1a}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.7;transition:background-color .3s,color .3s;overflow-x:hidden}a{color:inherit;text-decoration:none;transition:color .2s,opacity .2s}a:hover{color:var(--link-hover)}img{max-width:100%;display:block}button{cursor:pointer;background:0 0;border:none;font-family:inherit}.app{min-height:100vh}.main-content{border-left:1px solid var(--border-color);border-right:1px solid var(--border-color);max-width:680px;min-height:100vh;margin:0 auto;padding:56px 0 0;position:relative}.home-page>:not(.dot-grid-block):not(.stripe-line),.projects-page>:not(.dot-grid-block):not(.stripe-line){padding-left:24px;padding-right:24px}.dot-grid-block{background-image:radial-gradient(circle, var(--pattern-color) 1px, transparent 1px);background-position:50%;background-size:10px 10px;width:100%;min-height:110px}.stripe-line{border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);width:100%;height:24px;position:relative}.stripe-line:before{content:"";background-image:repeating-linear-gradient(315deg, var(--stripe-color) 0, var(--stripe-color) 1px, transparent 1px, transparent 50%);z-index:-1;background-size:10px 10px;width:200vw;height:100%;position:absolute;top:0;left:-50vw}.corner-plus{z-index:10;pointer-events:none;width:12px;height:12px;position:absolute;transform:translate(-50%,-50%)}.corner-plus:before,.corner-plus:after{content:"";background:var(--text-muted);position:absolute}.corner-plus:before{width:12px;height:1px;top:5px;left:0}.corner-plus:after{width:1px;height:12px;top:0;left:5px}.top-left-plus{top:0;left:0}.top-right-plus{top:0;left:100%}.bottom-left-plus{top:100%;left:0}.bottom-right-plus{top:100%;left:100%}.navbar{background:var(--nav-bg);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color);z-index:1000;align-items:center;height:56px;padding:0 24px;transition:background-color .3s;display:flex;position:fixed;top:0;left:0;right:0}.navbar-logo{letter-spacing:-.02em;color:var(--text-primary);margin-right:auto;font-size:1.3rem;font-weight:700}.navbar-links{align-items:center;gap:4px;margin-right:16px;display:flex}.navbar-link{color:var(--text-secondary);white-space:nowrap;border-radius:8px;padding:6px 14px;font-size:.9rem;transition:all .2s}.navbar-link:hover,.navbar-link.active{color:var(--text-primary);background:var(--hover-bg)}.navbar-more-wrapper{position:relative}.navbar-more-btn{cursor:pointer;color:var(--text-secondary);border-radius:8px;align-items:center;gap:4px;padding:6px 14px;font-size:.9rem;transition:all .2s;display:flex}.navbar-more-btn:hover{color:var(--text-primary);background:var(--hover-bg)}.navbar-dropdown{background:var(--bg-card);border:1px solid var(--border-color);z-index:1001;border-radius:10px;min-width:160px;padding:6px;animation:.15s dropdownFade;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 8px 24px #0000001f}@keyframes dropdownFade{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.dropdown-link{color:var(--text-secondary);border-radius:6px;padding:8px 12px;font-size:.88rem;transition:all .15s;display:block}.dropdown-link:hover{background:var(--hover-bg);color:var(--text-primary)}.navbar-actions{align-items:center;gap:8px;display:flex}.nav-btn{color:var(--text-secondary);border:1px solid var(--border-color);background:var(--bg-card);cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:6px 14px;font-size:.85rem;transition:all .2s;display:flex}.nav-btn:hover{background:var(--hover-bg);color:var(--text-primary)}.search-shortcut{align-items:center;gap:3px;display:flex}.search-shortcut kbd{color:var(--text-muted);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;padding:1px 5px;font-family:inherit;font-size:.72rem;line-height:1.4;display:inline-block}.nav-icon-btn{width:36px;height:36px;color:var(--text-secondary);border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.nav-icon-btn:hover{background:var(--hover-bg);color:var(--text-primary)}.nav-icon-btn.mobile-only{display:none}.mobile-menu-overlay{z-index:999;opacity:0;pointer-events:none;background:#0006;transition:opacity .3s;position:fixed;inset:56px 0 0}.mobile-menu-overlay.open{opacity:1;pointer-events:all}.mobile-menu{background:var(--bg-card);border-left:1px solid var(--border-color);border-bottom:1px solid var(--border-color);z-index:1000;border-bottom-left-radius:12px;width:240px;padding:12px;transition:transform .3s;position:fixed;top:56px;right:0;transform:translate(100%)}.mobile-menu.open{transform:translate(0)}.mobile-menu-link{color:var(--text-secondary);border-radius:8px;padding:10px 14px;font-family:GeistPixelSquare,monospace;font-size:14px;transition:all .2s;display:block}.mobile-menu-link:hover,.mobile-menu-link.active{background:var(--hover-bg);color:var(--text-primary)}.hero-section{margin-bottom:0}.hero-card{border:1px solid var(--border-color);background:var(--bg-card);border-radius:16px;position:relative;overflow:hidden}.hero-card-dot-bg{background-image:radial-gradient(circle, var(--pattern-color) 1px, transparent 1px);background-size:16px 16px;min-height:80px;padding:32px 32px 0;position:relative}.hero-card-content{align-items:flex-start;gap:20px;padding:0 32px 28px;display:flex;position:relative}.hero-avatar-container{flex-shrink:0;margin-top:-30px;position:relative}.hero-avatar{object-fit:cover;background:var(--bg-secondary);border:2px solid #a29e9e;border-radius:14px;width:120px;height:120px;transition:all .3s}.hero-avatar:hover{animation:.3s glitch}@keyframes glitch{0%{transform:translate(0)}20%{transform:translate(-3px,3px)}40%{transform:translate(3px,-3px)}60%{transform:translate(-2px,-2px)}80%{transform:translate(2px,2px)}to{transform:translate(0)}}.hero-info{flex:1;margin-top:-20px;padding-top:0}.hero-meta-top{justify-content:space-between;align-items:center;display:flex;position:absolute;top:10px;left:32px;right:32px}.hero-idle-badge{color:var(--text-muted);align-items:center;gap:4px;font-size:.75rem;display:flex}.hero-view-count{color:var(--text-muted);align-items:center;gap:4px;font-size:.8rem;display:flex}.hero-name{align-items:center;gap:6px;margin-top:10px;font-family:GeistPixelGrid,monospace;font-size:2rem;font-weight:900;line-height:1.3;display:flex}.verified-badge{color:var(--verified-color);flex-shrink:0;width:20px;height:20px}.hero-status{color:var(--text-muted);align-items:center;gap:6px;margin-top:4px;font-size:.85rem;display:flex}.status-dot{background-color:#1e1d1b;border-radius:50%;width:8px;height:8px}.hero-slider{height:24px;margin-top:4px;margin-bottom:2px;margin-left:5px;position:relative;overflow:hidden}.slider-text{color:var(--text-secondary);letter-spacing:.01em;white-space:nowrap;font-family:GeistPixelSquare,monospace;font-size:14px;position:absolute;top:0;left:0}.slider-idle{opacity:1;transform:translateY(0)}.slider-enter{animation:.35s ease-out forwards slideIn}.slider-exit{animation:.35s ease-in forwards slideOut}@keyframes slideIn{0%{opacity:0;filter:blur(4px);transform:translateY(-100%)}to{opacity:1;filter:blur();transform:translateY(0)}}@keyframes slideOut{0%{opacity:1;filter:blur();transform:translateY(0)}to{opacity:0;filter:blur(4px);transform:translateY(100%)}}.section-heading{color:var(--section-heading);margin-bottom:14px;font-family:GeistPixelGrid,monospace;font-size:2.2rem;font-style:normal;font-weight:600;line-height:1.2}.about-section{margin-bottom:0;padding:20px 0}.about-list{padding:0;list-style:none}.about-list li{color:var(--text-secondary);margin-bottom:18px;padding-left:20px;font-size:.95rem;line-height:1.75;position:relative}.about-list li:before{content:"•";color:var(--text-muted);font-size:1.1rem;position:absolute;top:0;left:0}.connect-section{margin-bottom:0;padding:12px 0}.connect-links{flex-wrap:wrap;gap:10px;display:flex}.connect-pill{border:1px solid var(--border-color);color:var(--text-secondary);background:var(--bg-card);border-radius:10px;align-items:center;gap:8px;padding:8px 18px;font-size:.88rem;text-decoration:none;transition:all .2s;display:inline-flex}.connect-pill:hover{background:var(--hover-bg);color:var(--text-primary);border-color:var(--text-muted);transform:translateY(-1px)}.connect-pill:active{transform:scale(.98)}.connect-pill svg{flex-shrink:0;width:16px;height:16px}.github-section{margin-bottom:0;padding:12px 0}.github-graph{border:1px solid var(--border-color);background:var(--bg-card);border-radius:12px;padding:16px;overflow:hidden}.github-graph img{border-radius:8px;width:100%;height:auto}.experience-section{margin-bottom:0;padding:12px 0}.experience-item{border-bottom:1px solid var(--border-light);margin-bottom:24px;padding-bottom:24px}.experience-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.exp-company{align-items:center;gap:8px;margin-bottom:8px;display:flex}.exp-dot{background:var(--text-muted);border-radius:50%;flex-shrink:0;width:8px;height:8px}.exp-company-name{color:var(--text-primary);font-size:1.05rem;font-weight:600}.exp-role-row{align-items:center;gap:10px;margin-bottom:6px;margin-left:16px;display:flex}.exp-code-icon{background:var(--code-icon-bg);width:32px;height:32px;color:var(--text-secondary);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.exp-role-info{flex:1}.exp-role-title{color:var(--text-primary);font-size:.95rem;font-weight:600}.exp-role-meta{color:var(--text-muted);align-items:center;gap:8px;font-size:.8rem;display:flex}.exp-role-meta span:not(:last-child):after{content:"|";color:var(--text-muted);margin-left:8px}.exp-chevron{color:var(--text-muted);flex-shrink:0}.exp-tags{flex-wrap:wrap;gap:8px;margin-top:12px;margin-left:16px;display:flex}.exp-tag{border:1px solid var(--tag-border);color:var(--text-secondary);background:var(--tag-bg);border-radius:6px;padding:4px 12px;font-size:.78rem}.education-section{margin-bottom:0;padding:12px 0}.education-item{border-bottom:1px solid var(--border-light);margin-bottom:24px;padding-bottom:24px}.education-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.edu-school{align-items:center;gap:8px;margin-bottom:8px;display:flex}.edu-school-name{color:var(--text-primary);font-size:1.05rem;font-weight:600}.edu-degree-row{align-items:center;gap:10px;margin-left:16px;display:flex}.edu-icon{background:var(--code-icon-bg);width:32px;height:32px;color:var(--text-secondary);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.edu-degree-info{flex:1}.edu-degree-title{color:var(--text-primary);font-size:.95rem}.edu-degree-title strong{font-weight:600}.edu-date{color:var(--text-muted);margin-top:2px;font-size:.8rem}.projects-page{padding-bottom:60px}.projects-intro{color:var(--text-secondary);margin-bottom:36px;font-size:.95rem;line-height:1.75}.project-card{border:1px solid var(--border-color);background:var(--bg-card);border-radius:16px;margin-bottom:32px;transition:all .3s;overflow:hidden}.project-card:hover{border-color:var(--text-muted);box-shadow:var(--shadow-card)}.project-image-container{aspect-ratio:16/10;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);width:100%;overflow:hidden}.project-image-container img{object-fit:cover;width:100%;height:100%;transition:transform .4s}.project-card:hover .project-image-container img{transform:scale(1.02)}.project-card-body{padding:24px}.project-title-row{justify-content:space-between;align-items:baseline;margin-bottom:10px;display:flex}.project-title{color:var(--text-primary);font-size:1.2rem;font-weight:700}.project-date{color:var(--text-muted);font-size:.82rem}.project-description{color:var(--text-secondary);margin-bottom:16px;font-size:.92rem;line-height:1.7}.project-tags{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.project-tag{border:1px solid var(--tag-border);color:var(--text-secondary);border-radius:6px;padding:4px 12px;font-size:.78rem}.project-links{border-top:1px solid var(--border-color);display:flex}.project-link{color:var(--text-secondary);flex:1;justify-content:center;align-items:center;gap:8px;padding:14px;font-size:.88rem;transition:all .2s;display:flex}.project-link:hover{background:var(--hover-bg);color:var(--text-primary)}.project-link:first-child{border-right:1px solid var(--border-color)}.project-link svg{width:16px;height:16px}.quote-section{text-align:center;border-top:1px solid var(--border-color);padding:60px 0 40px}.quote-marks{color:var(--text-muted);opacity:.35;-webkit-user-select:none;user-select:none;margin-bottom:8px;font-family:Playfair Display,Georgia,serif;font-size:4rem;line-height:1}.quote-text{color:var(--text-secondary);max-width:520px;margin:0 auto 20px;font-family:Playfair Display,Georgia,serif;font-size:1.15rem;font-style:italic;line-height:1.7}.quote-author-divider{justify-content:center;align-items:center;gap:16px;display:flex}.quote-line{background:var(--border-color);width:40px;height:1px}.quote-author{letter-spacing:.1em;color:var(--text-muted);text-transform:uppercase;font-size:.82rem;font-weight:600}.footer{border-top:1px solid var(--border-color);padding:30px 0 20px}.footer-content{justify-content:space-between;align-items:flex-end;display:flex}.footer-left{flex-direction:column;gap:2px;display:flex}.footer-copyright,.footer-tagline{color:var(--text-muted);font-family:GeistPixelSquare,monospace;font-size:.82rem}.footer-right{align-items:flex-end;display:flex}@media (width<=768px){.main-content{padding:72px 20px 50px}.hero-card-dot-bg{padding:24px 20px 0}.hero-card-content{gap:16px;padding:0 20px 24px}.hero-avatar{width:100px;height:100px}.hero-name{font-size:1.3rem}.section-heading{font-size:1.8rem}.connect-links{gap:8px}.connect-pill{padding:6px 14px;font-size:.82rem}.project-card-body{padding:20px}.nav-btn.search-btn,.navbar-links{display:none}.nav-icon-btn.mobile-only{display:flex}}@media (width<=480px){.main-content{max-width:100%;padding:66px 16px 40px}.navbar{padding:0 16px}.hero-card-content{flex-direction:column;align-items:flex-start;padding:0 16px 20px}.hero-avatar-container{margin-top:-20px}.hero-avatar{width:80px;height:80px}.hero-info{width:100%;padding-top:0}.hero-name{font-size:1.2rem}.hero-meta-top{flex-wrap:wrap;gap:8px}.section-heading{font-size:1.5rem}.about-list li{font-size:.9rem}.connect-links{gap:6px}.connect-pill{padding:6px 12px;font-size:.8rem}.exp-role-row{flex-direction:column;align-items:flex-start;gap:6px}.exp-tags{margin-left:0}.project-title-row{flex-direction:column;gap:4px}.project-links{flex-direction:column}.project-link:first-child{border-right:none;border-bottom:1px solid var(--border-color)}.edu-degree-row{flex-direction:column;align-items:flex-start;gap:6px}}:not(.hero-avatar){transition-property:background-color,border-color,color;transition-duration:.2s;transition-timing-function:ease}.nav-icon-btn:active,.nav-btn:active,.connect-pill:active,.project-link:active,.mobile-menu-link:active{transition:transform .1s;transform:scale(.92)}.nav-icon-btn{position:relative;overflow:hidden}@keyframes ripple{0%{opacity:.5;transform:scale(0)}to{opacity:0;transform:scale(4)}}.spotify-section{margin-bottom:0;padding:12px 0}.spotify-widget{border:1px solid var(--border-color);background:var(--bg-card);border-radius:12px;align-items:center;gap:14px;padding:16px 20px;transition:all .3s;display:flex}.spotify-widget:hover{border-color:var(--text-muted)}.spotify-playing{cursor:pointer;border-color:#1db9544d;text-decoration:none}.spotify-playing:hover{border-color:#1db95499;box-shadow:0 0 20px #1db95414}.spotify-album-art{object-fit:cover;border-radius:6px;flex-shrink:0;width:44px;height:44px;animation:8s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spotify-status-dot.playing{background:#1db954;box-shadow:0 0 6px #1db95499}.spotify-bars.paused .bar{height:4px;animation:none}.spotify-track-text.marquee{animation:12s linear infinite marqueeScroll}@keyframes marqueeScroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.spotify-icon{flex-shrink:0;align-items:center;display:flex}.spotify-info{flex:1;min-width:0}.spotify-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);align-items:center;gap:6px;margin-bottom:2px;font-size:.75rem;font-weight:600;display:flex}.spotify-status-dot{background:#1db954;border-radius:50%;width:6px;height:6px;animation:2s infinite spotifyPulse}@keyframes spotifyPulse{0%,to{opacity:1}50%{opacity:.4}}.spotify-track{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;overflow:hidden}.spotify-track-text{display:inline-block}.spotify-bars{flex-shrink:0;align-items:flex-end;gap:3px;height:20px;display:flex}.bar{background:#1db954;border-radius:2px;width:3px;animation:1.5s ease-in-out infinite equalize}.bar-1{height:8px;animation-delay:0s}.bar-2{height:14px;animation-delay:.2s}.bar-3{height:6px;animation-delay:.4s}.bar-4{height:10px;animation-delay:.6s}@keyframes equalize{0%,to{height:4px}25%{height:16px}50%{height:8px}75%{height:20px}}.sleeping-cat-container{width:80px;height:50px;margin-bottom:20px;display:inline-block;position:relative}.zzz-container{position:absolute;top:-10px;right:45px}.zzz{color:var(--text-muted);opacity:0;font-family:Inter,sans-serif;font-weight:700;animation:3s ease-in-out infinite floatZzz;position:absolute}.zzz-1{font-size:.6rem;animation-delay:0s;top:0;right:0}.zzz-2{font-size:.75rem;animation-delay:1s;top:-8px;right:8px}.zzz-3{font-size:.9rem;animation-delay:2s;top:-16px;right:16px}@keyframes floatZzz{0%{opacity:0;transform:translate(0)scale(.5)}20%{opacity:.8}to{opacity:0;transform:translate(-12px,-28px)scale(1.2)}}.pixel-cat{position:absolute;bottom:0;left:50%;transform:translate(-50%)}.cat-ear{background:var(--text-muted);clip-path:polygon(50% 0%,0% 100%,100% 100%);width:8px;height:10px;position:absolute}.cat-ear-left{top:-8px;left:8px}.cat-ear-right{top:-8px;right:8px}.cat-head{background:var(--text-muted);border-radius:10px 10px 6px 6px;width:32px;height:18px;position:relative}.cat-eye{background:var(--bg-primary);border-radius:0 0 6px 6px;width:6px;height:2px;position:absolute;top:8px}.cat-eye-left{left:6px}.cat-eye-right{right:6px}.cat-body{background:var(--text-muted);border-radius:20px 20px 8px 8px;width:42px;height:16px;margin-top:-4px;margin-left:-5px;animation:3s ease-in-out infinite catBreathe;position:relative}@keyframes catBreathe{0%,to{transform:scaleY(1)}50%{transform:scaleY(1.06)}}.cat-tail{background:var(--text-muted);transform-origin:0;border-radius:4px;width:20px;height:6px;animation:4s ease-in-out infinite tailWag;position:absolute;bottom:2px;right:-14px}@keyframes tailWag{0%,to{transform:rotate(-5deg)}50%{transform:rotate(10deg)}}
