body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}html,body{overflow-x:hidden;width:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root{--text-primary: #333;--text-secondary: #666;--bg-primary: #fff;--accent: #2563eb;--border: #e5e7eb}.App{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;max-width:1200px;margin:0 auto;padding:3rem 2rem;width:100%;box-sizing:border-box}@media (max-width: 768px){.main-content{padding:2rem 1rem;max-width:100%}}@media (max-width: 768px){.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem}.hero-description{font-size:.95rem;padding:0 1rem}.hero-buttons{flex-direction:column;align-items:center;gap:1rem}.btn{width:100%;max-width:250px;text-align:center}}@media (max-width: 480px){.hero{padding:2rem 0}.hero-title{font-size:1.75rem}.hero-subtitle{font-size:.9rem}}.hero{text-align:center;padding:4rem 0}.hero-title{font-size:3rem;font-weight:700;margin-bottom:1rem}.accent-text{color:#2563eb}.hero-subtitle{font-size:1.25rem;color:#666;margin-bottom:1rem}.hero-description{max-width:700px;margin:0 auto 2rem;color:#666;line-height:1.8}.hero-buttons{display:flex;gap:1rem;justify-content:center;margin-top:2rem}.btn{padding:.75rem 1.5rem;border-radius:8px;text-decoration:none;font-weight:500;transition:all .3s ease;display:inline-block}.btn-primary{background:#2563eb;color:#fff}.btn-primary:hover{background:#1d4ed8;transform:translateY(-2px)}.btn-secondary{background:#f3f4f6;color:#333;border:1px solid #e5e7eb}.btn-secondary:hover{background:#e5e7eb}.about h1{margin-bottom:2rem;color:#333}.about-intro{margin-bottom:3rem}.about-intro p{color:#666;line-height:1.8;margin-bottom:1rem;max-width:800px}.education{margin:3rem 0}.education h2{margin-bottom:1.5rem;color:#333;font-size:1.5rem}.education-item{margin-bottom:2rem;padding:1.5rem;background:#f9fafb;border-radius:12px;border-left:3px solid #2563eb}.education-item h3{color:#333;margin-bottom:.5rem}.degree{color:#2563eb;font-weight:500;margin-bottom:.5rem}.meta{color:#666;font-size:.875rem}.skills{margin:3rem 0}.skills h2{margin-bottom:1.5rem;color:#333;font-size:1.5rem}.skill-category{margin-bottom:2rem}.skill-category h3{color:#333;font-size:1rem;margin-bottom:1rem}.skill-tags{display:flex;flex-wrap:wrap;gap:.75rem;max-width:100%}.skill-tag{padding:.5rem 1rem;background:#fff;border:1px solid #e5e7eb;border-radius:20px;color:#666;font-size:.875rem;transition:all .3s ease}.skill-tag:hover{background:#2563eb;color:#fff;border-color:#2563eb;transform:translateY(-2px)}.certifications{margin:3rem 0}.certifications h2{margin-bottom:1.5rem;color:#333;font-size:1.5rem}.certifications ul{list-style:none;padding:0}.certifications li{color:#666;position:relative;padding:.75rem 0 .75rem 1.5rem}.certifications li:before{content:"✓";position:absolute;left:0;color:#2563eb;font-weight:700}@media (max-width: 768px){.skill-tags{gap:.5rem}}.experience h1{margin-bottom:1rem;color:#333}.timeline{position:relative;padding-left:2rem;margin-bottom:3rem}.timeline:before{content:"";position:absolute;left:0;top:0;height:100%;width:2px;background:#e5e7eb}.timeline-item{position:relative;margin-bottom:3rem}.timeline-item:before{content:"";position:absolute;left:-2.4rem;top:.5rem;width:12px;height:12px;border-radius:50%;background:#2563eb;border:2px solid white;box-shadow:0 0 0 2px #e5e7eb}.timeline-content h3{margin-bottom:.5rem;color:#333}.experience-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;color:#666;font-size:.875rem}.company{font-weight:600;color:#2563eb}.separator{color:#e5e7eb}.responsibilities{list-style:none;padding:0}.responsibilities li{position:relative;padding-left:1.5rem;margin-bottom:.75rem;color:#666;line-height:1.6}.responsibilities li:before{content:"▸";position:absolute;left:0;color:#2563eb}.teaching-section{margin-top:4rem}.teaching-section h2{margin-bottom:1.5rem;color:#333}.teaching-card{background:#f9fafb;padding:1.5rem;border-radius:12px;border:1px solid #e5e7eb}.teaching-card h3{margin-bottom:.5rem;color:#333}.teaching-meta{color:#666;font-size:.875rem;margin-bottom:1rem}.teaching-card p{color:#666;line-height:1.6}@media (max-width: 768px){.timeline{padding-left:1.5rem}.timeline-item:before{left:-1.9rem}.experience-meta{flex-direction:column;gap:.25rem}.separator{display:none}}@media (max-width: 768px){.projects h1{font-size:1.75rem}.page-description{font-size:.95rem;padding:0 1rem}.projects-grid{grid-template-columns:1fr;gap:1.5rem;padding:0}}@media (max-width: 480px){.projects-grid{gap:1rem}}.projects h1{margin-bottom:1rem;color:#333}.page-description{color:#666;margin-bottom:3rem;max-width:700px}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem;margin-top:2rem;padding:0}.project-card{background:#f9fafb;padding:1.5rem;border-radius:12px;border:1px solid #e5e7eb;transition:transform .3s ease,box-shadow .3s ease}.project-card:hover{transform:translateY(-4px);box-shadow:0 10px 25px #0000001a}.project-card h3{margin-bottom:1rem;color:#333}.project-card p{color:#666;line-height:1.6;margin-bottom:1rem}.project-tech{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.tech-tag-small{padding:.25rem .75rem;background:#fff;border:1px solid #e5e7eb;border-radius:15px;font-size:.75rem;color:#666}.project-links{display:flex;gap:1rem}.project-link{color:#2563eb;text-decoration:none;font-size:.875rem;font-weight:500;transition:color .3s ease}.project-link:hover{color:#1d4ed8}@media (max-width: 768px){.navbar{padding:1rem}.nav-container{flex-direction:column;gap:1rem}.nav-logo{font-size:1.1rem}.nav-menu{gap:.75rem;flex-wrap:wrap;justify-content:center}.nav-link{font-size:.9rem;padding:.25rem .5rem}}@media (max-width: 480px){.nav-menu{width:100%;justify-content:space-around}}.navbar{background:#fff;border-bottom:1px solid #e5e7eb;padding:1rem 2rem;position:sticky;top:0;z-index:100}.nav-container{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.nav-logo{font-size:1.25rem;font-weight:600;color:#333;text-decoration:none}.nav-menu{display:flex;list-style:none;gap:2rem;margin:0;padding:0}.nav-item{list-style:none}.nav-link{color:#666;text-decoration:none;transition:color .3s ease}.nav-link:hover{color:#2563eb}@media (max-width: 768px){.nav-container{flex-direction:column;gap:1rem}.nav-menu{gap:1rem}}.footer{background:#1a1a1a;color:#fff;margin-top:auto;padding:3rem 2rem 1rem}.footer-content{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:3rem;margin-bottom:2rem}.footer-section h3{color:#fff;margin-bottom:1rem;font-size:1.5rem}.footer-section h4{color:#fff;margin-bottom:1rem;font-size:1.1rem}.footer-section p{color:#b0b0b0;line-height:1.6}.footer-links{display:flex;flex-direction:column;gap:.75rem}.footer-link{color:#b0b0b0;text-decoration:none;transition:color .3s ease;font-size:.95rem}.footer-link:hover{color:#2563eb}.footer-bottom{border-top:1px solid #333;padding-top:1.5rem;text-align:center}.footer-bottom p{color:gray;font-size:.875rem}@media (max-width: 768px){.footer{padding:2rem 1rem 1rem}.footer-content{grid-template-columns:1fr;gap:2rem;text-align:center}.footer-links{align-items:center}.footer-section h3{font-size:1.25rem}.footer-section h4{font-size:1rem}}@media (max-width: 480px){.footer-link{font-size:.9rem}}
