*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html{scroll-behavior:smooth;font-size:18px}body{background-color:var(--color-bg);color:var(--color-ink);-webkit-font-smoothing:antialiased;font-family:Outfit,sans-serif;font-weight:400;line-height:1.6;overflow-x:hidden}:root{--color-bg:#171a1c;--color-bg-2:#1c1f22;--color-ink:#d0ddb0;--color-ink-muted:#b7c19f;--color-ink-faint:#5c6670;--color-border:#2e3338;--color-accent:#3b82f6;--font-display:"DM Sans", sans-serif;--font-body:"Outfit", sans-serif;--nav-height:72px;--container-max:1200px;--section-gap:120px;--transition:.35s cubic-bezier(.4, 0, .2, 1);--theme-transition:background-color .5s ease, color .5s ease, border-color .5s ease, opacity .5s ease}@media (prefers-color-scheme:light){:root:not([data-theme=dark]){--color-bg:#fafafa;--color-bg-2:#fff;--color-ink:#171a1c;--color-ink-muted:#454d54;--color-ink-faint:#abb3ba;--color-border:#e3e6e8}}[data-theme=light]{--color-bg:#fafafa;--color-bg-2:#fff;--color-ink:#171a1c;--color-ink-muted:#454d54;--color-ink-faint:#abb3ba;--color-border:#e3e6e8}[data-theme=dark]{--color-bg:#171a1c;--color-bg-2:#1c1f22;--color-ink:#d0ddb0;--color-ink-muted:#b7c19f;--color-ink-faint:#5c6670;--color-border:#2e3338}body,.section,.about,.hero,.nav,.nav__pill,.project-card,.floating-widget,.footer{transition:var(--theme-transition)}.container{width:100%;max-width:var(--container-max);margin-inline:auto;padding-inline:40px}.section{padding-block:var(--section-gap)}.section-label{font-family:var(--font-display);letter-spacing:-.02em;color:var(--color-ink);margin-bottom:24px;font-size:1.25rem;font-weight:700;display:inline-block}.section-title{font-family:var(--font-display);letter-spacing:-.02em;color:var(--color-ink);margin-bottom:56px;font-size:clamp(2rem,4vw,3rem);font-weight:700;line-height:1.1}.text-mask{display:block;overflow:hidden}.reveal-text{transition:transform 1.2s cubic-bezier(.16,1,.3,1);display:block;transform:translateY(105%)}.is-visible .reveal-text{transform:translateY(0)}.reveal-up{opacity:0;transition:opacity .7s ease var(--delay,0s), transform .7s ease var(--delay,0s);transform:translateY(36px)}.reveal-left{opacity:0;transition:opacity .7s ease var(--delay,0s), transform .7s ease var(--delay,0s);transform:translate(-36px)}.reveal-right{opacity:0;transition:opacity .7s ease var(--delay,0s), transform .7s ease var(--delay,0s);transform:translate(36px)}.btn{font-family:var(--font-body);letter-spacing:.01em;cursor:pointer;transition:background-color var(--transition), color var(--transition), box-shadow var(--transition), transform var(--transition);border-radius:100px;align-items:center;gap:6px;padding:12px 24px;font-size:.875rem;font-weight:500;text-decoration:none;display:inline-flex}.btn--primary{background-color:var(--color-ink);color:var(--color-bg);border:2px solid #0000}.btn--primary:hover{background-color:var(--color-ink-muted);transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.btn--outline{color:var(--color-ink);border:1.5px solid var(--color-border);background-color:#0000}.btn--outline:hover{border-color:var(--color-ink);transform:translateY(-2px)}.btn--nav{background-color:var(--color-ink);color:var(--color-bg);border-radius:100px;padding:10px 20px;font-size:.8125rem}.btn--nav:hover{background-color:var(--color-ink-muted)}.scroll-progress{z-index:9999;background:linear-gradient(90deg,#ff6b6b,#4d96ff,#6bcb77);width:0%;height:3px;transition:width .1s ease-out;display:none;position:fixed;top:0;left:0}[data-theme=dark] .scroll-progress{display:none!important}.nav{z-index:100;flex-direction:column;align-items:center;width:max-content;max-width:calc(100% - 48px);transition:transform .4s cubic-bezier(.16,1,.3,1),box-shadow .4s;display:flex;position:fixed;top:32px;left:50%;transform:translate(-50%)}.nav.scrolled{transform:translate(-50%,-8px)}.nav__pill{-webkit-backdrop-filter:blur(16px);background:#1c1f22b3;border:1px solid #d0ddb026;border-radius:100px;align-items:center;gap:16px;padding:6px 6px 6px 24px;transition:background-color .4s,border-color .4s;display:flex;box-shadow:0 8px 32px #0006}.nav.scrolled .nav__pill{background:#171a1ce6;border-color:#d0ddb040;box-shadow:0 12px 48px #0009}.nav__links{gap:32px;margin-right:-4px;list-style:none;display:flex}.nav__divider{background:var(--color-border);opacity:.6;width:1px;height:20px}.theme-toggle{cursor:pointer;color:var(--color-ink);background:#ffffff0d;border:none;border-radius:50%;justify-content:center;align-items:center;padding:8px;transition:transform .3s,color .3s;display:flex}.theme-toggle:hover{background:#ffffff1a;transform:scale(1.1)}.theme-toggle svg{width:20px;height:20px}.nav__logo-mobile{display:none}.sun-icon{display:block}.moon-icon,[data-theme=light] .sun-icon{display:none}[data-theme=light] .moon-icon{display:block}[data-theme=light] .theme-toggle{background:#0000000d}[data-theme=light] .theme-toggle:hover{background:#0000001a}[data-theme=light] .nav__pill{background:#ffffffb3;border-color:#00000014;box-shadow:0 4px 16px #0000000d}[data-theme=light] .nav.scrolled .nav__pill{background:#ffffffe6;border-color:#0000001f}[data-theme=light] .project-card{background-color:var(--color-bg-2);border-color:var(--color-border);box-shadow:0 4px 20px #00000008}[data-theme=light] .project-card:hover{border-color:var(--color-ink-faint);box-shadow:0 8px 32px #0000000f}[data-theme=light] .project-card:after{mix-blend-mode:multiply;opacity:.05}[data-theme=light] .floating-widget{background:#ffffffb3;border-color:#00000014;box-shadow:0 4px 16px #0000000d}[data-theme=light] .floating-widget:hover{border-color:#00000026}[data-theme=light] .about__word{color:var(--color-ink-faint)}[data-theme=light] .about__word.word-visible{color:var(--color-ink)}[data-theme=light] .btn--primary{background-color:var(--color-ink);color:var(--color-bg)}[data-theme=light] .btn--outline{border-color:var(--color-ink);color:var(--color-ink)}[data-theme=light] .nav__link:hover,[data-theme=light] .nav__link.active{background-color:var(--color-ink);color:var(--color-bg)}[data-theme=light] .nav__mobile{border-color:var(--color-border);background:#fffffff2}[data-theme=light] .nav__burger span{background-color:var(--color-ink)}.nav__link{font-family:var(--font-body);color:var(--color-ink-muted);border-radius:100px;padding:6px 16px;font-size:.875rem;text-decoration:none;transition:color .3s,background-color .3s;position:relative}.nav__link:hover{color:var(--accent)}[data-theme=light] .nav__link{background:linear-gradient(var(--prism-deg,135deg), #ff6b6b, #4d96ff, #6bcb77, #ff6b6b);-webkit-text-fill-color:transparent;background-size:300% 300%;-webkit-background-clip:text;background-clip:text;transition:background-position .3s}[data-theme=light] .nav__link:hover{background:linear-gradient(135deg,#ff6b6b,#4d96ff,#6bcb77);-webkit-text-fill-color:transparent;-webkit-background-clip:text;transition:all .3s}.nav__link.active{color:var(--color-bg);background-color:var(--color-ink)}.nav__burger{cursor:pointer;background:0 0;border:none;flex-direction:column;gap:5px;padding:4px;display:none}.nav__burger span{background:var(--color-ink);width:22px;height:1.5px;transition:transform var(--transition), opacity var(--transition);display:block}.nav__burger.open span:first-child{transform:rotate(45deg)translate(4.5px,4.5px)}.nav__burger.open span:nth-child(2){opacity:0}.nav__burger.open span:nth-child(3){transform:rotate(-45deg)translate(4.5px,-4.5px)}.nav__mobile{-webkit-backdrop-filter:blur(24px);background:#1c1f22d9;border:1px solid #d0ddb026;border-radius:24px;flex-direction:column;width:100%;max-height:0;margin-top:12px;padding:12px 24px 24px;transition:max-height .4s,padding .4s;display:none;overflow:hidden}.nav__mobile.open{max-height:400px;display:flex}.nav__mobile-link:last-child{border-bottom:none}.nav__mobile-link:hover{color:var(--color-ink-muted)}@keyframes fadeIn{to{opacity:1}}.floating-widget{z-index:100;-webkit-backdrop-filter:blur(16px);opacity:0;background:#1c1f22b3;border:1px solid #d0ddb026;border-radius:100px;align-items:center;gap:16px;padding:12px 24px;transition:transform .3s,border-color .3s;animation:1s .8s forwards fadeIn;display:flex;position:fixed;bottom:40px;right:40px;box-shadow:0 8px 32px #0006}.floating-widget:hover{border-color:#d0ddb04d}[data-theme=light] .nav__pill,[data-theme=light] .floating-widget{background-image:linear-gradient(var(--bg), var(--bg)), linear-gradient(var(--prism-deg,135deg), #ffb6c166, #add8e666, #90ee9066, #ffffe066);background-origin:border-box;background-clip:padding-box,border-box;border:1px solid #0000;box-shadow:0 8px 32px #1f268712}.floating-widget{-webkit-backdrop-filter:blur(12px);background-color:#21242cb3}[data-theme=light] .floating-widget{background-color:#ffffffb3}.floating-widget{transition:background-color .4s,border-color .4s,opacity .5s}.floating-widget__col{flex-direction:column;gap:2px;display:flex}.floating-widget__label{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.1em;color:var(--color-ink-faint);font-size:.625rem}.floating-widget__value{font-family:var(--font-display);color:var(--color-ink);font-size:.875rem;font-weight:500}.floating-widget__divider{background:var(--color-border);width:1px;height:24px}@media (width<=600px){.floating-widget{gap:12px;padding:10px 20px;bottom:24px;right:24px}}.hero{min-height:100svh;padding-top:var(--nav-height);flex-direction:column;justify-content:center;display:flex;position:relative;overflow:hidden}.hero__inner{z-index:1;max-width:var(--container-max);flex-direction:column;gap:40px;margin-inline:auto;padding-block:60px;padding-inline:40px;display:flex;position:relative}.hero__greeting{font-family:var(--font-body);letter-spacing:.05em;color:var(--color-ink-muted);text-transform:uppercase;font-size:clamp(1rem,2vw,1.25rem);font-weight:500}.hero__headline-wrap{flex-direction:column;gap:24px;display:flex}.hero__headline{font-family:var(--font-display);letter-spacing:-.01em;color:var(--color-ink);font-size:clamp(3rem,9vw,8.5rem);font-weight:700;line-height:.9}.hero__sub{color:var(--color-ink-muted);max-width:560px;font-size:clamp(1rem,2vw,1.25rem);font-weight:300;line-height:1.7}.hero__actions{flex-wrap:wrap;gap:16px;display:flex}.hero__scroll{letter-spacing:.08em;text-transform:uppercase;color:var(--color-ink-muted);align-items:center;gap:10px;font-size:.75rem;display:flex;position:absolute;bottom:40px;left:40px}.hero__scroll-arrow{flex-shrink:0;width:18px;height:18px;animation:1.8s ease-in-out infinite bounce}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(6px)}}@keyframes blink-cursor{0%,to{border-color:currentColor}50%{border-color:#0000}}.hero__headline{animation:.75s step-end infinite blink-cursor}.fixed-logo{font-family:var(--font-display);letter-spacing:-.01em;color:var(--color-ink);z-index:101;opacity:0;pointer-events:none;white-space:nowrap;font-size:1.5rem;font-weight:700;text-decoration:none;transition:opacity .3s,color .5s;position:fixed;top:24px;left:32px}.fixed-logo.is-visible{opacity:1;pointer-events:auto}.fixed-logo:after{content:"";background-color:var(--color-ink);vertical-align:middle;width:3px;height:1.2em;margin-left:4px;animation:.75s step-end infinite blink-cursor;display:inline-block}.fixed-logo.typing-done:after{display:none}.about{background-color:var(--color-bg);border-top:1px solid var(--color-border)}.about__grid{grid-template-columns:220px 1fr;align-items:start;gap:80px;display:grid}.about__label{padding-top:8px}.about__label .section-label{writing-mode:unset}.about__content{flex-direction:column;gap:24px;display:flex}.about__bio{color:var(--color-ink-muted);font-size:1.125rem;line-height:1.75}.about__word{opacity:.2;color:var(--color-ink-faint);transition:opacity .4s,color .4s;display:inline}.about__word.word-visible{opacity:1;color:var(--color-ink)}.about__cv{align-self:flex-start;margin-top:8px}.skills{background-color:var(--color-bg);border-top:1px solid var(--color-border)}.skills__header{flex-direction:column;display:flex}.skills__grid{flex-wrap:wrap;gap:12px;display:flex}.skill-pill{border:1.5px solid var(--color-border);cursor:default;color:var(--color-ink);transition:background-color var(--transition), color var(--transition), border-color var(--transition), transform var(--transition);background:0 0;border-radius:100px;padding:10px 22px;font-size:.875rem;font-weight:500;display:inline-block}.skill-pill:hover{background-color:var(--color-ink);color:var(--color-bg);border-color:var(--color-ink);transform:translateY(-3px)}.education{background-color:var(--color-bg);border-top:1px solid var(--color-border)}.education__header{flex-direction:column;display:flex}.edu-card{border-top:1px solid var(--color-border);grid-template-columns:160px 1px 1fr;align-items:start;gap:40px;padding-block:48px;display:grid}.edu-card:last-child{border-bottom:1px solid var(--color-border)}.edu-card__year{font-family:var(--font-display);letter-spacing:-.03em;color:var(--color-ink-muted);padding-top:4px;font-size:1.5rem;font-weight:700}.edu-card__divider{background:var(--color-border);width:1px;height:100%;min-height:48px}.edu-card__info{flex-direction:column;gap:8px;display:flex}.edu-card__degree{font-family:var(--font-display);letter-spacing:-.02em;color:var(--color-ink);font-size:1.375rem;font-weight:600;line-height:1.2}.edu-card__institution{color:var(--color-ink-muted);font-size:1rem}.edu-card__location{color:var(--color-ink-faint);font-size:.835rem}.projects{background-color:var(--color-bg);border-top:1px solid var(--color-border)}.projects__header{flex-direction:column;display:flex}.projects__grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.project-card{background:var(--color-bg);border:1.5px solid var(--color-border);transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);border-radius:16px;flex-direction:column;gap:16px;padding:36px;display:flex;position:relative;overflow:hidden}.project-card:after{content:"";border-radius:inherit;opacity:.22;mix-blend-mode:screen;pointer-events:none;z-index:1;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-size:150px 150px;position:absolute;inset:0}.project-card>*{z-index:2;position:relative}.project-card:hover{border-color:var(--color-ink-faint);transform:translateY(-6px);box-shadow:0 20px 48px #0006}.project-card__num{font-family:var(--font-display);letter-spacing:.1em;color:var(--color-ink-faint);font-size:.75rem;font-weight:700}.project-card__title{font-family:var(--font-display);letter-spacing:-.02em;color:var(--color-ink);font-size:1.25rem;font-weight:700;line-height:1.2}.project-card__desc{color:var(--color-ink-muted);flex:1;font-size:.9rem;line-height:1.7}.project-card__tags{flex-wrap:wrap;gap:8px;display:flex}.tag{letter-spacing:.06em;text-transform:uppercase;color:var(--color-ink-muted);background:var(--color-bg-2);border:1px solid var(--color-border);border-radius:100px;padding:4px 12px;font-size:.7rem;font-weight:600}.project-card__link{color:var(--color-ink);transition:gap var(--transition), color var(--transition);align-items:center;gap:4px;margin-top:4px;font-size:.875rem;font-weight:600;text-decoration:none;display:inline-flex}.project-card__link:hover{color:var(--color-ink-muted);gap:10px}.contact{background-color:var(--color-bg);border-top:1px solid var(--color-border)}.contact__inner{flex-direction:column;gap:24px;max-width:800px;display:flex}.contact__heading{font-family:var(--font-display);letter-spacing:-.04em;color:var(--color-ink);margin-top:8px;font-size:clamp(3rem,8vw,6.5rem);font-weight:700;line-height:1}.contact__.hero__sub{font-family:var(--font-body);color:var(--color-ink-muted);max-width:800px;font-size:clamp(1.1rem,2.5vw,1.25rem);line-height:1.5}.contact__email{font-family:var(--font-display);color:var(--color-ink);border-bottom:1.5px solid var(--color-ink-faint);transition:border-color var(--transition), color var(--transition);font-size:clamp(1rem,2.5vw,1.75rem);font-weight:400;text-decoration:none;display:inline-block}.contact__email:hover{color:var(--color-ink-muted);border-color:var(--color-ink-muted)}.contact__socials{flex-wrap:wrap;gap:32px;margin-top:16px;display:flex}.social-link{color:var(--color-ink-muted);transition:color var(--transition), gap var(--transition);align-items:center;gap:8px;font-size:.875rem;font-weight:500;text-decoration:none;display:inline-flex}.social-link svg{flex-shrink:0;width:18px;height:18px}.social-link:hover{color:var(--color-ink);gap:12px}.footer{background:var(--color-bg);border-top:1px solid var(--color-border);position:relative;overflow:hidden}.footer__cta{border-bottom:1px solid var(--color-border);padding-block:100px 80px}.footer__cta-heading{font-family:var(--font-display);letter-spacing:-.04em;color:var(--color-ink);margin-bottom:48px;font-size:clamp(3rem,9vw,8rem);font-weight:700;line-height:1}.footer__cta-btn{font-family:var(--font-body);color:var(--color-ink);transition:background-color var(--transition), color var(--transition), border-color var(--transition);border:1.5px solid #bdd2964d;border-radius:100px;align-items:center;gap:8px;padding:14px 32px;font-size:.9375rem;font-weight:500;text-decoration:none;display:inline-flex}.footer__cta-btn:hover{background-color:var(--color-ink);color:var(--color-bg);border-color:var(--color-ink)}.footer__mid{border-bottom:1px solid var(--color-border);padding-block:60px}.footer__mid-inner{justify-content:space-between;align-items:flex-start;gap:40px;display:flex}.footer__nav,.footer__socials{flex-direction:column;gap:14px;display:flex}.footer__nav-link,.footer__social-link{font-family:var(--font-body);color:var(--color-ink-muted);transition:color var(--transition);width:fit-content;font-size:.9rem;font-weight:400;text-decoration:none}.footer__nav-link:hover,.footer__social-link:hover{color:var(--color-ink)}.footer__bottom-inner{justify-content:space-between;align-items:center;display:flex}.footer__location,.footer__copy{color:var(--color-ink-faint);letter-spacing:.01em;font-size:.8125rem}.footer__bottom{padding-block:12px}.footer__brand{font-family:var(--font-display);letter-spacing:-.04em;color:var(--color-ink);opacity:.04;pointer-events:none;-webkit-user-select:none;user-select:none;text-align:center;white-space:nowrap;margin-bottom:-10px;padding-bottom:0;font-size:clamp(3rem,12vw,12rem);font-weight:700;line-height:.85;overflow:hidden}@media (width<=1100px){.fixed-logo{display:none!important}}@media (width<=1024px){:root{--section-gap:96px}.projects__grid{grid-template-columns:repeat(2,1fr)}}.mobile-dock{display:none}@media (width<=991px){:root{--section-gap:80px}.scroll-progress{display:block}body{padding-bottom:100px}.container{padding-inline:20px}.section-label,.section__title{text-align:center;width:100%}.nav__links,.btn--nav,.theme-toggle,.nav__divider,.nav__pill{display:none!important}.floating-widget{z-index:1001;bottom:100px;right:20px;transform:none;display:flex!important}.nav{width:calc(100% - 32px);top:16px}.nav__pill{justify-content:space-between;width:100%;padding:8px 16px}.mobile-dock{-webkit-backdrop-filter:blur(20px)saturate(180%);z-index:1000;background:#1c1f22cc;border:1px solid #d0ddb026;border-radius:20px;justify-content:space-around;align-items:center;width:calc(100% - 32px);max-width:400px;height:64px;padding:0 8px;transition:transform .4s cubic-bezier(.16,1,.3,1),background-color .4s;display:flex;position:fixed;top:24px;left:50%;transform:translate(-50%)translateY(0);box-shadow:0 10px 40px #0000004d}[data-theme=light] .mobile-dock{background:#fffc;border-color:#0000;overflow:hidden;box-shadow:0 4px 16px #0000000d}[data-theme=light] .mobile-dock:before{content:"";background:conic-gradient(from var(--prism-deg,0deg), #ff6b6b, #4d96ff, #6bcb77, #ff6b6b);-webkit-mask-composite:xor;opacity:.6;pointer-events:none;border-radius:20px;padding:2px;position:absolute;inset:-2px;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;-webkit-mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}[data-theme=light] .mobile-dock:after{content:"";pointer-events:none;border:1px dotted #0000001a;border-radius:20px;position:absolute;inset:0}.mobile-dock__item{color:var(--color-ink);background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:60px;padding:0;font-size:10px;font-weight:500;text-decoration:none;transition:transform .2s,opacity .2s;display:flex}.mobile-dock__item:active{transform:scale(.9)}.mobile-dock__item svg{opacity:.8;width:22px;height:22px}.mobile-dock__item span{opacity:.7}.about__grid{text-align:center;grid-template-columns:1fr;gap:32px}.about__label{padding-top:0}.about__content{align-items:center}.about__bio{font-size:1.1rem;line-height:1.5}.edu-card{text-align:center;grid-template-columns:1fr;gap:16px;padding-block:32px}.edu-card__divider{display:none}.edu-card__info{align-items:center}.hero{justify-content:flex-start;padding-top:100px}.hero__inner{gap:16px;min-height:auto;padding-block:100px 40px;padding-inline:20px}.hero__sub{margin-top:8px;font-size:1.05rem;line-height:1.4}.hero__headline{letter-spacing:-.06em;margin-bottom:8px;font-size:clamp(3rem,15vw,6rem);line-height:1}.hero__greeting{margin-bottom:-16px}.fixed-logo{display:none!important}.projects__grid{grid-template-columns:1fr;gap:32px}.footer__mid-inner{flex-direction:column;align-items:flex-start;gap:40px}.footer__brand{letter-spacing:-.03em;font-size:clamp(2rem,10vw,6rem)}}@media (width<=480px){.hero__headline{letter-spacing:-.01em;font-size:clamp(2.5rem,10vw,3.5rem)}.hero__stats{gap:20px}.contact__heading{font-size:clamp(2.5rem,12vw,4rem)}}.is-visible{opacity:1!important;transform:none!important}.footer__brand{margin-top:-10px;position:relative}.btn{transition:transform .3s cubic-bezier(.175, .885, .32, 1.275), background-color var(--transition), color var(--transition), box-shadow var(--transition)}.btn:active{transform:scale(.95)}
