:root{--bg-primary: #0a0f14;--bg-secondary: #111820;--bg-card: #161d26;--text-primary: #e8eaed;--text-secondary: #9aa0a8;--accent: #00d4aa;--accent-dim: #00d4aa22;--accent-glow: #00d4aa44;--border: #2a3440;--gradient-1: linear-gradient(135deg, #00d4aa 0%, #00a080 100%);--gradient-2: linear-gradient(180deg, transparent 0%, var(--bg-primary) 100%)}[data-theme=light]{--bg-primary: #f8f9fa;--bg-secondary: #ffffff;--bg-card: #ffffff;--text-primary: #1a1a2e;--text-secondary: #4a4a5a;--accent: #00a080;--accent-dim: #00a08022;--accent-glow: #00a08044;--border: #d0d5dd}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:"Source Serif 4",Georgia,serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.7;font-size:17px}.bg-grid{position:fixed;top:0;left:0;width:100%;height:100%;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:60px 60px;opacity:.15;pointer-events:none;z-index:0}h1{font-size:clamp(2.5rem,6vw,4rem);font-weight:600;line-height:1.1;margin-bottom:1.5rem;letter-spacing:-1px}h2{font-size:2.5rem;font-weight:600;letter-spacing:-.5px}.btn{font-family:IBM Plex Mono,monospace;font-size:.9rem;padding:1rem 2rem;border-radius:4px;text-decoration:none;transition:all .3s ease;cursor:pointer;border:none}.btn-primary{background:var(--gradient-1);color:var(--bg-primary);font-weight:600}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px var(--accent-glow)}.btn-secondary{background:transparent;color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}section{padding:6rem 0}.section-header{margin-bottom:4rem}.section-label{font-family:IBM Plex Mono,monospace;font-size:.75rem;color:var(--accent);letter-spacing:2px;text-transform:uppercase;margin-bottom:1rem}a:visited{color:#1a5276}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.fade-in{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}.fade-in.visible{opacity:1;transform:translateY(0)}@media (max-width: 768px){section{padding:4rem 0}h1{font-size:2.25rem}h2{font-size:1.75rem}}.container{max-width:1100px;margin:0 auto;padding:0 2rem;position:relative;z-index:1}nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.5rem 0;background:linear-gradient(180deg,var(--bg-primary) 0%,transparent 100%)}nav .container{display:flex;justify-content:space-between;align-items:center}.logo{font-family:IBM Plex Mono,monospace;font-weight:600;font-size:1.1rem;color:var(--accent);letter-spacing:-.5px}.nav-links{display:flex;gap:2.5rem;list-style:none}.nav-links a{font-family:IBM Plex Mono,monospace;font-size:.85rem;color:var(--text-secondary);text-decoration:none;transition:color .3s ease;letter-spacing:.5px}.nav-links a:hover,.nav-links a.active{color:var(--accent)}.nav-actions{display:flex;align-items:center;gap:1rem}.theme-toggle{background:transparent;border:1px solid var(--border);color:var(--text-secondary);padding:.5rem;border-radius:4px;cursor:pointer;font-size:1rem;line-height:1;transition:all .3s ease;display:flex;align-items:center;justify-content:center;width:36px;height:36px}.theme-toggle:hover{border-color:var(--accent);color:var(--accent)}.nav-toggle{display:none;background:transparent;border:none;color:var(--text-primary);font-size:1.5rem;cursor:pointer;padding:.5rem}.nav-toggle span{display:block;width:24px;height:2px;background:var(--text-primary);margin:5px 0;transition:all .3s ease}@media (max-width: 768px){.nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--bg-primary);flex-direction:column;padding:1rem 2rem 2rem;gap:1rem;border-bottom:1px solid var(--border)}.nav-links.open{display:flex}.nav-toggle{display:block}.nav-toggle.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.nav-toggle.open span:nth-child(2){opacity:0}.nav-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}}.hero{min-height:100vh;display:flex;align-items:center;padding:8rem 0 4rem;position:relative}.hero-content{max-width:800px}.hero-label{font-family:IBM Plex Mono,monospace;font-size:.8rem;color:var(--accent);letter-spacing:2px;text-transform:uppercase;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem}.hero-label:before{content:"";width:40px;height:1px;background:var(--accent)}.hero-subtitle{font-size:1.25rem;color:var(--text-secondary);margin-bottom:2.5rem;max-width:600px}.hero-subtitle a{color:var(--accent);text-decoration:none;border-bottom:1px solid var(--accent-dim);transition:border-color .3s ease}.hero-subtitle a:hover{border-color:var(--accent)}.hero-cta{display:flex;gap:1rem;flex-wrap:wrap}.hero-graphic{position:absolute;right:0;top:50%;transform:translateY(-50%);width:400px;height:400px;background:radial-gradient(circle at center,var(--accent-dim) 0%,transparent 70%);border-radius:50%;filter:blur(60px);opacity:.6;pointer-events:none}.hero-content>*{animation:fadeInUp .8s ease forwards;opacity:0}.hero-content>*:nth-child(1){animation-delay:.1s}.hero-content>*:nth-child(2){animation-delay:.2s}.hero-content>*:nth-child(3){animation-delay:.3s}.hero-content>*:nth-child(4){animation-delay:.4s}@media (max-width: 768px){.hero-graphic{width:250px;height:250px;right:-50px}}.about-grid{display:grid;grid-template-columns:2fr 1fr;gap:4rem;align-items:start}.about-text p{color:var(--text-secondary);margin-bottom:1.5rem}.about-text a{color:var(--accent);text-decoration:none;border-bottom:1px solid var(--accent-dim);transition:border-color .3s ease}.about-text a:hover{border-color:var(--accent)}.about-text p:first-of-type{font-size:1.15rem;color:var(--text-primary)}.stats{display:grid;gap:1.5rem}.stat{background:var(--bg-card);padding:1.5rem;border-radius:8px;border:1px solid var(--border)}.stat-number{font-family:IBM Plex Mono,monospace;font-size:2rem;color:var(--accent);font-weight:600}.stat-label{font-size:.9rem;color:var(--text-secondary);margin-top:.25rem}@media (max-width: 768px){.about-grid{grid-template-columns:1fr;gap:2rem}}.timeline{position:relative;padding-left:2rem}.timeline:before{content:"";position:absolute;left:0;top:0;bottom:0;width:1px;background:var(--border)}.timeline-item{position:relative;padding-bottom:3rem}.timeline-item:last-child{padding-bottom:0}.timeline-item:before{content:"";position:absolute;left:-2rem;top:.5rem;width:9px;height:9px;background:var(--accent);border-radius:50%;transform:translate(-4px)}.timeline-date{font-family:IBM Plex Mono,monospace;font-size:.8rem;color:var(--accent);margin-bottom:.5rem}.timeline-title{font-size:1.25rem;font-weight:600;margin-bottom:.25rem}.timeline-company{font-size:1rem;color:var(--text-secondary);margin-bottom:1rem}.timeline-description{color:var(--text-secondary);font-size:.95rem}.timeline-description ul{margin-top:.75rem;padding-left:1.25rem}.timeline-description li{margin-bottom:.5rem}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.skill-card{background:var(--bg-card);padding:2rem;border-radius:8px;border:1px solid var(--border);transition:all .3s ease}.skill-card:hover{border-color:var(--accent);transform:translateY(-4px)}.skill-icon{font-family:IBM Plex Mono,monospace;font-size:1.5rem;color:var(--accent);margin-bottom:1rem}.skill-title{font-size:1.1rem;font-weight:600;margin-bottom:.75rem}.skill-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.skill-tag{font-family:IBM Plex Mono,monospace;font-size:.7rem;padding:.3rem .6rem;background:var(--accent-dim);color:var(--accent);border-radius:3px}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.project-card{background:var(--bg-card);border-radius:8px;border:1px solid var(--border);overflow:hidden;transition:all .3s ease}.project-card:hover{border-color:var(--accent);transform:translateY(-4px)}.project-header{padding:1.5rem;border-bottom:1px solid var(--border)}.project-platform{font-family:IBM Plex Mono,monospace;font-size:.7rem;color:var(--accent);letter-spacing:1px;text-transform:uppercase;margin-bottom:.5rem}.project-title{font-size:1.15rem;font-weight:600}.project-body{padding:1.5rem}.project-description{color:var(--text-secondary);font-size:.95rem;margin-bottom:1rem}.project-link{font-family:IBM Plex Mono,monospace;font-size:.85rem;color:var(--accent);text-decoration:none;display:inline-flex;align-items:center;gap:.5rem}.project-link:hover{text-decoration:underline}.publication-item{padding:1.5rem 0;border-bottom:1px solid var(--border)}.publication-item:last-child{border-bottom:none}.publication-title{font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.publication-meta{font-family:IBM Plex Mono,monospace;font-size:.85rem;color:var(--accent)}.contact-content{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}.contact-info p{color:var(--text-secondary);margin-bottom:2rem;font-size:1.1rem}.contact-links{display:flex;flex-direction:column;gap:1rem}.contact-link{display:flex;align-items:center;gap:1rem;color:var(--text-primary);text-decoration:none;font-family:IBM Plex Mono,monospace;font-size:.95rem;transition:color .3s ease}.contact-link:hover{color:var(--accent)}.contact-link-icon{width:40px;height:40px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.1rem}@media (max-width: 768px){.contact-content{grid-template-columns:1fr;gap:2rem}}footer{padding:3rem 0;border-top:1px solid var(--border);text-align:center}footer p{font-family:IBM Plex Mono,monospace;font-size:.85rem;color:var(--text-secondary);margin-bottom:.5rem}footer p:last-child{margin-bottom:0}footer a{color:var(--accent);text-decoration:none;transition:opacity .3s ease}footer a:hover{opacity:.8}
