@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@300;400;500;600&family=Mr+De+Haviland&display=swap";:root{--bg-primary: #090909;--bg-surface: #111111;--bg-elevated: #1a1a1a;--bg-card: #141414;--text-primary: #f0f0f0;--text-secondary: #a0a0a0;--text-muted: #606060;--accent: #ffffff;--accent-dim: rgba(255, 255, 255, .08);--accent-hover: rgba(255, 255, 255, .12);--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .16);--font-heading: "Space Grotesk", -apple-system, sans-serif;--font-body: "Inter", -apple-system, sans-serif;--font-signature: "Mr De Haviland", cursive;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 2rem;--text-4xl: 2.75rem;--text-5xl: 3.75rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-6: 1.5rem;--space-8: 2rem;--space-12: 3rem;--space-16: 4rem;--space-24: 6rem;--max-width: 1100px;--header-height: 64px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--ease-fast: .15s cubic-bezier(.4, 0, .2, 1);--ease-normal: .25s cubic-bezier(.4, 0, .2, 1);--ease-slow: .4s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;scroll-padding-top:var(--header-height)}body{font-family:var(--font-body);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600;line-height:1.2;color:var(--text-primary)}a{color:inherit;text-decoration:none;transition:color var(--ease-fast)}ul,ol{list-style:none}img{max-width:100%;height:auto;display:block}button{cursor:pointer;border:none;background:none;font:inherit}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 var(--space-6)}.section{padding:var(--space-24) 0}.section-title{font-family:var(--font-heading);font-size:var(--text-3xl);font-weight:700;margin-bottom:var(--space-12);letter-spacing:-.02em;position:relative;display:inline-block}.section-title:after{content:"";position:absolute;bottom:-8px;left:0;width:32px;height:2px;background-color:var(--accent)}.section-header{margin-bottom:var(--space-12)}.section-title--center{display:block;text-align:center}.section-title--center:after{left:50%;transform:translate(-50%)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{background:#fff3;color:var(--text-primary)}.header{position:fixed;top:0;left:0;right:0;height:var(--header-height);z-index:1000;transition:background-color var(--ease-normal),border-color var(--ease-normal);border-bottom:1px solid transparent}.header.scrolled{background-color:#090909eb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom-color:var(--border)}.header-content{height:100%;display:flex;align-items:center;justify-content:space-between}.logo{font-family:var(--font-signature);font-size:2.2rem;color:var(--text-primary);transition:opacity var(--ease-fast);padding-bottom:5px}.logo:hover{opacity:.8}.nav-list{display:flex;align-items:center;gap:var(--space-8)}.nav-link{font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);letter-spacing:.04em;text-transform:uppercase;transition:color var(--ease-fast);position:relative;padding-bottom:2px}.nav-link:after{content:"";position:absolute;bottom:0;left:0;width:0;height:1px;background-color:var(--accent);transition:width var(--ease-normal)}.nav-link:hover{color:var(--text-primary)}.nav-link:hover:after{width:100%}.nav-resume-btn{font-size:var(--text-sm);font-weight:500;color:var(--text-primary);padding:var(--space-2) var(--space-4);border:1px solid var(--border-strong);border-radius:var(--radius-sm);transition:all var(--ease-fast);letter-spacing:.04em;text-transform:uppercase}.nav-resume-btn:hover{background-color:var(--accent);color:var(--bg-primary);border-color:var(--accent)}.nav-toggle{display:none;flex-direction:column;gap:5px;padding:var(--space-2);background:none;border:none;cursor:pointer}.nav-toggle span{display:block;width:22px;height:1.5px;background-color:var(--text-primary);transition:all var(--ease-normal);transform-origin:center}.nav-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}.nav-toggle.open span:nth-child(2){opacity:0}.nav-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding-top:var(--header-height)}.hero:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.04) 1px,transparent 1px);background-size:32px 32px;pointer-events:none}.hero:after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 40%,var(--bg-primary) 100%);pointer-events:none}.hero-content{position:relative;z-index:1;max-width:780px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-6)}.hero-image{position:relative;width:150px;height:150px;margin-bottom:var(--space-2);border:1px solid var(--border-strong);border-radius:50%;padding:4px}.profile-pic{position:relative;z-index:1;width:140px;height:140px;border-radius:50%;object-fit:cover;object-position:center top;filter:grayscale(15%);transform:translateZ(0);left:50%;top:50%;transform:translate(-50%,-50%)}.hero-eyebrow{font-size:var(--text-sm);font-weight:500;color:var(--text-muted);letter-spacing:.12em;text-transform:uppercase}.hero-name{font-family:var(--font-heading);font-size:clamp(2.5rem,7vw,4.5rem);font-weight:700;letter-spacing:-.03em;line-height:1;color:var(--text-primary)}.hero-tagline{font-size:var(--text-lg);color:var(--text-secondary);font-weight:400;min-height:1.6em}.cursor-blink{display:inline-block;width:2px;height:1.1em;background-color:var(--text-primary);margin-left:2px;vertical-align:text-bottom;animation:blink 1s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-actions{display:flex;gap:var(--space-4);flex-wrap:wrap;justify-content:center}.btn-primary{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);background-color:var(--accent);color:var(--bg-primary);font-family:var(--font-heading);font-size:var(--text-sm);font-weight:600;letter-spacing:.04em;text-transform:uppercase;border-radius:var(--radius-sm);transition:all var(--ease-fast);border:1px solid var(--accent)}.btn-primary:hover{background-color:transparent;color:var(--accent)}.btn-secondary{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);background-color:transparent;color:var(--text-primary);font-family:var(--font-heading);font-size:var(--text-sm);font-weight:600;letter-spacing:.04em;text-transform:uppercase;border-radius:var(--radius-sm);border:1px solid var(--border-strong);transition:all var(--ease-fast)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.hero-scroll-hint{position:absolute;bottom:var(--space-8);left:50%;transform:translate(-50%);z-index:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-2);color:var(--text-muted);font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;animation:float 2s ease-in-out infinite}.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--text-muted),transparent)}@keyframes float{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(6px)}}.about{background-color:var(--bg-surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.about-grid{display:grid;grid-template-columns:1fr 2fr;gap:var(--space-16);align-items:center}.about-label{font-size:var(--text-xs);font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:var(--space-4)}.about-text{font-size:var(--text-lg);color:var(--text-secondary);line-height:1.8}.about-text strong{color:var(--text-primary);font-weight:500}.about-meta{margin-top:var(--space-8);display:flex;flex-direction:column;gap:var(--space-3)}.about-meta-item{display:flex;align-items:flex-start;gap:var(--space-3);font-size:var(--text-sm);color:var(--text-secondary)}.about-meta-dot{width:6px;height:6px;border-radius:50%;background-color:var(--text-muted);flex-shrink:0;margin-top:6px}.experience{background-color:var(--bg-primary)}.experience-cols{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-16)}.exp-col-title{font-size:var(--text-xs);font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:var(--space-8);padding-bottom:var(--space-4);border-bottom:1px solid var(--border)}.edu-list{display:flex;flex-direction:column;gap:var(--space-6)}.edu-card{padding:var(--space-6);background-color:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);transition:border-color var(--ease-fast)}.edu-card:hover{border-color:var(--border-strong)}.edu-period{font-size:var(--text-xs);font-weight:600;letter-spacing:.08em;color:var(--text-muted);text-transform:uppercase;margin-bottom:var(--space-2)}.edu-institution{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-1)}.edu-subtitle{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-3)}.edu-degree{font-size:var(--text-sm);color:var(--text-secondary);font-style:italic}.activity-list{display:flex;flex-direction:column;gap:0}.activity-item{display:flex;gap:var(--space-4);padding:var(--space-6) 0;border-bottom:1px solid var(--border);position:relative}.activity-item:first-child{padding-top:0}.activity-item:last-child{border-bottom:none}.activity-index{font-family:var(--font-heading);font-size:var(--text-xs);color:var(--text-muted);font-weight:600;min-width:24px;padding-top:2px}.activity-title{font-family:var(--font-heading);font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-1)}.activity-org{font-size:var(--text-xs);color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:var(--space-2)}.activity-desc{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.7}.projects{background-color:var(--bg-surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1px;background-color:var(--border);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.project-card{background-color:var(--bg-card);padding:var(--space-8);display:flex;flex-direction:column;gap:var(--space-4);transition:background-color var(--ease-normal);position:relative;overflow:hidden}.project-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--border-strong),transparent);opacity:0;transition:opacity var(--ease-normal)}.project-card:hover{background-color:var(--bg-elevated)}.project-card:hover:before{opacity:1}.project-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-4)}.project-period{font-size:var(--text-xs);font-weight:600;letter-spacing:.08em;color:var(--text-muted);text-transform:uppercase;white-space:nowrap}.project-title{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.project-description{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.7;flex:1}.project-tech{display:flex;flex-wrap:wrap;gap:var(--space-2)}.tech-tag{font-size:var(--text-xs);font-weight:500;color:var(--text-muted);padding:3px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);letter-spacing:.04em;transition:all var(--ease-fast)}.project-card:hover .tech-tag{border-color:var(--border-strong);color:var(--text-secondary)}.project-links{display:flex;gap:var(--space-4);padding-top:var(--space-2);border-top:1px solid var(--border)}.project-link{display:inline-flex;align-items:center;gap:6px;font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);transition:color var(--ease-fast);letter-spacing:.02em}.project-link:hover{color:var(--text-primary)}.project-link svg{width:14px;height:14px}.techstack{background-color:var(--bg-primary)}.skills-grid{display:flex;flex-direction:column;gap:var(--space-8)}.skill-category{display:flex;gap:var(--space-8);padding-bottom:var(--space-8);border-bottom:1px solid var(--border);align-items:flex-start}.skill-category:last-child{border-bottom:none;padding-bottom:0}.skill-category-name{font-size:var(--text-xs);font-weight:600;letter-spacing:.12em;color:var(--text-muted);text-transform:uppercase;min-width:140px;padding-top:4px}.skill-pills{display:flex;flex-wrap:wrap;gap:var(--space-2);flex:1}.skill-pill{font-family:var(--font-heading);font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);padding:var(--space-2) var(--space-4);background-color:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);transition:all var(--ease-fast);letter-spacing:.01em}.skill-pill:hover{background-color:var(--bg-elevated);border-color:var(--border-strong);color:var(--text-primary);transform:translateY(-1px)}.contact{background-color:var(--bg-surface);border-top:1px solid var(--border)}.contact-inner{max-width:640px}.contact-heading{font-family:var(--font-heading);font-size:clamp(1.75rem,4vw,3rem);font-weight:700;letter-spacing:-.03em;line-height:1.1;margin-bottom:var(--space-6);color:var(--text-primary)}.contact-heading em{font-style:normal;color:var(--text-muted)}.contact-text{font-size:var(--text-lg);color:var(--text-secondary);line-height:1.7;margin-bottom:var(--space-12)}.contact-links{display:flex;flex-wrap:wrap;gap:var(--space-3)}.contact-link{display:inline-flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-6);background-color:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);letter-spacing:.02em;transition:all var(--ease-fast)}.contact-link:hover{border-color:var(--border-strong);color:var(--text-primary);background-color:var(--bg-elevated)}.contact-link-icon{width:16px;height:16px;opacity:.7;transition:opacity var(--ease-fast);object-fit:contain}.contact-link:hover .contact-link-icon{opacity:1}.contact-email-cta{display:inline-flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-8);background-color:var(--accent);color:var(--bg-primary);font-family:var(--font-heading);font-size:var(--text-base);font-weight:600;border-radius:var(--radius-sm);border:1px solid var(--accent);transition:all var(--ease-fast);letter-spacing:.02em}.contact-email-cta:hover{background-color:transparent;color:var(--accent)}.footer{background-color:var(--bg-primary);padding:var(--space-8) 0;border-top:1px solid var(--border)}.footer-content{display:flex;align-items:center;justify-content:space-between}.footer-text{font-size:var(--text-xs);color:var(--text-muted);letter-spacing:.04em}.footer-links{display:flex;gap:var(--space-6)}.footer-link{font-size:var(--text-xs);color:var(--text-muted);letter-spacing:.04em;transition:color var(--ease-fast)}.footer-link:hover{color:var(--text-primary)}@media(max-width:900px){.about-grid{grid-template-columns:1fr;gap:var(--space-8)}.experience-cols{grid-template-columns:1fr;gap:var(--space-12)}.skill-category{flex-direction:column;gap:var(--space-4)}.skill-category-name{min-width:unset}}@media(max-width:640px){.container{padding:0 var(--space-4)}.section{padding:var(--space-16) 0}.nav-list{display:none;flex-direction:column;position:fixed;top:var(--header-height);left:0;right:0;bottom:0;background-color:#090909fa;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);align-items:center;justify-content:center;gap:var(--space-8);z-index:999}.nav-list.open{display:flex}.nav-link{font-size:var(--text-xl)}.nav-toggle{display:flex}.nav-resume-btn{display:none}.projects-grid{grid-template-columns:1fr}.hero-name{font-size:2.5rem}.footer-content{flex-direction:column;gap:var(--space-4);text-align:center}.contact-links{flex-direction:column}.contact-link{justify-content:center}}@keyframes fadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:fadeUp .6s var(--ease-normal) both}.fade-up--delay-1{animation-delay:.1s}.fade-up--delay-2{animation-delay:.2s}.fade-up--delay-3{animation-delay:.3s}.fade-up--delay-4{animation-delay:.4s}
