:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:#2b2b2b;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}a{color:#2b2b2b;-webkit-text-decoration:inherit;text-decoration:inherit;font-weight:500}a:hover{color:#b3b3b3}body{background-color:#fff;width:100%;min-width:320px;min-height:100vh;margin:0;display:block;overflow-x:hidden}h1{margin:0;font-size:3.2em;line-height:1.1}button{cursor:pointer;background-color:#1a1a1a;border:1px solid #0000;border-radius:8px;padding:.6em 1.2em;font-family:inherit;font-size:1em;font-weight:500;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme:light){:root{color:#2b2b2b;background-color:#fff}a:hover{color:#b3b3b3}button{background-color:#f9f9f9}}:root{--dusty:#2b2b2b;--lavender:#2b2b2b;--navbar-height:84px;--navbar-z:9999;--overlay-z:9998;--overcast:#b3b3b3;--paper:#fff}body,html{background:var(--paper);height:100%;color:var(--dusty);margin:0;font-family:Montserrat,Arial,Helvetica,sans-serif;overflow:hidden}.navbar{width:100vw;height:var(--navbar-height);z-index:var(--navbar-z);box-sizing:border-box;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#d4d4d4f2;justify-content:space-between;align-items:center;padding:0 3vw;display:flex;position:fixed;top:0;left:0;box-shadow:0 2px 8px #2b2b2b1a}.nav-container{justify-content:space-between;align-items:center;width:100%;max-width:1400px;margin:0 auto;display:flex}.nav-logo{color:var(--lavender);font-size:1.5rem;font-weight:800;text-decoration:none;transition:color .18s cubic-bezier(.4,0,.2,1)}.nav-logo:hover{color:var(--dusty)}.nav-links{gap:2rem;display:flex}.nav-links .nav-link{color:var(--dusty);letter-spacing:.5px;font-size:1rem;font-weight:600;text-decoration:none;transition:color .18s cubic-bezier(.4,0,.2,1);position:relative}.nav-links .nav-link:hover{color:var(--lavender)}.nav-links .nav-link:after{content:"";background:var(--lavender);width:0;height:2px;transition:width .3s;position:absolute;bottom:-4px;left:0}.nav-links .nav-link:hover:after{width:100%}.home{min-height:calc(100vh - var(--navbar-height));box-sizing:border-box;z-index:1;background:linear-gradient(120deg,#2b2b2b 0%,#fff 100%);flex-direction:column;justify-content:center;align-items:center;width:100vw;padding:0;animation:1.1s cubic-bezier(.4,0,.2,1) fadeIn;display:flex;position:relative;box-shadow:inset 0 16px 56px #2b2b2b10}.profile-photo-container{color:#999;background:linear-gradient(135deg,#e8e8e8 0%,#d0d0d0 100%);border-radius:50%;justify-content:center;align-items:center;width:clamp(220px,25vw,320px);height:clamp(220px,25vw,320px);font-size:3rem;transition:all .3s cubic-bezier(.4,0,.2,1);animation:1.2s cubic-bezier(.4,0,.2,1) .2s backwards slideInDown;display:flex;position:relative;overflow:hidden;box-shadow:0 12px 40px #2b2b2b59,0 0 0 10px #ffffffb3,inset 0 0 30px #00000026}.profile-photo-container:before{content:"📷";z-index:1;opacity:.6;font-size:4rem;position:absolute}.profile-photo-container:hover{transform:translateY(-12px);box-shadow:0 16px 48px #2b2b2b73,0 0 0 10px #fffc,inset 0 0 36px #0003}.profile-photo{object-fit:cover;width:100%;height:100%;transition:transform .3s cubic-bezier(.4,0,.2,1);display:block}.profile-photo-container:hover .profile-photo{transform:scale(1.08)}@keyframes slideInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}.hero-content{flex-direction:column;gap:2rem;display:flex}.hi-heading{letter-spacing:-4px;color:#222;text-align:left;filter:drop-shadow(2px 6px 18px #2b2b2b40);text-shadow:2px 5px 38px var(--paper),0 2px 12px #2b2b2b;margin:0 0 -.5rem;font-family:Montserrat,Arial,Helvetica,sans-serif;font-size:clamp(4.2rem,14vw,12rem);font-weight:800;line-height:1}.im-heading{letter-spacing:-4px;color:#222;text-align:left;filter:drop-shadow(2px 6px 18px #2b2b2b40);text-shadow:2px 5px 38px var(--paper),0 2px 12px #2b2b2b;margin:0 0 1.5rem;font-family:Montserrat,Arial,Helvetica,sans-serif;font-size:clamp(4.2rem,14vw,12rem);font-weight:800;line-height:1}.subtitle{color:var(--dusty);max-width:600px;margin:0;font-size:1.3rem;font-weight:500}.cta-buttons{gap:1rem;margin-top:1rem;display:flex}.cta-button{cursor:pointer;border:none;border-radius:8px;padding:.8rem 1.8rem;font-family:Montserrat,Arial,Helvetica,sans-serif;font-size:1rem;font-weight:600;text-decoration:none;transition:all .3s}.cta-button.primary{background:var(--lavender);color:#fff}.cta-button.primary:hover{background:var(--dusty);transform:translateY(-2px);box-shadow:0 6px 20px #2b2b2b4d}.cta-button.secondary{color:var(--dusty);border:2px solid var(--dusty);background:0 0}.cta-button.secondary:hover{background:var(--dusty);color:#fff;transform:translateY(-2px)}.name{color:var(--lavender);background:var(--paper);border-radius:12px;margin-left:.1em;padding:.08em .45em;font-style:italic;box-shadow:0 3px 24px #2b2b2b40}.wave-emoji{transform-origin:70% 70%;margin-bottom:.2em;margin-right:.18em;font-size:1.5em;animation:1.9s infinite wave;display:inline-block}.about-section{box-sizing:border-box;opacity:0;z-index:2;scroll-snap-align:start;background:linear-gradient(120deg,#fff 60%,#b3b3b3 100%);justify-content:center;align-items:flex-start;width:100vw;max-width:100%;min-height:100vh;padding:6rem 7vw;transition:opacity .9s cubic-bezier(.4,0,.2,1),transform .9s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow-x:hidden;transform:translate(100vw)}.about-section.visible{opacity:1;animation:.85s cubic-bezier(.2,.9,.2,1) both slideInFromRight;transform:translate(0)}.about-photo{flex:none;justify-content:center;align-items:center;min-width:300px;max-width:360px;margin-right:3rem;display:flex}.about-photo img{object-fit:cover;border-radius:12px;width:100%;max-width:360px;height:auto}.about-content{flex:auto;min-width:0;max-width:600px}.show-about,.show-work,.show-contact{overflow:hidden}.show-about .home,.show-work .home,.show-contact .home{transition:transform .85s cubic-bezier(.2,.9,.2,1);transform:translate(-100vw)}.show-about .about-section,.show-work .work-section,.show-contact .contact-section{z-index:20;transition:transform .85s cubic-bezier(.2,.9,.2,1),opacity .6s;opacity:1!important;transform:translate(0)!important}.show-about .about-section{color:var(--dusty);background:linear-gradient(120deg,#fff 40%,#e6f2ff 100%)}.show-about .about-content{color:var(--dusty)}.about-photo img{box-shadow:0 12px 40px #2b2b2b1f}.show-about .about-section{top:var(--navbar-height);width:100%;height:calc(100vh - var(--navbar-height));z-index:var(--overlay-z);box-sizing:border-box;position:fixed;left:0;overflow:hidden auto;padding:3rem 7vw!important;transform:translate(0)!important}.about-photo img{border:none}.show-work .work-section{top:var(--navbar-height);width:100%;height:calc(100vh - var(--navbar-height));z-index:var(--overlay-z);box-sizing:border-box;position:fixed;left:0;overflow:hidden auto;padding:2rem 7vw!important;transform:translate(0)!important}.show-contact .contact-section{top:var(--navbar-height);width:100%;height:calc(100vh - var(--navbar-height));z-index:var(--overlay-z);box-sizing:border-box;position:fixed;left:0;overflow:hidden auto;padding:3rem 7vw!important;transform:translate(0)!important}.show-about .about-section,.show-work .work-section,.show-contact .contact-section{overflow:hidden auto}html.show-about,body.show-about,html.show-work,body.show-work,html.show-contact,body.show-contact{height:100vh;overflow:hidden}.about-content h1{color:var(--lavender);margin:0 0 1.2rem;font-family:Montserrat,Arial,Helvetica,sans-serif;font-size:clamp(3rem,6.2vw,5rem);font-weight:800}.bio{margin-bottom:3rem}.bio p{color:var(--dusty);margin-bottom:1.2rem;font-family:Montserrat,Arial,Helvetica,sans-serif;font-size:1.18rem;line-height:1.6}.timeline{margin:2rem 0}.timeline h2{color:var(--lavender);margin-bottom:2rem;font-size:1.8rem;font-weight:700}.timeline-item{opacity:.28;border-left:3px solid #0000;gap:2rem;margin-bottom:2.5rem;padding-bottom:2rem;padding-left:2rem;transition:opacity .26s,transform .26s,color .26s;display:flex;transform:translateY(6px)}.timeline-item:last-child{border-left:none}.timeline-date{color:var(--lavender);white-space:nowrap;margin-top:.3rem;margin-left:-2.85rem;font-size:.95rem;font-weight:700;position:relative}.timeline-date:before{content:"";background:var(--lavender);border:3px solid var(--paper);border-radius:50%;width:12px;height:12px;position:absolute;top:.45rem;left:-.55rem}.timeline-content h3{color:var(--overcast);margin:0 0 .3rem;font-size:1.35rem;font-weight:700}.timeline-content .company{color:var(--overcast);margin:0 0 .8rem;font-size:.95rem;font-weight:600}.timeline-content .description{color:var(--overcast);margin:0 0 .8rem;font-size:1rem;line-height:1.6}.timeline-item.active{opacity:1;transform:translateY(0)}.timeline-item.active .timeline-content h3,.timeline-item.active .timeline-content .description,.timeline-item.active .timeline-content .company{color:var(--dusty)!important}.timeline{padding-top:1rem}.tools{color:var(--overcast);margin-top:.8rem;font-size:.85rem}.contact-links{border-top:2px solid var(--overcast);margin-top:3rem;padding-top:2rem}.contact-links h3{color:var(--dusty);margin:0 0 1rem;font-size:1rem}.contact-links ul{gap:1.5rem;margin:0;padding:0;list-style:none;display:flex}.contact-links ul li a{color:var(--lavender);font-weight:600;text-decoration:none;transition:color .18s}.contact-links ul li a:hover{color:var(--dusty)}.work-section{background:linear-gradient(120deg,var(--overcast)0%,var(--paper)100%);scroll-snap-align:start;box-sizing:border-box;opacity:0;width:100vw;min-height:auto;overflow-x:hidden;transform:translate(100vw)}.work-hero{justify-content:space-between;align-items:center;gap:2rem;padding:3rem 0 2rem;display:flex}.work-hero-content h1{color:var(--lavender);margin:0 0 .6rem;font-size:clamp(2.4rem,5vw,3.6rem)}.work-hero-figure img{object-fit:contain;opacity:.98;width:160px;height:160px}.projects-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem;margin-top:1.6rem;display:grid}.project-card{background:#fff;border-radius:12px;flex-direction:column;transition:transform .28s,box-shadow .28s;display:flex;overflow:hidden;box-shadow:0 8px 30px #2b2b2b0f}.project-image img{object-fit:cover;width:100%;height:180px;display:block}.project-body{flex-direction:column;gap:.8rem;padding:1.2rem;display:flex}.project-body h3,.project-description{color:var(--dusty);margin:0}.project-tags{flex-wrap:wrap;gap:.5rem;margin-top:.6rem;display:flex}.project-link{color:var(--lavender);margin-top:auto;font-weight:700;text-decoration:none}@media (max-width:900px){.work-hero{flex-direction:column-reverse;align-items:flex-start}.work-hero-figure img{width:120px;height:120px}}.view-all-button{border:2px solid var(--lavender);color:var(--lavender);cursor:pointer;background:0 0;border-radius:8px;margin:2rem auto 4rem;padding:.85rem 1.2rem;font-weight:700;display:inline-block}.view-all-button:hover{background:var(--lavender);color:#fff;transform:translateY(-3px)}.project-card{opacity:0;transition:opacity .36s,transform .36s cubic-bezier(.2,.9,.2,1);transform:translateY(8px)}.projects-grid .project-card{opacity:1;transform:translateY(0)}.work-section h1{color:var(--lavender);margin-bottom:1rem;font-size:clamp(2.4rem,5vw,3.5rem);font-weight:800}.work-intro{color:var(--dusty);max-width:600px;margin-bottom:3rem;font-size:1.1rem;line-height:1.6}.projects-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem;margin-bottom:3rem;display:grid}.project-card{background:#fff;border-radius:12px;flex-direction:column;padding:2rem;transition:all .3s;display:flex;box-shadow:0 4px 12px #2b2b2b1a}.project-card:hover{transform:translateY(-8px);box-shadow:0 12px 28px #2b2b2b33}.project-card h3{color:var(--lavender);margin:0 0 .8rem;font-size:1.3rem;font-weight:700}.project-description{color:var(--dusty);flex-grow:1;margin-bottom:1.5rem;font-size:.95rem;line-height:1.6}.project-tags{flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;display:flex}.tag{color:var(--lavender);background:#2b2b2b1a;border-radius:20px;padding:.3rem .8rem;font-size:.8rem;font-weight:600}.project-link{color:var(--lavender);align-self:flex-start;font-weight:600;text-decoration:none;transition:all .3s}.project-link:hover{color:var(--dusty);transform:translate(4px)}.more-work{text-align:center;padding:2rem 0}.more-work p{color:var(--dusty);font-size:1.1rem}.more-work a{color:var(--lavender);font-weight:700;text-decoration:none;transition:color .3s}.more-work a:hover{color:var(--dusty)}.contact-section{background:linear-gradient(120deg,var(--paper)0%,var(--lavender)100%);color:#fff;scroll-snap-align:start;box-sizing:border-box;opacity:0;width:100vw;overflow-x:hidden;transform:translate(100vw)}.contact-section h1{color:#fff;margin-bottom:2rem;font-size:clamp(2.4rem,5vw,3.5rem);font-weight:800}.contact-content p{color:#fffffff2;max-width:600px;margin-bottom:2rem;font-size:1.1rem;line-height:1.6}.contact-methods{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin:2rem 0;display:grid}.contact-item h3{color:#fff;margin-bottom:1rem;font-size:1.1rem;font-weight:700}.contact-link{color:#ffffffe6;font-size:1.05rem;font-weight:600;text-decoration:none;transition:all .3s}.contact-link:hover{color:#fff;transform:translate(4px)}.social-links{flex-direction:column;gap:.8rem;margin:0;padding:0;list-style:none;display:flex}.social-links li a{color:#ffffffe6;font-weight:600;text-decoration:none;transition:all .3s}.social-links li a:hover{color:#fff;transform:translate(4px)}.footer{text-align:center;border-top:1px solid #fff3;margin-top:4rem;padding-top:2rem}.footer p{color:#ffffffb3;margin:0;font-size:.9rem}main,.work-section,.contact-section{scroll-snap-align:start;padding:5vw 10vw}@keyframes fadeIn{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInFromRight{0%{opacity:0;transform:translate(100vw)}to{opacity:1;transform:translate(0)}}.scroll-hint{z-index:50;border:2px solid var(--lavender);color:var(--lavender);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.6rem;transition:transform .18s,background .18s;display:flex;position:fixed;bottom:36px;left:50%;transform:translate(-50%);box-shadow:0 6px 18px #2b2b2b14}.scroll-hint:hover{background:#b3b3b30f;transform:translate(-50%)translateY(-4px)}.scroll-hint:focus{outline:3px solid #b3b3b31f}@keyframes hintBounce{0%,to{transform:translate(-50%)translateY(0)}50%{transform:translate(-50%)translateY(-6px)}}.scroll-hint{animation:1.8s ease-in-out infinite hintBounce}.home-links{z-index:20;gap:1rem;display:flex;position:fixed;bottom:120px;left:50%;transform:translate(-50%)}.home-link{color:var(--lavender);background:#ffffffeb;border-radius:999px;padding:.5rem .9rem;font-weight:700;text-decoration:none;transition:transform .15s,background .15s;box-shadow:0 6px 18px #2b2b2b0f}.home-link:hover{background:var(--lavender);color:#fff;transform:translateY(-3px)}@media (max-width:520px){.home-links{gap:.6rem;bottom:100px}.home-link{padding:.45rem .7rem;font-size:.95rem}}@keyframes wave{0%{transform:rotate(0)}10%{transform:rotate(14deg)}20%{transform:rotate(-8deg)}30%{transform:rotate(14deg)}40%{transform:rotate(-4deg)}50%{transform:rotate(10deg)}60%,to{transform:rotate(0)}}@media (max-width:900px){.navbar{height:72px}.home{margin-top:72px;padding-left:5vw}.hi-heading{font-size:clamp(2.4rem,13vw,6.5rem)}.cta-buttons{flex-direction:column}.about-section{flex-direction:column;align-items:center;padding:3rem 4vw}.show-about .about-section{padding:2.5rem 4vw!important}.about-photo{min-width:200px;max-width:280px;margin-bottom:2rem;margin-right:0}.about-photo img{width:100%;height:auto}.about-content{max-width:100%}.about-content h1{font-size:2.7rem}.nav-links{gap:1rem}.nav-links .nav-link{font-size:.9rem}}@media (max-width:520px){.navbar{height:60px;padding:0 3vw}.nav-links{gap:.5rem}.nav-links .nav-link{font-size:.75rem}.home{margin-top:60px;padding-left:3vw}.hi-heading{font-size:clamp(1.2rem,19vw,3.2rem)}.subtitle{font-size:1rem}.cta-buttons{flex-direction:column}.about-section{padding:2rem 3vw}.show-about .about-section{padding:1.5rem 3vw!important}.about-photo{min-width:150px;max-width:200px;margin-bottom:1.5rem}.about-content{max-width:100%}.bio p{font-size:.95rem}.timeline-item{gap:1rem}.contact-methods,.projects-grid{grid-template-columns:1fr}}@media (min-width:521px) and (max-width:899px){.about-section{padding:3rem 5vw}.show-about .about-section{padding:2rem 5vw!important}.about-photo{min-width:220px;max-width:300px}}@media (min-width:1200px){.about-section{padding:6rem 5vw}.show-about .about-section{padding:3rem 5vw!important}}
