@charset "UTF-8";@font-face{font-family:IBM Plex Sans;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/IBMPlexSans-Regular.woff2) format("woff2")}@font-face{font-family:IBM Plex Sans;font-style:italic;font-weight:400;font-display:swap;src:url(/fonts/IBMPlexSans-Italic.woff2) format("woff2")}@font-face{font-family:IBM Plex Sans;font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/IBMPlexSans-Medium.woff2) format("woff2")}@font-face{font-family:IBM Plex Sans;font-style:italic;font-weight:500;font-display:swap;src:url(/fonts/IBMPlexSans-MediumItalic.woff2) format("woff2")}@font-face{font-family:IBM Plex Sans;font-style:normal;font-weight:600;font-display:swap;src:url(/fonts/IBMPlexSans-SemiBold.woff2) format("woff2")}@font-face{font-family:IBM Plex Sans;font-style:italic;font-weight:600;font-display:swap;src:url(/fonts/IBMPlexSans-SemiBoldItalic.woff2) format("woff2")}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background-color:#0f1117;color:#dde1ea;font-family:IBM Plex Sans,system-ui,-apple-system,sans-serif;font-size:100%;font-weight:400;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}img{max-width:100%;display:block}#root{width:100%}.skip-link{position:absolute;top:1rem;left:1rem;padding:.5rem 1rem;background-color:#4e8fd4;color:#0f1117;font-size:.875rem;font-weight:600;border-radius:4px;z-index:200;transform:translateY(-300%);transition:transform .2s ease}.skip-link:focus-visible{transform:translateY(0);outline:none}:focus-visible{outline:2px solid #4e8fd4;outline-offset:3px;border-radius:2px}.nav{position:sticky;top:0;z-index:100;transition:background-color .3s ease,box-shadow .3s ease}.nav.nav-scrolled{background-color:#0f111766;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:0 1px #ffffff12}.nav .nav-inner{max-width:1100px;margin:0 auto;padding:0 2rem;height:4rem;display:flex;align-items:center;justify-content:space-between}.nav .nav-logo{font-size:18px;font-weight:600;color:#dde1ea;letter-spacing:.02em;transition:color .2s ease}.nav .nav-logo:hover{color:#4e8fd4}.nav .nav-links{display:flex;gap:2.25rem;align-items:center}.nav .nav-link{font-size:15px;font-weight:500;color:#8892a4;position:relative;transition:color .2s ease}.nav .nav-link:after{content:"";position:absolute;bottom:-.25rem;left:0;right:0;height:2px;background-color:#4e8fd4;border-radius:1px;transform:scaleX(0);transform-origin:left center;transition:transform .25s ease}.nav .nav-link:hover,.nav .nav-link.active{color:#dde1ea}.nav .nav-link.active:after{transform:scaleX(1)}.nav .nav-hamburger{display:none;background:none;border:none;padding:.5rem;cursor:pointer;align-items:center;justify-content:center}.nav .nav-ham{display:block;width:1.375rem;height:2px;background-color:#dde1ea;border-radius:1px;position:relative;transition:background-color .25s ease,transform .25s ease}.nav .nav-ham:before,.nav .nav-ham:after{content:"";position:absolute;left:0;width:100%;height:2px;background-color:#dde1ea;border-radius:1px;transition:top .25s ease,transform .25s ease}.nav .nav-ham:before{top:-.4375rem}.nav .nav-ham:after{top:.4375rem}.nav .nav-ham.open{background-color:transparent}.nav .nav-ham.open:before{top:0;transform:rotate(45deg)}.nav .nav-ham.open:after{top:0;transform:rotate(-45deg)}@media(max-width:640px){.nav .nav-hamburger{display:flex}.nav .nav-links{display:none;position:absolute;top:4rem;left:0;right:0;flex-direction:column;align-items:flex-start;gap:0;background-color:#0f1117f2;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.07);padding:.5rem 0}.nav .nav-links.open{display:flex}.nav .nav-link{width:100%;padding:.875rem 2rem;font-size:16px}.nav .nav-link:after{display:none}.nav .nav-link.active{color:#4e8fd4}}.home{padding:9.25rem 0 3.5rem}.home .home-inner{max-width:1100px;margin:0 auto;padding:0 2rem;animation:home-in .6s ease both}.home .home-name{font-size:clamp(44px,5.5dvw,68px);font-weight:600;letter-spacing:-.03em;color:#dde1ea;line-height:1.05;margin-bottom:1rem}.home .home-role{font-size:15px;color:#4e8fd4;font-weight:500;letter-spacing:.01em;margin-bottom:2.25rem}.home .home-description{font-size:19px;color:#8892a4;line-height:1.65;max-width:500px;margin-bottom:1rem;font-weight:400}.home .home-detail{font-size:15px;color:#8892a4;max-width:460px;margin-bottom:3.5rem;line-height:1.8}.home .home-links{display:flex;gap:2.25rem;align-items:center}.home .home-link{font-size:15px;font-weight:500;color:#dde1ea;padding-bottom:2px;border-bottom:1px solid rgba(255,255,255,.16);transition:color .2s ease,border-color .2s ease}.home .home-link:hover{color:#4e8fd4;border-bottom-color:#4e8fd4}.home .home-link.home-link-muted{color:#8892a4;border-bottom-color:transparent}.home .home-link.home-link-muted:hover{color:#dde1ea;border-bottom-color:#ffffff29}@keyframes home-in{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@media(max-width:640px){.home{padding:6.25rem 0 5.5rem}.home .home-description{font-size:17px}}@media(prefers-reduced-motion:reduce){.home .home-inner{animation:none}}.cred-strip{background-color:#0f1117;padding:0 2rem 5rem}.cred-strip .cred-strip-inner{max-width:1100px;margin:0 auto;border-top:1px solid rgba(255,255,255,.07);padding-top:1.75rem;display:flex;align-items:center;flex-wrap:wrap}.cred-strip .cred-strip-item{font-size:13px;font-weight:400;color:#8892a4;padding:0 1.5rem 0 0}.cred-strip .cred-strip-item+.cred-strip-item{padding:0 1.5rem;border-left:1px solid rgba(255,255,255,.07)}.cred-strip .cred-strip-item:last-child{padding-right:0}@media(max-width:640px){.cred-strip{padding:0 1.5rem 4rem}.cred-strip .cred-strip-inner{flex-direction:column;align-items:flex-start;gap:.75rem;padding-top:1.5rem}.cred-strip .cred-strip-item,.cred-strip .cred-strip-item+.cred-strip-item{padding:0;border-left:none}}.section{padding:6.25rem 2rem;background-color:#0f1117;opacity:0;transform:translateY(14px);transition:opacity .55s ease-out,transform .55s ease-out}.section.section-alt{background-color:#13161e}.section.visible{opacity:1;transform:translateY(0)}.section .section-inner{max-width:1100px;margin:0 auto;width:100%}@media(max-width:768px){.section{padding:4.5rem 1.5rem}}@media(prefers-reduced-motion:reduce){.section{opacity:1;transform:none;transition:none}}.about{max-width:700px}.about .about-title{font-size:32px;font-weight:600;color:#dde1ea;margin-bottom:2rem}.about .about-body{display:flex;flex-direction:column;gap:1.125rem;margin-bottom:3rem}.about .about-body p{font-size:17px;color:#8892a4;line-height:1.8}.about .about-body strong{color:#dde1ea;font-weight:500}.about .about-personal{font-size:14px;font-style:italic;color:#8892a4;line-height:1.7;margin-top:.5rem;margin-bottom:3rem}.about .about-timeline{display:flex;flex-direction:column;gap:1.5rem;border-left:1px solid rgba(255,255,255,.07);padding-left:1.5rem}.about .about-entry{display:flex;gap:1.5rem;align-items:flex-start}.about .about-year{font-size:13px;color:#4e8fd4;font-weight:500;white-space:nowrap;min-width:8.5rem;padding-top:.125rem}.about .about-entry-title{display:block;font-size:15px;font-weight:600;color:#dde1ea;margin-bottom:.2rem}.about .about-entry-sub{font-size:14px;color:#8892a4;display:block}@media(max-width:640px){.about .about-entry{flex-direction:column;gap:.25rem}}.skill-card{background-color:#181c25;border:1px solid rgba(255,255,255,.07);border-radius:5px;padding:1.125rem 1.375rem;display:flex;align-items:flex-start;gap:1rem;transition:border-color .2s ease}.skill-card:hover{border-color:#ffffff1f}.skill-card .skill-card-body{flex:1;min-width:0}.skill-card .skill-card-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.625rem}.skill-card .skill-card-name{font-size:15px;font-weight:600;color:#dde1ea}.skill-card .skill-card-level{font-size:11px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;flex-shrink:0}.skill-card .skill-card-track{width:100%;height:3px;background-color:#ffffff0f;border-radius:2px;overflow:hidden}.skill-card .skill-card-fill{height:100%;border-radius:2px;transition:width 1s ease-out}@media(prefers-reduced-motion:reduce){.skill-card-fill{transition:none}}.skills .skills-title{font-size:32px;font-weight:600;color:#dde1ea;margin-bottom:.5rem}.skills .skills-sub{font-size:16px;color:#8892a4;margin-bottom:3rem}.skills .skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.875rem}.work-block{padding:2rem 0;border-top:1px solid rgba(255,255,255,.07)}.work-block:last-of-type{border-bottom:1px solid rgba(255,255,255,.07)}.work-block .work-block-category{display:block;font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#8892a4;margin-bottom:.5rem}.work-block .work-block-title{font-size:17px;font-weight:600;color:#dde1ea;margin-bottom:.875rem;line-height:1.35}.work-block .work-block-desc{font-size:15px;color:#8892a4;line-height:1.8;max-width:700px;margin-bottom:1.25rem}.work-block .work-block-tech{display:flex;flex-wrap:wrap;gap:.375rem}.work-block .work-block-tag{font-size:12px;font-weight:500;color:#8892a4;padding:.2rem .5rem;border:1px solid rgba(255,255,255,.07);border-radius:3px;background:transparent}.timeline-item{display:flex;gap:1.375rem;position:relative}.timeline-item .timeline-item-rail{display:flex;flex-direction:column;align-items:center;flex-shrink:0;padding-top:.25rem}.timeline-item .timeline-item-rail:after{content:"";flex:1;width:1px;background-color:#ffffff12;margin-top:.5rem}.timeline-item.last .timeline-item-rail:after{display:none}.timeline-item .timeline-item-dot{width:.875rem;height:.875rem;border-radius:50%;background-color:#4e8fd4;box-shadow:0 0 0 3px #22d3ee2e;flex-shrink:0}.timeline-item .timeline-item-content{flex:1;padding-bottom:3rem}.timeline-item.last .timeline-item-content{padding-bottom:0}.timeline-item .timeline-item-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:.875rem}.timeline-item .timeline-item-role{font-size:17px;font-weight:600;color:#dde1ea;margin-bottom:.2rem}.timeline-item .timeline-item-company{font-size:15px;color:#4e8fd4;font-weight:500}.timeline-item .timeline-item-period{font-size:13px;color:#8892a4;white-space:nowrap;flex-shrink:0;padding-top:.25rem}.timeline-item .timeline-item-bullets{list-style:none;padding:0;margin:0 0 1rem;display:flex;flex-direction:column;gap:.375rem}.timeline-item .timeline-item-bullets li{font-size:15px;color:#8892a4;line-height:1.65;padding-left:1rem;position:relative}.timeline-item .timeline-item-bullets li:before{content:"·";position:absolute;left:0;color:#4e8fd4;font-size:18px;line-height:1.5}.timeline-item .timeline-item-tech{display:flex;flex-wrap:wrap;gap:.375rem}.timeline-item .timeline-item-tag{font-size:12px;font-weight:500;padding:.2rem .5rem;border-radius:4px;background-color:#1e2230;color:#8892a4;border:1px solid rgba(255,255,255,.07)}.experience .experience-title{font-size:32px;font-weight:600;color:#dde1ea;margin-bottom:.75rem}.experience .experience-sub{font-size:15px;color:#8892a4;line-height:1.8;max-width:620px;margin-bottom:3rem}.experience .experience-work{margin-bottom:4rem}.experience .experience-employment-label{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#8892a4;margin-bottom:2rem}.experience .experience-timeline{max-width:720px}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:4px;font-size:15px;font-weight:500;border:none;transition:background-color .2s ease,border-color .2s ease,color .2s ease;white-space:nowrap;cursor:pointer}.btn:active{opacity:.85}.btn.btn-primary{background-color:#4e8fd4;color:#0f1117}.btn.btn-primary:hover{background-color:#4688d0}.btn.btn-ghost{background-color:transparent;color:#dde1ea;border:1px solid rgba(255,255,255,.1)}.btn.btn-ghost:hover{border-color:#fff3;color:#dde1ea}.contact{max-width:580px}.contact .contact-title{font-size:32px;font-weight:600;color:#dde1ea;margin-bottom:2.25rem}.contact .contact-text{font-size:17px;color:#8892a4;line-height:1.8;margin-bottom:2.25rem}.contact .contact-cta{margin-bottom:2rem}.contact .contact-social{display:flex;align-items:center;gap:.75rem}.contact .contact-social-link{font-size:15px;font-weight:500;color:#8892a4;transition:color .2s ease}.contact .contact-social-link:hover{color:#4e8fd4}.contact .contact-divider{color:#8892a4;opacity:.5;font-size:16px}.footer{border-top:1px solid rgba(255,255,255,.07);padding:2rem;text-align:center}.footer .footer-copy{font-size:13px;color:#8892a4;margin:0}
