@import"https://fonts.googleapis.com/css2?family=Newsreader:ital,opsz,wght@0,6..72,400;0,6..72,600;0,6..72,700;1,6..72,400&family=Inter:wght@400;500&display=swap";:root{--bg: #faf9f6;--text: #1a1a1a;--text-muted: #5c5c5c;--border: #e0ddd6;--accent: #ff5f05;--max-width: 42rem;--header-height: 3.5rem}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:calc(var(--header-height) + 1rem)}body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:1rem;line-height:1.7;-webkit-font-smoothing:antialiased;display:flex;flex-direction:column;min-height:100vh}h1,h2,h3,.site-title{font-family:Newsreader,Georgia,Times New Roman,serif;font-weight:600;line-height:1.25}h1{font-size:1.75rem;margin:0 0 1.25rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.site-header{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;height:var(--header-height);padding:0 1.5rem;background:var(--bg);border-bottom:1px solid var(--border)}.site-title{font-size:1.125rem;color:var(--text);text-decoration:none;white-space:nowrap}.site-title:hover{color:var(--accent);text-decoration:none}.site-nav{display:flex;flex-wrap:wrap;gap:.25rem 1.25rem;justify-content:flex-end}.site-nav a{font-size:.875rem;color:var(--text-muted);text-decoration:none}.site-nav a:hover,.site-nav a[aria-current=page]{color:var(--accent);text-decoration:none}main{flex:1;padding:2.5rem 1.5rem 4rem}.main-home{display:block;padding:2.5rem 0 2rem;max-width:none;margin:0;width:100%}.main-home .hero-home{max-width:var(--max-width);margin-left:auto;margin-right:auto;padding-left:1.5rem;padding-right:1.5rem}.main-home~footer .footer-label{display:none}.main-home~footer{padding-top:1.5rem;padding-bottom:1.75rem}.gallery-vertical{display:flex;flex-direction:column;gap:2.25rem;margin-top:2rem}.gallery-section-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;max-width:var(--max-width);margin:0 auto .75rem;padding:0 1.5rem}.gallery-section-header h2{font-family:Inter,sans-serif;font-size:.6875rem;font-weight:500;text-transform:uppercase;letter-spacing:.14em;color:var(--text-muted);margin:0;padding:0;border:none}.gallery-section-link{font-size:.6875rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);text-decoration:none;opacity:.6}.gallery-section-link:hover{color:var(--text);opacity:1;text-decoration:none}.gallery-section{width:100%}.gallery-marquee{overflow:hidden;width:100%;padding-inline:1.5rem}.gallery-marquee-track{display:flex;gap:3rem;width:max-content;padding:.25rem 0;will-change:transform;animation:gallery-marquee-scroll var(--marquee-duration, 40s) linear infinite}.gallery-marquee-reverse .gallery-marquee-track{animation-direction:reverse}@keyframes gallery-marquee-scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.gallery-marquee-track .gallery-card{flex:0 0 clamp(140px,26vw,200px);width:clamp(140px,26vw,200px)}@media (min-width: 1024px){.gallery-marquee-track .gallery-card{flex:0 0 200px;width:200px}.gallery-marquee-track{gap:3.5rem}}@media (prefers-reduced-motion: reduce){.gallery-marquee{overflow-x:auto}.gallery-marquee-track{animation:none}}.gallery-card{display:flex;flex-direction:column;align-items:center;gap:.625rem;text-decoration:none;color:inherit}.gallery-card:hover{text-decoration:none}.gallery-card-visual{display:flex;align-items:center;justify-content:center;width:100%;height:clamp(72px,16vw,96px)}.gallery-card-visual-media{overflow:hidden;border-radius:6px;background:#1a1a1a}.gallery-video{display:block;width:100%;height:100%;object-fit:cover}.gallery-logo{display:block;max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;opacity:1;transition:transform .3s ease,opacity .3s ease}.gallery-card:hover .gallery-logo{transform:scale(1.05)}.gallery-monogram{font-family:Inter,sans-serif;font-size:.875rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);opacity:.85;transition:opacity .3s ease}.gallery-card:hover .gallery-monogram{opacity:1}.gallery-card-text{width:100%;text-align:center}.gallery-label{display:block;font-family:Inter,sans-serif;font-size:.6875rem;font-weight:400;color:var(--text);line-height:1.3;letter-spacing:.02em;opacity:.8;transition:opacity .3s ease}.gallery-desc{display:block;max-height:0;overflow:hidden;font-size:.625rem;color:var(--text-muted);margin-top:0;line-height:1.35;opacity:0;transition:max-height .4s ease,opacity .4s ease,margin-top .4s ease}.gallery-card:hover .gallery-label{color:var(--text);opacity:1}.gallery-card:hover .gallery-desc{max-height:2.5rem;margin-top:.2rem;opacity:.7}.page{max-width:var(--max-width);margin:0 auto}section{padding:0}.page section{padding:0}h2{font-size:1.25rem;margin:0 0 .5rem;padding-bottom:0;border-bottom:none}h3{font-size:1.125rem;margin:0 0 .5rem}p{margin:0 0 1rem}p:last-child{margin-bottom:0}strong{font-weight:500}.hero{text-align:center}.hero-home{width:100%;max-width:var(--max-width);margin:0 auto;padding-bottom:.5rem}.main-home .profile-photo-lg{width:112px;height:112px;border:none;margin-bottom:1rem;opacity:.92}.main-home .hero h1{font-size:2.25rem;font-weight:600;letter-spacing:-.02em}.main-home .tagline{font-size:.9375rem;letter-spacing:.02em;opacity:.7}.profile-photo{width:96px;height:96px;border-radius:50%;object-fit:cover;margin-bottom:1.25rem;border:2px solid var(--border)}.profile-photo-lg{width:128px;height:128px}.hero h1{font-size:2.75rem;margin:0 0 .5rem;padding-bottom:0;border-bottom:none}.tagline{font-size:1.125rem;color:var(--text-muted);margin:0}.education-header{display:flex;align-items:flex-start;gap:1.5rem}.education-text{flex:1;min-width:0}.education-logo{flex-shrink:0;width:64px;height:auto}.project,.experience-card{scroll-margin-top:calc(var(--header-height) + 1rem)}.project{margin-bottom:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid var(--border)}.project:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.project-meta{font-weight:400;color:var(--text-muted);font-size:.9375rem}.project-links{margin-bottom:.5rem}.project-links a{margin-right:1rem;font-size:.875rem}.project-links i{font-size:.75em}.project-stack{font-size:.875rem;color:var(--text-muted);margin-bottom:1rem}.media{margin:1.25rem 0}.media iframe,.media video{display:block;width:100%;aspect-ratio:16 / 9;border:none;border-radius:6px;background:#eee}.experience-card{display:flex;align-items:flex-start;gap:1.5rem;margin-bottom:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid var(--border)}.experience-card:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.experience-text{flex:1;min-width:0}.experience-text h3{margin-bottom:.25rem}.role{font-size:.9375rem;color:var(--text-muted);margin-bottom:1rem}.experience-logo{flex-shrink:0;width:72px;height:72px;object-fit:contain;border-radius:6px;border:1px solid var(--border);padding:8px;background:#fff}footer{border-top:1px solid var(--border);padding:2rem 1.5rem;text-align:center}.footer-label{font-family:Newsreader,Georgia,serif;font-size:.875rem;color:var(--text-muted);margin:0 0 .75rem}.social-links{display:flex;justify-content:center;gap:1.5rem}.social-links a{color:var(--text-muted);font-size:1.25rem;text-decoration:none}.social-links a:hover{color:var(--accent);text-decoration:none}.contact-intro{color:var(--text-muted);margin-bottom:1.5rem}.contact-list{list-style:none;padding:0;margin:0}.contact-list li{margin-bottom:.75rem}.contact-list a{display:inline-flex;align-items:center;gap:.5rem;font-size:1rem}.contact-list i{width:1.25rem;text-align:center;color:var(--text-muted)}@media (max-width: 640px){.site-header{flex-direction:column;align-items:flex-start;height:auto;padding:.875rem 1rem;gap:.75rem}.site-nav{justify-content:flex-start}.main-home{padding:2rem 0 1.5rem}.main-home .hero-home{padding-left:1rem;padding-right:1rem}.gallery-section-header{padding:0 1rem}.gallery-vertical{margin-top:1.5rem;gap:1.75rem}.gallery-marquee-track{gap:2.25rem}.gallery-marquee-track .gallery-card{flex-basis:36vw;width:36vw}main{padding:1.5rem 1rem 3rem}.main-home .profile-photo-lg{width:96px;height:96px}.main-home .hero h1{font-size:1.875rem}.experience-card{flex-direction:column-reverse;align-items:center;text-align:center}.experience-logo{width:64px;height:64px}.education-header{flex-direction:column-reverse;align-items:center;text-align:center}.education-logo{width:56px}}
