:root{--background:#000;--background-soft:#050505;--surface:#0a0a0a;--surface-elevated:#111;--surface-muted:#161616;--border-subtle:#ffffff14;--border-default:#ffffff1f;--border-strong:#ffffff2e;--text-primary:#fff;--text-secondary:#a1a1aa;--text-muted:#71717a;--text-faint:#3f3f46;--accent-blue:#60a5fa;--accent-purple:#a78bfa;--accent-cyan:#22d3ee;--accent-green:#34d399;--gradient-ring:linear-gradient(90deg, #22d3ee, #a78bfa, #f472b6, #facc15, #22d3ee);--gradient-surface:linear-gradient(180deg, #ffffff09, #ffffff03);--shadow-soft:0 24px 70px #00000085;--radius-card:16px;--container:1200px;--section-gap:120px;--ease:cubic-bezier(.16, 1, .3, 1);--font-display:"Instrument Serif", Georgia, serif;--font-sans:"Geist", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"JetBrains Mono", "SFMono-Regular", Consolas, monospace}*{box-sizing:border-box}html{scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent;overflow:hidden auto}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);background-clip:padding-box;border:2px solid #0000;border-radius:999px}body{background:linear-gradient(180deg, #ffffff09, transparent 24rem), repeating-linear-gradient(90deg, #ffffff05 0 1px, transparent 1px 120px), var(--background);color:var(--text-primary);font-family:var(--font-sans);margin:0;font-size:16px;line-height:1.6;overflow:hidden clip}body:before{content:"";z-index:-1;opacity:.6;pointer-events:none;background:linear-gradient(115deg,#0000 0 48%,#ffffff09 49%,#0000 58%),linear-gradient(#0000 0%,#ffffff05 100%);position:fixed;inset:0}body.nav-open,body.contact-modal-open{overflow:hidden}body.contact-modal-open:after{content:"";z-index:40;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#00000094;position:fixed;inset:0}img{max-width:100%;display:block}[hidden]{display:none!important}a{color:inherit;text-decoration:none}button{font:inherit;color:inherit}h1,h2,h3,p{margin-top:0}h1{max-width:760px;font-family:var(--font-display);letter-spacing:0;margin-bottom:22px;font-size:104px;font-weight:400;line-height:.98}.hero-title{gap:2px;margin-left:auto;margin-right:auto;padding:.04em 0 .08em;display:grid}.hero-title span{background:linear-gradient(#fff 0%,#f3f4f6 48%,#9ca3af 100%);color:#0000;-webkit-background-clip:text;background-clip:text;display:block}.title-mobile{display:none!important}h2{background:linear-gradient(#fff 0%,#f4f4f5 45%,#a1a1aa 100%);color:#0000;font-family:var(--font-sans);letter-spacing:0;-webkit-background-clip:text;background-clip:text;margin-bottom:0;font-size:58px;font-weight:400;line-height:1.12}h3{color:var(--text-primary);letter-spacing:0;margin-bottom:10px;font-size:20px;font-weight:600;line-height:1.25}.site-header{z-index:20;pointer-events:none;width:100%;padding:8px 12px;position:fixed;top:0;left:0;right:0}.site-header-inner{width:min(100%, var(--container));pointer-events:auto;transition:width .35s var(--ease), max-width .35s var(--ease), padding .35s var(--ease), border-color .35s var(--ease), background .35s var(--ease), box-shadow .35s var(--ease), backdrop-filter .35s var(--ease);background:0 0;border:1px solid #0000;border-radius:20px;justify-content:space-between;align-items:center;gap:24px;margin:0 auto;padding:14px 20px;display:flex;position:relative}.site-header.is-scrolled .site-header-inner,body.nav-open .site-header-inner{border-color:var(--border-default);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#00000094;width:min(100%,900px);padding:10px 14px;box-shadow:0 18px 60px #0006}.brand{min-width:0;color:var(--text-primary);font-family:var(--font-mono);letter-spacing:0;align-items:center;font-size:14px;font-weight:600;display:inline-flex}.brand-text{white-space:nowrap;position:relative}.brand-text:before{content:"/";background:var(--gradient-ring);color:#0000;background-size:220% 100%;-webkit-background-clip:text;background-clip:text;margin-right:9px;font-size:16px;animation:5.5s linear infinite gradient-flow}.site-nav{align-items:center;gap:2px;display:flex;position:absolute;left:50%;transform:translate(-50%)}.site-nav a{color:var(--text-secondary);transition:background .35s var(--ease), color .35s var(--ease);border-radius:999px;padding:8px 12px;font-size:14px;font-weight:600}.site-nav a:hover,.site-nav a.is-active{color:var(--text-primary);background:#ffffff0f}.mobile-nav-actions{display:none}.header-actions{align-items:center;gap:8px;display:flex;position:relative}.header-link,.header-cta{cursor:pointer;min-height:34px;transition:transform .35s var(--ease), border-color .35s var(--ease), background .35s var(--ease), color .35s var(--ease);border:0;border-radius:999px;justify-content:center;align-items:center;padding:0 13px;font-size:13px;font-weight:700;display:inline-flex}.header-link{color:var(--text-secondary)}.header-link:hover,.header-cta:hover{color:var(--text-primary);transform:translateY(-1px)}.header-cta{border:1px solid var(--text-primary);background:var(--text-primary);color:var(--background);padding:0 16px;box-shadow:0 0 34px #ffffff14}.header-cta:hover,.header-cta[aria-expanded=true]{color:var(--background);box-shadow:0 0 44px #ffffff29}.site-header.is-scrolled .header-link,.site-header.is-scrolled .header-cta{min-height:32px}.inline-icon,.contact-popover svg{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2px}.inline-icon{width:15px;height:15px;margin-left:7px}.contact-popover{z-index:50;border:1px solid var(--border-default);opacity:0;transform-origin:50%;visibility:hidden;pointer-events:none;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);width:min(392px,100vw - 24px);transition:opacity .25s var(--ease), transform .25s var(--ease), visibility .25s var(--ease);background:linear-gradient(#ffffff07,#ffffff02),#070707f7;border-radius:10px;padding:22px;position:fixed;top:50%;left:50%;right:auto;transform:translate(-50%,-46%)scale(.98);box-shadow:0 30px 90px #0000009e}.contact-popover.is-open{opacity:1;visibility:visible;pointer-events:auto;transform:translate(-50%,-50%)scale(1)}.contact-close{width:30px;height:30px;color:var(--text-secondary);cursor:pointer;background:0 0;border:0;border-radius:50%;place-items:center;display:grid;position:absolute;top:18px;right:18px}.contact-close:hover{color:var(--text-primary)}.contact-close svg,.contact-email-row svg{width:18px;height:18px}.contact-popover h2{color:var(--text-primary);font-family:var(--font-sans);background:0 0;margin:0 36px 4px 0;font-size:18px;font-weight:700;line-height:1.3}.contact-popover p{color:var(--text-secondary);margin:0 0 22px;font-size:15px;line-height:1.45}.contact-email-row{border:1px solid var(--border-subtle);background:#ffffff06;border-radius:8px;grid-template-columns:minmax(0,1fr) 34px 34px;align-items:center;gap:8px;min-height:56px;margin-bottom:16px;padding:8px 10px;display:grid;position:relative}.contact-email-row a:first-child{min-width:0;color:var(--text-secondary);align-items:center;gap:12px;font-weight:600;display:flex}.contact-email-row a:first-child span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.contact-email-row button,.contact-email-row>a:not(:first-child){width:34px;height:34px;color:var(--text-secondary);cursor:pointer;background:0 0;border:0;border-radius:9px;place-items:center;display:grid;position:relative}.contact-email-row button:hover,.contact-email-row>a:not(:first-child):hover,.contact-card:hover{color:var(--text-primary)}.contact-email-row button.is-copied{color:var(--accent-green);background:#34d3991a}.contact-email-row button .check-icon{opacity:0;pointer-events:none;transition:opacity .22s var(--ease), transform .22s var(--ease);position:absolute;transform:scale(.7)}.contact-email-row button .copy-icon{transition:opacity .18s var(--ease), transform .18s var(--ease)}.contact-email-row button.is-copied .copy-icon{opacity:0;transform:scale(.7)}.contact-email-row button.is-copied .check-icon{opacity:1;transform:scale(1)}.contact-icon-red{color:#fb7185}.contact-card-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.contact-card{border:1px solid var(--border-subtle);min-height:76px;color:var(--text-secondary);text-align:center;transition:transform .25s var(--ease), border-color .25s var(--ease), background .25s var(--ease), color .25s var(--ease);background:#ffffff06;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:11px;font-size:13px;font-weight:700;display:flex}.contact-icon-chip{width:24px;height:24px;color:var(--text-primary);transition:color .25s var(--ease);background:0 0;border:0;border-radius:0;place-items:center;display:grid}.contact-icon-chip svg{width:22px;height:22px}.contact-icon-chip .brand-svg{fill:currentColor;stroke:none}.contact-icon-whatsapp{color:#34d399}.contact-icon-linkedin{color:#60a5fa}.contact-icon-github{color:#a78bfa}.contact-card:hover{border-color:var(--border-strong);background:#ffffff0a;transform:translateY(-2px)}.contact-card:hover .contact-icon-whatsapp{color:#6ee7b7}.contact-card:hover .contact-icon-linkedin{color:#93c5fd}.contact-card:hover .contact-icon-github{color:#c4b5fd}.nav-toggle{border:1px solid var(--border-default);cursor:pointer;background:#ffffff0f;border-radius:50%;width:42px;height:42px;display:none}.nav-toggle span{background:var(--text-primary);width:17px;height:2px;transition:transform .25s var(--ease), opacity .25s var(--ease);border-radius:999px;margin:4px auto;display:block}.nav-toggle[aria-expanded=true] span:first-child{transform:translateY(3px)rotate(45deg)}.nav-toggle[aria-expanded=true] span:last-child{transform:translateY(-3px)rotate(-45deg)}.section-shell{width:calc(100% - 40px);max-width:var(--container);margin:0 auto}section[id]{scroll-margin-top:92px}.hero{isolation:isolate;text-align:center;grid-template-rows:minmax(0,1fr) auto;grid-template-columns:minmax(0,1fr);place-items:center;row-gap:82px;min-height:100vh;padding:150px 0 120px;display:grid;position:relative}.hero-ambient{z-index:-1;opacity:.5;pointer-events:none;width:min(620px,52vw);height:100%;position:absolute;inset:0 auto auto 0;overflow:visible}.hero-ambient span{width:22rem;height:78rem;animation:ambient-drift 12s var(--ease) infinite alternate;background:radial-gradient(68% 68% at 55% 32%,#ffffff17 0%,#ffffff06 52%,#fff0 82%);border-radius:999px;position:absolute;top:-360px;left:-180px;transform:rotate(-45deg)}.hero-ambient span:nth-child(2){opacity:.64;width:9rem;animation-delay:.8s;top:-280px;left:-44px}.hero-ambient span:nth-child(3){opacity:.34;width:12rem;animation-delay:1.5s;top:-420px;left:116px}.hero-content{z-index:1;grid-area:1/1;justify-self:center;width:min(100%,1040px);min-width:0;max-width:1040px;position:relative}.hero-animate{opacity:0;filter:blur(12px);animation:hero-reveal 1.5s var(--ease) forwards;will-change:opacity, transform, filter;transform:translateY(20px)}.hero-animate-1{animation-delay:.12s}.hero-animate-2{animation-delay:.22s}.hero-animate-3{animation-delay:.34s}.hero-animate-4{animation-delay:.46s}.hero-animate-5{animation-delay:.58s}.hero-animate-6{animation-delay:.7s}.scroll-reveal{opacity:0;filter:blur(12px);transition:opacity 1.1s var(--ease), transform 1.1s var(--ease), filter 1.1s var(--ease);transition-delay:var(--reveal-delay,0s);will-change:opacity, transform, filter;transform:translateY(20px)}.scroll-reveal.is-visible{opacity:1;filter:blur();transform:translateY(0)}@keyframes gradient-flow{0%{background-position:0%}to{background-position:220%}}@keyframes hero-reveal{0%{opacity:0;filter:blur(12px);transform:translateY(20px)}to{opacity:1;filter:blur();transform:translateY(0)}}@keyframes ambient-drift{0%{transform:translate(0,0)rotate(-45deg)}to{transform:translate(22px,18px)rotate(-45deg)}}.eyebrow{color:var(--text-muted);letter-spacing:0;text-transform:none;margin:0 0 28px;padding:0;font-size:13px;font-weight:600}.hero-eyebrow{background:linear-gradient(var(--background), var(--background)) padding-box, var(--gradient-ring) border-box;width:fit-content;color:var(--text-primary);background-size:auto,220% 100%;border:1px solid #0000;border-radius:999px;align-items:center;gap:8px;margin-left:auto;margin-right:auto;padding:5px 12px 5px 10px;font-size:12px;line-height:1.2;animation:6s linear infinite gradient-flow;display:inline-flex}.hero-eyebrow:before{content:"";background:var(--gradient-ring);background-size:220% 100%;border-radius:50%;flex:none;width:5px;height:5px;animation:6s linear infinite gradient-flow;box-shadow:0 0 14px #22d3ee6b}.hero-eyebrow.hero-animate{animation:hero-reveal 1.5s var(--ease) forwards, gradient-flow 6s linear infinite}.hero-eyebrow.hero-animate-1{animation-delay:.12s,0s}.hero-copy{max-width:min(680px,100%);color:var(--text-secondary);overflow-wrap:break-word;margin:0 auto 28px;font-size:19px;line-height:1.55}.hero-copy strong{color:var(--text-primary);font-weight:700}.hero-meta{justify-content:center;align-items:center;gap:10px;display:flex}.hero-socials{align-items:center;gap:10px;display:flex}.hero-socials a{border:1px solid var(--border-default);width:46px;height:46px;color:var(--social-color,var(--text-secondary));transition:transform .3s var(--ease), border-color .3s var(--ease), background .3s var(--ease), color .3s var(--ease), box-shadow .3s var(--ease), opacity .3s var(--ease);background:#ffffff06;border-radius:50%;place-items:center;display:grid}.hero-socials a:hover{border-color:var(--border-strong);color:var(--text-primary);opacity:1;background:#ffffff0e;transform:translateY(-2px);box-shadow:0 0 34px #ffffff14}.hero-socials svg{width:22px;height:22px}.hero-socials .brand-svg{fill:currentColor;stroke:none}.hero-socials .line-svg{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2px}.hero-stack-marquee{z-index:1;width:100%;min-width:0;position:relative}.hero-stack-strip{grid-area:2/1/auto/-1;place-self:end center;width:min(100%,1120px);padding:4px 0 0}.hero-stack-marquee p{color:#ffffffb8;text-align:center;margin:0 0 12px;font-size:15px;font-weight:600}.hero-stack-marquee strong{color:#fff;font-weight:700}.stack-marquee{align-items:center;width:100%;padding:9px 0;display:flex;position:relative;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#0000,#000 8% 92%,#0000);mask-image:linear-gradient(90deg,#0000,#000 8% 92%,#0000)}.stack-marquee-track{flex:none;align-items:center;gap:48px;width:max-content;padding-right:48px;animation:54s linear infinite stack-marquee;display:inline-flex}.stack-marquee:hover .stack-marquee-track{animation-play-state:paused}.stack-logo-item{color:#ffffffe6;white-space:nowrap;align-items:center;gap:11px;font-size:18px;font-weight:700;line-height:1;display:inline-flex}.stack-logo-item svg{flex:none;width:27px;height:27px}.stack-logo-item img{object-fit:contain;flex:none;width:27px;height:27px}.stack-logo-item svg,.stack-logo-item path,.stack-logo-item circle,.stack-logo-item ellipse{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.8px}@keyframes stack-marquee{0%{transform:translate(0)}to{transform:translate(-100%)}}.hero-actions,.contact-actions,.project-links{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.button{cursor:pointer;min-height:46px;transition:transform .35s var(--ease), border-color .35s var(--ease), background .35s var(--ease), color .35s var(--ease), box-shadow .35s var(--ease);border-radius:999px;justify-content:center;align-items:center;padding:0 20px;font-size:15px;font-weight:700;display:inline-flex}.button:hover{transform:translateY(-1px)}.button-primary{border:1px solid var(--text-primary);background:var(--text-primary);color:var(--background);box-shadow:0 0 34px #ffffff14}.button-primary:hover{box-shadow:0 0 48px #ffffff29}.button-secondary{border:1px solid var(--border-default);color:var(--text-secondary);background:#ffffff06}.button-secondary:hover{border-color:var(--border-strong);color:var(--text-primary)}.hero-highlights{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin:38px 0 0;padding:0;list-style:none;display:grid}.hero-highlights li,.project-card,.stack-card,.education-list article{border:1px solid var(--border-subtle);border-radius:var(--radius-card);background:var(--gradient-surface);box-shadow:var(--shadow-soft)}.hero-highlights li{min-height:96px;padding:18px}.hero-highlights strong,.hero-highlights span{display:block}.hero-highlights strong{color:var(--text-primary);margin-bottom:4px;font-size:15px}.hero-highlights span{color:var(--text-muted);font-size:14px;line-height:1.35}.hero-visual{z-index:1;grid-area:1/2;min-width:0;min-height:520px;position:relative}.hero-visual:before{content:"";border:1px solid var(--border-subtle);opacity:.28;width:64%;height:50%;position:absolute;inset:16% -8% auto auto;transform:rotate(10deg)}.code-window{border:1px solid var(--border-subtle);min-width:0;min-height:520px;box-shadow:var(--shadow-soft);background:linear-gradient(#ffffff0a,#ffffff02),#030303;border-radius:22px;position:relative;overflow:hidden}.code-window:before{content:"";opacity:.45;background-color:#0000;background-image:linear-gradient(#ffffff08 1px,#0000 1px),linear-gradient(90deg,#ffffff06 1px,#0000 1px);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:64px 64px;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;position:absolute;inset:0}.code-tabs,.code-footer{z-index:1;border-bottom:1px solid var(--border-subtle);color:var(--text-faint);font-family:var(--font-mono);align-items:center;gap:18px;padding:17px 20px;font-size:12px;display:flex;position:relative}.code-tabs span{white-space:nowrap}.code-tabs .is-active{color:var(--text-secondary)}.code-window pre{z-index:1;color:var(--text-secondary);font-family:var(--font-mono);white-space:pre-wrap;margin:0;padding:34px 24px 0;font-size:13px;line-height:2;position:relative}.code-window .line{display:block}.code-window .muted{color:var(--text-faint);margin-right:14px}.code-window .string{color:var(--accent-purple)}.code-window .accent{color:var(--accent-green)}.code-footer{border-top:1px solid var(--border-subtle);background:#0000006b;border-bottom:0;justify-content:space-between;position:absolute;bottom:0;left:0;right:0}.education-band,.stack-section{border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);background:#ffffff03}.education-grid{grid-template-columns:minmax(0,.72fr) minmax(0,1fr);gap:56px;padding:82px 0;display:grid}.project-card p,.stack-card p,.timeline-item p,.education-list p{color:var(--text-secondary)}.section-block,.stack-section{padding:var(--section-gap) 0}.section-heading{gap:16px;max-width:680px;margin-bottom:34px;display:grid}.section-description{max-width:680px;color:var(--text-secondary);margin:0;font-size:18px;line-height:1.5}.about-section{padding-top:0}.about-content{border:1px solid var(--border-subtle);border-radius:var(--radius-card);background:var(--gradient-surface);box-shadow:var(--shadow-soft);transition:transform .35s var(--ease), border-color .35s var(--ease), background .35s var(--ease);grid-template-columns:minmax(260px,.42fr) minmax(0,1fr);align-items:center;gap:44px;padding:30px;display:grid}.about-content:hover{border-color:var(--border-strong);background:linear-gradient(#ffffff0e,#ffffff04);transform:translateY(-3px)}.about-portrait-wrap{aspect-ratio:4/5;border:1px solid var(--border-default);border-radius:var(--radius-card);background:var(--surface-elevated);width:min(100%,300px);position:relative;overflow:hidden}.about-portrait-wrap:after{content:"";border-radius:inherit;pointer-events:none;background:linear-gradient(#0000 42%,#00000061);position:absolute;inset:0}.about-portrait{object-fit:cover;object-position:50% 28%;width:100%;height:100%}.about-details{min-width:0}.about-heading{max-width:680px;margin-bottom:34px}.about-text{gap:14px;max-width:720px;display:grid}.about-text p{color:var(--text-secondary);margin:0;font-size:18px;line-height:1.62}.about-text strong{color:var(--text-primary);font-weight:700}.about-resume{width:fit-content;margin-top:28px}.experience-section{padding-top:var(--section-gap)}.experience-timeline{gap:46px;padding:8px 0;display:grid;position:relative}.experience-timeline:before{content:"";background:linear-gradient(180deg, transparent, var(--border-default) 14%, var(--border-default) 86%, transparent);width:1px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.experience-card{grid-template-columns:minmax(0,1fr) 80px minmax(0,1fr);align-items:center;min-height:174px;display:grid;position:relative}.experience-card-inner{border:1px solid var(--border-subtle);border-radius:var(--radius-card);background:var(--gradient-surface);min-width:0;box-shadow:var(--shadow-soft);transition:transform .35s var(--ease), border-color .35s var(--ease), background .35s var(--ease);padding:28px 32px}.experience-card-inner:hover{border-color:var(--border-strong);background:linear-gradient(#ffffff0e,#ffffff04);transform:translateY(-3px)}.experience-card-left .experience-card-inner{grid-column:1}.experience-card-right .experience-card-inner{grid-column:3}.experience-node{z-index:2;border:1px solid var(--border-default);background:#000000d6;border-radius:50%;place-items:center;width:42px;height:42px;display:grid;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.experience-node:after{content:"";background:var(--gradient-ring);background-size:220% 100%;border-radius:50%;width:9px;height:9px;animation:5.5s linear infinite gradient-flow;box-shadow:0 0 18px #34d39973}.experience-card-top{justify-content:space-between;align-items:center;gap:14px;margin-bottom:10px;display:flex}.experience-company{overflow-wrap:anywhere;color:var(--text-muted);font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;font-size:13px;font-weight:700}.experience-status{min-height:26px;color:var(--text-primary);text-transform:uppercase;background:#34d39912;background:linear-gradient(var(--surface), var(--surface)) padding-box, var(--gradient-ring) border-box;background-size:auto,220% 100%;border:1px solid #34d39938;border-radius:999px;align-items:center;gap:6px;padding:0 10px;font-size:12px;font-weight:800;animation:5.5s linear infinite gradient-flow;display:inline-flex}.experience-status:before{content:"";background:var(--gradient-ring);background-size:220% 100%;border-radius:50%;width:6px;height:6px;animation:5.5s linear infinite gradient-flow}.experience-card h3{overflow-wrap:break-word;margin:0 0 5px;font-size:22px}.experience-location{color:var(--text-secondary);margin:0 0 14px;font-size:14px}.experience-card p:not(.experience-location){color:var(--text-secondary);margin:0 0 18px}.experience-badges{flex-wrap:wrap;gap:8px;display:flex}.experience-badges span{border:1px solid var(--border-subtle);min-height:30px;color:var(--text-primary);background:#ffffff05;border-radius:999px;align-items:center;padding:0 10px;font-size:12px;font-weight:700;display:inline-flex}.project-board{overflow-anchor:none;gap:0;display:grid}.project-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;display:grid}.project-card{min-height:330px;transition:transform .35s var(--ease), border-color .35s var(--ease), background .35s var(--ease), box-shadow .35s var(--ease);flex-direction:column;padding:30px;display:flex;position:relative;overflow:hidden}.project-card:before{content:"";opacity:0;transition:opacity .35s var(--ease);pointer-events:none;background:radial-gradient(circle at 20% 0,#ffffff14,#0000 36%);position:absolute;inset:0}.project-card:hover:before{opacity:1}.project-card:hover,.stack-card:hover,.education-list article:hover{border-color:var(--border-strong);background:linear-gradient(#ffffff0e,#ffffff04);transform:translateY(-3px)}.project-card.scroll-reveal{opacity:0;filter:blur(12px);transition:opacity 1.1s var(--ease), transform 1.1s var(--ease), filter 1.1s var(--ease), border-color .35s var(--ease), background .35s var(--ease), box-shadow .35s var(--ease);transition-delay:var(--reveal-delay,0s), var(--reveal-delay,0s), var(--reveal-delay,0s), 0s, 0s, 0s;transform:translateY(24px)scale(.985)}.project-card.scroll-reveal.is-visible{opacity:1;filter:blur();transform:translateY(0)scale(1)}.project-card.scroll-reveal.is-visible:hover{transform:translateY(-3px)scale(1)}.project-card-extra,.project-card-extra.scroll-reveal{opacity:0;filter:blur(12px);transition:opacity .72s var(--ease), transform .72s var(--ease), filter .72s var(--ease), border-color .35s var(--ease), background .35s var(--ease), box-shadow .35s var(--ease);transition-delay:var(--extra-delay,0s), var(--extra-delay,0s), var(--extra-delay,0s), 0s, 0s, 0s;transform:translateY(26px)scale(.982)}.project-card-extra.is-visible,.project-card-extra.scroll-reveal.is-visible{opacity:1;filter:blur();transform:translateY(0)scale(1)}.project-card-extra.is-visible:hover,.project-card-extra.scroll-reveal.is-visible:hover{transform:translateY(-3px)scale(1)}.project-card-extra.is-collapsing,.project-card-extra.scroll-reveal.is-collapsing{pointer-events:none}.project-extra-wrap{opacity:0;max-height:0;transition:max-height .76s var(--ease), margin-top .76s var(--ease), opacity .4s var(--ease);margin-top:0;overflow:hidden}.project-extra-wrap.is-expanded,.project-extra-wrap.is-collapsing{opacity:1;max-height:560px;margin-top:18px}.project-extra-wrap.is-collapsing{max-height:0;margin-top:0}.project-more-row{margin-top:24px}.project-card-live{border-color:#34d3993d}.project-card-featured{grid-row:span 2;min-height:430px}.project-card-featured h3{font-family:var(--font-sans);font-size:30px;font-weight:600}.project-card-header{justify-content:space-between;gap:12px;margin-bottom:26px;display:flex}.status-dot,.project-type,.education-list span,.timeline-date{color:var(--text-muted);letter-spacing:0;text-transform:uppercase;font-size:12px;font-weight:700}.status-dot{color:var(--accent-cyan)}.status-dot:not(.status-muted){background:var(--gradient-ring);color:#0000;background-size:220% 100%;-webkit-background-clip:text;background-clip:text;animation:5.5s linear infinite gradient-flow}.status-dot:before{content:"";vertical-align:1px;background:currentColor;border-radius:50%;width:6px;height:6px;margin-right:7px;display:inline-block;box-shadow:0 0 14px}.status-dot:not(.status-muted):before{background:var(--gradient-ring);background-size:220% 100%;animation:5.5s linear infinite gradient-flow;box-shadow:0 0 10px #22d3ee8c,0 0 18px #facc1547}.status-muted{color:var(--text-muted)}.status-blue{color:var(--accent-purple)}.status-green{color:var(--accent-green)}.tag-list{flex-wrap:wrap;gap:8px;margin-top:auto;padding-top:22px;display:flex}.tag-list span{border:1px solid var(--border-subtle);min-height:30px;color:var(--text-secondary);background:#ffffff06;border-radius:999px;align-items:center;padding:0 10px;font-size:13px;font-weight:600;display:inline-flex}.project-stack-list{flex-wrap:wrap;gap:8px;margin-top:auto;padding-top:22px;display:flex}.project-stack-list span{border:1px solid var(--border-subtle);min-height:30px;color:var(--text-secondary);background:#ffffff06;border-radius:999px;align-items:center;gap:7px;padding:0 10px;font-size:12px;font-weight:700;display:inline-flex}.project-stack-list img,.project-stack-list svg{flex:none;width:16px;height:16px}.project-stack-list svg{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.8px}.stack-fallback{border:1px solid var(--border-subtle);width:16px;height:16px;color:var(--text-primary);border-radius:50%;place-items:center;font-size:10px;font-style:normal;line-height:1;display:inline-grid}.project-card-cta{width:fit-content;color:var(--text-primary);margin-top:22px;font-size:14px;font-weight:800;display:inline-flex}.project-card-cta:after{content:"→";transition:transform .3s var(--ease);margin-left:8px}.project-card:hover .project-card-cta:after{transform:translate(3px)}.project-more-row{justify-content:center;display:flex}.project-more-button{border:1px solid var(--border-default);min-height:42px;color:var(--text-secondary);cursor:pointer;transition:transform .3s var(--ease), border-color .3s var(--ease), color .3s var(--ease), background .3s var(--ease);background:#ffffff06;border-radius:999px;justify-content:center;align-items:center;padding:0 18px;font-size:14px;font-weight:700;display:inline-flex}.project-more-button:hover{border-color:var(--border-strong);color:var(--text-primary);background:#ffffff0b;transform:translateY(-1px)}.project-links{margin-top:24px}.project-links a{color:var(--text-primary);font-weight:700}.project-links a:hover{color:var(--text-secondary)}.stack-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;display:grid}.stack-card{min-height:276px;transition:transform .35s var(--ease), border-color .35s var(--ease), background .35s var(--ease);padding:32px}.timeline{gap:14px;display:grid}.timeline-item{border-top:1px solid var(--border-subtle);grid-template-columns:150px minmax(0,1fr);gap:26px;padding:28px 0;display:grid}.timeline-item:last-child{border-bottom:1px solid var(--border-subtle)}.company{margin-bottom:10px;font-weight:700;color:var(--text-primary)!important}.education-list{gap:14px;display:grid}.education-list article{transition:transform .35s var(--ease), border-color .35s var(--ease), background .35s var(--ease);padding:28px 32px}.education-list h3{margin:6px 0}.project-detail-hero{padding:158px 0 78px}.project-back{width:fit-content;color:var(--text-secondary);align-items:center;margin-bottom:30px;font-size:14px;font-weight:700;display:flex}.project-back:hover{color:var(--text-primary)}.project-back:before{content:"←";margin-right:8px}.project-detail-status{text-transform:uppercase;align-items:center;width:fit-content;margin-bottom:20px;font-size:13px;font-weight:800;display:inline-flex}.project-detail-hero h1{max-width:940px;margin-bottom:24px;font-size:96px}.project-detail-hero p{max-width:780px;color:var(--text-secondary);font-size:20px;line-height:1.55}.project-detail-actions{flex-wrap:wrap;gap:12px;margin-top:34px;display:flex}.project-disabled-action{cursor:default;opacity:.72}.project-disabled-action:hover{transform:none}.project-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;padding-bottom:120px;display:grid}.project-detail-panel{border:1px solid var(--border-subtle);border-radius:var(--radius-card);background:var(--gradient-surface);min-height:260px;box-shadow:var(--shadow-soft);padding:32px}.project-detail-panel-wide{grid-column:1/-1}.project-detail-panel>span{color:var(--text-muted);font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;margin-bottom:14px;font-size:12px;font-weight:700;display:block}.project-detail-panel h2{color:var(--text-primary);font-family:var(--font-sans);background:0 0;margin-bottom:16px;font-size:24px;font-weight:700;line-height:1.2}.project-detail-panel p,.project-detail-panel li{color:var(--text-secondary)}.project-detail-panel ul{gap:12px;margin:0;padding-left:18px;display:grid}.project-stack-list-large{margin-top:0;padding-top:0}.project-stack-list-large span{min-height:36px;padding:0 12px;font-size:13px}.contact-section{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:28px;padding:102px 0;display:flex}.contact-section>div{width:100%}.contact-section .section-heading{max-width:880px;margin-bottom:0;margin-left:auto;margin-right:auto}.contact-section h2{max-width:880px;font-family:var(--font-display);margin-left:auto;margin-right:auto;padding:.04em 0 .08em;font-size:82px;line-height:1}.contact-section .section-description{max-width:620px;margin-left:auto;margin-right:auto;font-size:20px;line-height:1.45}.contact-section .eyebrow{margin-left:auto;margin-right:auto}.contact-actions{justify-content:center;width:100%}.contact-section .contact-actions .button{width:auto;min-width:210px;margin:0 auto}.site-footer{z-index:1;border-top:1px solid var(--border-strong);background:linear-gradient(180deg, #ffffff09, #ffffff02 48%, transparent 100%), var(--background);width:100%;color:var(--text-muted);margin:76px 0 0;padding:0 0 44px;font-size:14px;position:relative}.site-footer:before{content:"";pointer-events:none;background:linear-gradient(90deg,#0000 0%,#ffffff47 50%,#0000 100%);height:1px;position:absolute;top:-1px;left:0;right:0}.site-footer-inner{width:min(calc(100% - 40px), var(--container));grid-template-columns:minmax(0,1.1fr) minmax(auto,420px) auto;align-items:center;gap:28px;margin:0 auto;padding:34px 0 28px;display:grid}.footer-brand{gap:8px;min-width:0;display:grid}.footer-brand p{max-width:420px;color:var(--text-secondary);margin:0;font-size:14px;line-height:1.5}.footer-nav,.footer-socials{align-items:center;display:flex}.footer-nav{flex-wrap:wrap;justify-content:center;gap:18px}.footer-nav a{color:var(--text-secondary);transition:color .25s var(--ease);font-size:13px;font-weight:700}.footer-nav a:hover{color:var(--text-primary)}.footer-socials{justify-content:flex-end;gap:8px}.footer-socials a{border:1px solid var(--border-subtle);width:36px;height:36px;color:var(--text-secondary);transition:transform .25s var(--ease), border-color .25s var(--ease), color .25s var(--ease), background .25s var(--ease);background:#ffffff05;border-radius:50%;place-items:center;display:grid}.footer-socials a:hover{border-color:var(--border-strong);color:var(--text-primary);background:#ffffff0b;transform:translateY(-1px)}.footer-socials svg{width:17px;height:17px}.footer-socials .brand-svg{fill:currentColor;stroke:none}.footer-socials .line-svg{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2px}.site-footer-bottom{width:min(calc(100% - 40px), var(--container));border-top:1px solid var(--border-subtle);color:var(--text-faint);flex-wrap:wrap;justify-content:space-between;gap:8px 18px;margin:0 auto;padding:18px 0 0;font-size:12px;font-weight:600;display:flex}@media (max-width:980px){h1{font-size:84px}h2{font-size:50px}.hero,.education-grid,.contact-section{grid-template-columns:1fr}.hero{grid-template-rows:auto auto;gap:42px;min-height:auto;padding-top:64px}.hero-content{grid-area:1/1;width:min(100%,100vw - 32px);overflow:hidden}.hero-visual{grid-area:2/1}.hero-stack-strip{grid-area:2/1;width:100%}.hero-visual,.code-window{min-height:420px}.project-grid,.stack-grid,.project-detail-grid{grid-template-columns:1fr}.project-extra-wrap.is-expanded,.project-extra-wrap.is-collapsing{max-height:1180px}.project-extra-wrap.is-collapsing{max-height:0}.about-content{grid-template-columns:1fr;gap:34px}.about-portrait-wrap{width:min(100%,270px)}.project-card-featured{grid-row:auto;min-height:340px}.project-detail-hero h1{font-size:78px}.project-detail-panel-wide{grid-column:auto}}@media (max-width:860px){.experience-timeline{gap:16px;padding:0}.experience-timeline:before{display:none}.experience-card{min-height:auto;display:block}.experience-card-inner{padding:24px 22px 22px 24px}.experience-node{display:none}.experience-card-top{align-items:flex-start;gap:10px}.experience-company{flex:1;font-size:11px;line-height:1.5}.experience-card h3{margin-top:8px;font-size:clamp(20px,5.4vw,23px);line-height:1.14}.experience-location{margin-bottom:12px;font-size:13px;line-height:1.45}.experience-card p:not(.experience-location){margin-bottom:16px;font-size:14px;line-height:1.55}.experience-badges{gap:7px}.experience-badges span{min-height:28px;padding:0 10px;font-size:11px}}@media (max-width:760px){h1{max-width:100%;font-size:clamp(48px,13vw,58px);line-height:1.03}h2{font-size:38px;line-height:1.08}.contact-section h2{max-width:100%;font-size:54px;line-height:1}h3{font-size:19px}.site-header{width:100%;padding:8px}.site-header-inner,.site-header.is-scrolled .site-header-inner,body.nav-open .site-header-inner{border-color:var(--border-default);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#000000b8;border-radius:999px;width:100%;min-height:48px;padding:4px 58px 4px 14px}.brand-text{text-overflow:ellipsis;max-width:180px;overflow:hidden}.nav-toggle{z-index:30;opacity:1;visibility:visible;flex:none;place-items:center;width:38px;height:38px;margin-left:0;position:absolute;top:50%;left:auto;right:6px;transform:translateY(-50%);display:grid!important}.nav-toggle span{margin:0;position:absolute;top:50%;left:50%}.nav-toggle span:first-child{transform:translate(-50%,calc(-50% - 4px))}.nav-toggle span:last-child{transform:translate(-50%,calc(4px - 50%))}.nav-toggle[aria-expanded=true] span:first-child{transform:translate(-50%,-50%)rotate(45deg)}.nav-toggle[aria-expanded=true] span:last-child{transform:translate(-50%,-50%)rotate(-45deg)}.header-actions{display:none}.site-nav{border:1px solid var(--border-default);border-radius:var(--radius-card);box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#000000f0;flex-direction:column;align-items:stretch;gap:0;padding:12px 16px;display:none;position:fixed;inset:72px 14px auto;transform:none}.site-nav.is-open{display:flex}.site-nav a{min-height:44px;color:var(--text-secondary);background:0 0;border-bottom:0;border-radius:0;justify-content:space-between;align-items:center;padding:0 4px;font-size:15px;display:flex}.site-nav a:hover,.site-nav a.is-active{color:var(--text-primary);background:0 0}.site-nav .mobile-nav-actions{border-top:1px solid var(--border-subtle);flex-wrap:nowrap;justify-content:flex-start;align-items:center;gap:10px;margin-top:10px;padding-top:14px;display:flex}.site-nav .mobile-nav-resume,.site-nav .mobile-nav-contact{white-space:nowrap;cursor:pointer;width:auto;min-width:0;min-height:42px;transition:transform .3s var(--ease), border-color .3s var(--ease), background .3s var(--ease), color .3s var(--ease);border-radius:999px;justify-content:center;align-items:center;padding:0 16px;font-size:14px;font-weight:800;display:inline-flex}.site-nav .mobile-nav-resume{border:1px solid var(--border-default);color:var(--text-primary);background:#ffffff09}.site-nav .mobile-nav-contact{border:1px solid var(--text-primary);background:var(--text-primary);color:var(--background)}.site-nav .mobile-nav-resume:hover,.site-nav .mobile-nav-contact:hover{transform:translateY(-1px)}.site-nav .mobile-nav-contact:hover,.site-nav .mobile-nav-contact[aria-expanded=true]{color:var(--background)}.section-shell{width:calc(100% - 32px)}.hero{grid-template-rows:minmax(0,1fr) auto;align-items:stretch;row-gap:clamp(32px,7svh,62px);min-height:100dvh;padding:104px 0 28px}.hero-content{align-self:center}.hero-title{gap:8px;width:min(100%,100vw - 32px)}.title-desktop{display:none!important}.title-mobile{display:block!important}.eyebrow{margin-bottom:22px}.hero-copy{white-space:normal;width:min(360px,100vw - 32px);max-width:100%;margin-bottom:30px;font-size:17px;line-height:1.58}.hero-meta{align-items:center;gap:10px}.hero-stack-strip{align-self:end;width:calc(100vw - 32px);padding-top:0;padding-bottom:10px}.hero-stack-marquee p{text-align:center;margin-bottom:10px;font-size:14px}.stack-marquee-track{gap:34px;padding-right:34px;animation-duration:46s}.stack-logo-item{gap:9px;font-size:16px}.stack-logo-item svg,.stack-logo-item img{width:23px;height:23px}.hero-highlights{grid-template-columns:1fr}.hero-visual,.code-window{min-height:360px}.code-tabs{overflow-x:auto}.code-window pre{padding:26px 18px 0;font-size:12px;line-height:1.9}.code-footer{flex-direction:column;align-items:flex-start;gap:6px}.education-grid{gap:24px;padding:66px 0}.section-block,.stack-section{padding:82px 0}.project-card,.stack-card,.education-list article{min-height:auto;padding:24px}.project-card{min-height:300px}.about-section .section-heading{text-align:left}.about-content{justify-items:center;width:min(100%,100vw - 32px);margin:0 auto;padding:22px 20px}.about-portrait-wrap{width:100%;margin:0 auto}.about-details,.about-text{text-align:left;width:100%;max-width:390px}.about-text p{font-size:14px;line-height:1.62}.about-resume{width:auto;min-width:190px;margin-top:26px;margin-left:auto;margin-right:auto;padding:0 18px;display:flex}.project-card-header{flex-direction:column;align-items:flex-start;margin-bottom:24px}.project-card-featured h3{font-size:26px}.project-detail-hero{padding:118px 0 58px}.project-detail-hero h1{font-size:58px;line-height:1}.project-detail-hero p{font-size:17px}.project-detail-actions{flex-direction:column;align-items:stretch}.project-detail-panel{min-height:auto;padding:24px}.timeline-item{grid-template-columns:1fr;gap:8px}.contact-section{padding:76px 0}.contact-actions,.hero-actions{flex-direction:column;align-items:stretch}.contact-section .contact-actions{align-items:center}.contact-section .contact-actions .button{width:min(100%,220px)}.hero-actions{flex-direction:row;align-items:center;gap:10px}.button{width:100%}.about-section .about-resume{width:auto;min-width:190px}.hero-actions .button{width:auto;min-height:40px;padding:0 16px;font-size:14px}.site-footer{width:100%;margin-top:56px;padding:0 0 34px}.site-footer-inner{text-align:center;grid-template-columns:1fr;gap:20px;width:calc(100% - 32px);padding:28px 0 22px}.footer-brand{justify-items:center}.footer-brand p{max-width:300px}.footer-nav,.footer-socials{justify-content:center}.footer-nav{gap:12px 16px}.site-footer-bottom{text-align:center;justify-content:center;width:calc(100% - 32px);padding-top:18px}}@media (max-width:420px){h1{font-size:clamp(46px,12.4vw,52px)}h2{font-size:35px}.contact-section h2{font-size:46px}.nav-toggle{left:auto}}@media (max-width:520px){.nav-toggle{right:6px}}@media (max-width:380px){.nav-toggle{left:auto}}@media (max-width:360px){.nav-toggle{left:auto}}@media (max-width:340px){.nav-toggle{left:auto}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.hero-animate{opacity:1;filter:none;transform:none}.scroll-reveal{opacity:1;filter:none;transition:none;transform:none}}
