@import"https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--color-bg: #f6f3ee;--color-text: #1a1a18;--color-text-light: #7a756d;--color-watermark: rgba(0, 0, 0, .03);--color-accent: #c8553d;--color-border: #ddd8cf;--color-card-bg: #fffdf9;--font-heading: "DM Serif Display", Georgia, "Times New Roman", serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Courier New", monospace;--ease-out-expo: cubic-bezier(.16, 1, .3, 1)}[data-theme=dark]{--color-bg: #111110;--color-text: #ece8e1;--color-text-light: #8a857d;--color-watermark: rgba(255, 255, 255, .03);--color-accent: #d4785c;--color-border: #2a2926;--color-card-bg: #1a1918}html{font-size:16px;scroll-behavior:smooth;color-scheme:light dark}body{font-family:var(--font-body);background-color:var(--color-bg);color:var(--color-text);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .5s ease,color .5s ease}a{text-decoration:none;color:inherit}ul,ol{list-style:none}img{max-width:100%;display:block}::selection{background:var(--color-accent);color:#fff}section{transition:background-color .5s ease}.app{width:100%;min-height:100vh;position:relative}.grain-overlay{position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:180px 180px}[data-theme=dark] .grain-overlay{opacity:.05}.section-divider{display:flex;align-items:center;justify-content:center;padding:0 2rem;max-width:900px;margin:0 auto;position:relative}.section-divider:before,.section-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.section-divider__ornament{font-size:.6rem;color:var(--color-accent);padding:0 1.2rem;letter-spacing:2px;-webkit-user-select:none;user-select:none}.scroll-progress{position:fixed;top:0;left:0;width:100%;height:2px;background:transparent;z-index:9999;pointer-events:none}.scroll-progress__bar{height:100%;background:var(--color-accent);border-radius:0;transition:width .1s linear;opacity:.7}.theme-toggle{position:fixed;top:1.2rem;right:1.5rem;z-index:1000;width:38px;height:38px;border-radius:0;border:1px solid var(--color-border);background:var(--color-card-bg);color:var(--color-text);display:flex;align-items:center;justify-content:center;transition:all .3s ease}.theme-toggle:hover{border-color:var(--color-accent);color:var(--color-accent)}[data-theme=dark] .theme-toggle{background:var(--color-card-bg);border-color:var(--color-border);color:var(--color-text)}[data-theme=dark] .theme-toggle:hover{border-color:var(--color-accent);color:var(--color-accent)}.theme-toggle__icon{position:relative;width:18px;height:18px}.theme-toggle__sun,.theme-toggle__moon{position:absolute;inset:0;transition:all .4s var(--ease-out-expo)}.theme-toggle__sun{opacity:1;transform:rotate(0) scale(1)}.theme-toggle__moon{opacity:0;transform:rotate(-90deg) scale(.5)}.theme-toggle__icon--dark .theme-toggle__sun{opacity:0;transform:rotate(90deg) scale(.5)}.theme-toggle__icon--dark .theme-toggle__moon{opacity:1;transform:rotate(0) scale(1)}.topnav{position:fixed;top:0;left:0;width:100%;z-index:1000;padding:1.2rem 2.5rem;transition:all .4s ease}.topnav--scrolled{padding:.8rem 2.5rem;background:var(--color-bg);border-bottom:1px solid var(--color-border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}[data-theme=dark] .topnav--scrolled{background:#111110e6}.topnav__inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.topnav__logo{font-family:var(--font-heading);font-size:1.4rem;font-weight:400;color:var(--color-text);letter-spacing:-.5px;transition:color .3s ease}.topnav__logo:hover,.topnav__logo-dot{color:var(--color-accent)}.topnav__links{display:flex;align-items:center;gap:2.5rem}.topnav__link{font-family:var(--font-mono);font-size:.68rem;font-weight:400;letter-spacing:1.5px;text-transform:uppercase;color:var(--color-text-light);position:relative;padding-bottom:2px;transition:color .3s ease}.topnav__link:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--color-accent);transition:width .3s ease}.topnav__link:hover{color:var(--color-text)}.topnav__link:hover:after{width:100%}.topnav__link--active{color:var(--color-text)}.topnav__link--active:after{width:100%;background:var(--color-accent)}@media(max-width:600px){.topnav{padding:1rem 1.2rem}.topnav--scrolled{padding:.7rem 1.2rem}.topnav__links{gap:1.2rem}.topnav__link{font-size:.6rem;letter-spacing:1px}}.hero{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:8rem 2rem 6rem;position:relative}.hero__content{width:100%;max-width:760px;text-align:center}.hero__greeting{font-family:var(--font-mono);font-size:.8rem;font-weight:400;color:var(--color-accent);margin-bottom:1.5rem;letter-spacing:2px;text-transform:uppercase}.hero__heading{font-family:var(--font-heading);font-size:clamp(3.5rem,10vw,7rem);font-weight:400;color:var(--color-text);line-height:1;letter-spacing:-1px;margin-bottom:2rem}.hero__typed{margin-bottom:2rem;min-height:2rem;display:flex;align-items:center;justify-content:center;padding:.6rem 0;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.hero__typed-text{font-family:var(--font-mono);font-size:.85rem;font-weight:400;color:var(--color-text);letter-spacing:.5px}.hero__typed-cursor{font-family:var(--font-mono);font-size:.85rem;font-weight:400;color:var(--color-accent);animation:cursorBlink .8s step-end infinite;margin-left:2px}@keyframes cursorBlink{0%,to{opacity:1}50%{opacity:0}}.hero__bio{max-width:480px;margin:0 auto}.hero__bio p{font-size:1rem;font-weight:400;color:var(--color-text-light);line-height:1.85}.hero__cta{display:flex;align-items:center;justify-content:center;gap:1.2rem;margin-top:3rem}.hero__btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.75rem;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;padding:.9rem 2rem;border-radius:0;transition:all .3s ease;text-decoration:none}.hero__btn--primary{background:var(--color-text);color:var(--color-bg);border:1px solid var(--color-text)}.hero__btn--primary:hover{background:var(--color-accent);border-color:var(--color-accent);color:#fff}[data-theme=dark] .hero__btn--primary{background:var(--color-text);color:var(--color-bg);border-color:var(--color-text)}[data-theme=dark] .hero__btn--primary:hover{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.hero__btn--ghost{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.hero__btn--ghost:hover{border-color:var(--color-text)}.hero__scroll-hint{position:absolute;bottom:2.5rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--color-text-light);font-family:var(--font-mono);font-size:.6rem;font-weight:400;letter-spacing:3px;text-transform:uppercase;opacity:.5}.hero__scroll-line{width:1px;height:30px;background:var(--color-text-light);animation:scrollPulse 2.5s ease-in-out infinite;transform-origin:top}@keyframes scrollPulse{0%,to{opacity:.5;transform:scaleY(1)}50%{opacity:.1;transform:scaleY(.4)}}.animate-in{opacity:0;transform:translateY(20px);animation:fadeInUp .9s var(--ease-out-expo) forwards}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hero__greeting.animate-in{animation-delay:.1s}.hero__heading.animate-in{animation-delay:.25s}.hero__typed.animate-in{animation-delay:.4s}.hero__bio.animate-in{animation-delay:.55s}.hero__quote{font-family:var(--font-heading);font-size:1.2rem;font-weight:400;font-style:italic;color:var(--color-text);margin:2rem auto 0;padding-left:1.2rem;border-left:2px solid var(--color-accent);max-width:400px;line-height:1.6;opacity:.8}.hero__quote.animate-in{animation-delay:.6s}.hero__cta.animate-in{animation-delay:.8s}.hero__scroll-hint.animate-in{animation-delay:1.1s}@media(max-width:768px){.hero{padding:6rem 1.5rem 4rem}.hero__heading{font-size:3rem}.hero__cta{flex-direction:column}.hero__btn{width:100%;justify-content:center}}.resume{width:100%;padding:6rem 2rem;position:relative;background:var(--color-bg)}.resume__header{max-width:900px;margin:0 auto 3.5rem;text-align:center}.resume__watermark{display:none}.resume__heading{font-family:var(--font-heading);font-size:clamp(2.5rem,5vw,3.5rem);font-weight:400;color:var(--color-text);line-height:1.1;letter-spacing:-.5px}.resume__number{font-family:var(--font-mono);font-size:.75rem;font-weight:400;color:var(--color-accent);letter-spacing:2px;display:block;margin-bottom:.5rem}.resume__content{display:flex;gap:4rem;max-width:900px;margin:0 auto}.resume__left{flex:0 0 38%}.resume__right{flex:1}.resume__section{margin-bottom:2rem}.resume__section-title{font-family:var(--font-mono);font-size:.7rem;font-weight:500;color:var(--color-accent);margin-bottom:1.5rem;letter-spacing:2px;text-transform:uppercase}.resume__section-title--exp{font-size:.7rem;margin-bottom:1.5rem}.resume__edu-item{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;padding-left:.2rem}.resume__edu-marker{flex-shrink:0;width:6px;height:6px;border-radius:0;background:var(--color-accent);border:none;margin-top:7px;position:relative}.resume__edu-marker:after{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:1px;height:30px;background:var(--color-border)}.resume__edu-item:last-child .resume__edu-marker:after{display:none}.resume__edu-details{display:flex;flex-direction:column}.resume__edu-name{font-family:var(--font-heading);font-size:1.05rem;font-weight:400;color:var(--color-text);line-height:1.3}.resume__edu-year{font-family:var(--font-mono);font-size:.7rem;font-weight:400;color:var(--color-text-light);margin-bottom:.2rem;letter-spacing:.5px}.resume__edu-desc{font-size:.85rem;font-weight:400;color:var(--color-text-light);line-height:1.5}.resume__exp-list{display:flex;flex-direction:column}.resume__exp-item{position:relative;padding:1.3rem 0;border-top:1px solid var(--color-border);transition:padding .3s ease}.resume__exp-item:last-child{border-bottom:1px solid var(--color-border)}.resume__exp-item:hover{padding-left:.6rem}.resume__exp-company{font-family:var(--font-heading);font-size:1rem;font-weight:400;color:var(--color-text);letter-spacing:0;text-transform:none;margin-bottom:.15rem}.resume__exp-role{font-family:var(--font-mono);font-size:.72rem;font-weight:400;color:var(--color-text-light);margin-bottom:.5rem;letter-spacing:.3px}.resume__exp-sep{margin:0 .4rem;color:var(--color-border)}.resume__exp-desc{font-size:.85rem;font-weight:400;color:var(--color-text-light);line-height:1.7;max-width:520px}.resume .animate-in{opacity:0;transform:translateY(20px);animation:resumeFadeIn .7s var(--ease-out-expo) forwards}@keyframes resumeFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.resume__header.animate-in{animation-delay:0s}.resume__left .resume__section.animate-in{animation-delay:.1s}.resume__right .resume__section.animate-in{animation-delay:.15s}@media(max-width:768px){.resume{padding:4rem 1.5rem}.resume__content{flex-direction:column;gap:2rem}.resume__left{flex:none}}[data-theme=dark] .resume__edu-marker{background:var(--color-accent)}.projects{width:100%;padding:6rem 2rem;position:relative;background:var(--color-bg)}.projects__header{max-width:900px;margin:0 auto 3.5rem;text-align:center}.projects__heading{font-family:var(--font-heading);font-size:clamp(2.5rem,5vw,3.5rem);font-weight:400;color:var(--color-text);line-height:1.1;letter-spacing:-.5px;margin-bottom:1rem}.projects__number{font-family:var(--font-mono);font-size:.75rem;font-weight:400;color:var(--color-accent);letter-spacing:2px;display:block;margin-bottom:.5rem}.projects__intro{font-size:1rem;font-weight:400;color:var(--color-text-light);max-width:460px;margin:0 auto;line-height:1.75}.projects__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;max-width:900px;margin:0 auto}.projects__card-link{display:block;text-decoration:none;color:inherit}.projects__card{border:1px solid var(--color-border);overflow:hidden;background:var(--color-card-bg);padding:2rem 2rem 1.8rem;transition:border-color .3s ease;position:relative}.projects__card:before{content:"";position:absolute;top:0;left:0;width:4px;height:0;background:var(--color-accent);transition:height .4s var(--ease-out-expo)}.projects__card:hover{border-color:var(--color-text-light)}.projects__card:hover:before{height:100%}.projects__card-number{font-family:var(--font-heading);font-size:3rem;font-weight:400;color:var(--color-watermark);font-style:italic;letter-spacing:-1px;margin-bottom:1rem;-webkit-user-select:none;user-select:none;line-height:1}.projects__card-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem}.projects__card-category{font-family:var(--font-mono);font-size:.65rem;font-weight:500;text-transform:uppercase;letter-spacing:1.5px;color:var(--color-accent)}.projects__card-year{font-family:var(--font-mono);font-size:.68rem;font-weight:400;color:var(--color-text-light)}.projects__card-title{font-family:var(--font-heading);font-size:1.3rem;font-weight:400;color:var(--color-text);margin-bottom:.6rem}.projects__card-desc{font-size:.88rem;font-weight:400;color:var(--color-text-light);line-height:1.7;margin-bottom:1.2rem}.projects__card-tags{display:flex;flex-wrap:wrap;gap:.4rem}.projects__tag{font-family:var(--font-mono);font-size:.62rem;font-weight:400;color:var(--color-text-light);background:transparent;border:1px solid var(--color-border);padding:.25rem .65rem;letter-spacing:.5px;transition:all .3s ease}.projects__card:hover .projects__tag{border-color:var(--color-accent);color:var(--color-accent)}.projects .animate-in{opacity:0;transform:translateY(20px);animation:projectsFadeIn .7s var(--ease-out-expo) forwards}@keyframes projectsFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.projects{padding:4rem 1.5rem}.projects__grid{grid-template-columns:1fr}}[data-theme=dark] .projects__tag{border-color:#333}[data-theme=dark] .projects__card:hover .projects__tag{border-color:var(--color-accent);color:var(--color-accent)}.footer__cta{background:var(--color-text);color:var(--color-bg);padding:5rem 2rem}.footer__cta-inner{max-width:900px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:2rem}.footer__cta-heading{font-family:var(--font-heading);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:400;letter-spacing:-.5px;margin-bottom:.4rem}.footer__cta-sub{font-size:.9rem;font-weight:300;color:#ffffff73;font-style:italic}.footer__cta-actions{display:flex;align-items:center;gap:.8rem;flex-shrink:0}.footer__btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.72rem;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;padding:.85rem 1.8rem;transition:all .3s ease;text-decoration:none}.footer__btn--primary{background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-bg)}.footer__btn--primary:hover{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.footer__btn-arrow{transition:transform .3s ease}.footer__btn--primary:hover .footer__btn-arrow{transform:translate(3px)}.footer__btn--secondary{background:transparent;color:#fff9;border:1px solid rgba(255,255,255,.2)}.footer__btn--secondary:hover{color:#fff;border-color:#fff}.footer__bottom{background:#0a0a09;padding:1.2rem 2rem}.footer__bottom-inner{max-width:900px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.footer__copy{font-family:var(--font-mono);font-size:.65rem;font-weight:400;color:#ffffff4d;letter-spacing:.5px}.footer__socials{display:flex;align-items:center;gap:.6rem}.footer__social-link{width:32px;height:32px;border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;color:#fff6;transition:all .3s ease}.footer__social-link:hover{border-color:var(--color-accent);color:var(--color-accent)}@media(max-width:768px){.footer__cta-inner{flex-direction:column;text-align:center}.footer__cta-actions{flex-direction:column;width:100%}.footer__btn{width:100%;justify-content:center}.footer__bottom-inner{flex-direction:column;gap:.8rem;text-align:center}}[data-theme=dark] .footer__cta{background:#1a1918}[data-theme=dark] .footer__bottom{background:#050504}[data-theme=dark] .footer__btn--primary{background:var(--color-bg);color:var(--color-text)}[data-theme=dark] .footer__btn--primary:hover{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}
