@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.6;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--primary-color: #ff6b35;--primary-dark: #e55a2e;--secondary-color: #6c757d;--success-color: #28a745;--danger-color: #dc3545;--warning-color: #ffc107;--info-color: #17a2b8;--text-primary: #1a1a1a;--text-secondary: #333;--text-light: #666;--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--bg-dark: #343a40;--border-light: #e9ecef;--border-medium: #dee2e6;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-xxl: 3rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: 1rem;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .1);--shadow-md: 0 4px 8px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .1);--shadow-xl: 0 16px 32px rgba(0, 0, 0, .1)}body{margin:0;min-width:320px;min-height:100vh;color:var(--text-primary);background-color:var(--bg-primary)}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{margin-bottom:var(--spacing-md);font-weight:700;line-height:1.3}p{margin-bottom:var(--spacing-md)}a{color:var(--primary-color);text-decoration:none;transition:color .3s ease}a:hover{color:var(--primary-dark)}ul,ol{margin-bottom:var(--spacing-md)}img{max-width:100%;height:auto}button,input,textarea,select{font-family:inherit;font-size:inherit}button{cursor:pointer;border:none;background:none;transition:all .3s ease}button:focus,a:focus,input:focus,textarea:focus{outline:2px solid var(--primary-color);outline-offset:2px}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.navigation{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1rem 0;transition:all .3s ease;background-color:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 20px #0000001a}.navigation--scrolled{background-color:#fffffffa;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);box-shadow:0 2px 25px #00000026}.navigation__container{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.navigation__logo a{font-size:1.5rem;font-weight:700;text-decoration:none;color:#1a1a1a;transition:color .3s ease}.navigation__logo a:hover{color:#0056b3}.navigation__list{display:flex;list-style:none;margin:0;padding:0;gap:2rem}.navigation__item{margin:0}.navigation__link{text-decoration:none;color:#444;font-weight:500;padding:.5rem 1rem;border-radius:.5rem;transition:all .3s ease;position:relative}.navigation__link:hover{color:#0056b3;background-color:#0056b31f}.navigation__link--active{color:#0056b3;background-color:#0056b32e}.navigation__link--active:after{content:"";position:absolute;bottom:-2px;left:1rem;right:1rem;height:2px;background-color:#0056b3;border-radius:1px}@media (max-width: 768px){.navigation__container{padding:0 1rem}.navigation__list{gap:1rem}.navigation__link{padding:.5rem .75rem;font-size:.9rem}.navigation__logo a{font-size:1.25rem}}.footer{background-color:#1a1a1a;color:#f5f5f5;padding:2rem 0;text-align:center}.footer__container{max-width:1200px;margin:0 auto;padding:0 2rem}.footer__text{font-size:1rem;margin:0;color:#e0e0e0;font-weight:400}.footer__text:before{content:"";display:block;width:60px;height:2px;background:linear-gradient(90deg,#ff6b35,#e55a2e);margin:0 auto 1rem;border-radius:1px}@media (max-width: 768px){.footer{padding:1.5rem 0}.footer__container{padding:0 1rem}.footer__text{font-size:.9rem}}.home{min-height:100vh;display:flex;align-items:center;padding:6rem 2rem 2rem;background:linear-gradient(135deg,#4a5fd1,#5c3a8c);color:#fff;position:relative;overflow:hidden}.home:before{content:"";position:absolute;inset:0;background:#00000040;z-index:1}.home__container{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;position:relative;z-index:2}.home__content{animation:fadeInUp 1s ease-out}.home__title{font-size:3.5rem;font-weight:700;margin-bottom:1rem;line-height:1.2;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.home__name{color:#f95;text-shadow:3px 3px 6px rgba(0,0,0,.6)}.home__subtitle{font-size:1.75rem;font-weight:400;margin-bottom:1.5rem;color:#f5f5f5;text-shadow:1px 1px 3px rgba(0,0,0,.4)}.home__description{font-size:1.1rem;line-height:1.6;margin-bottom:2.5rem;color:#fff;max-width:500px;text-shadow:1px 1px 3px rgba(0,0,0,.4)}.home__cta{display:flex;gap:1rem;flex-wrap:wrap}.btn{padding:.75rem 1.5rem;border-radius:.5rem;text-decoration:none;font-weight:600;transition:all .3s ease;display:inline-block;border:2px solid transparent;cursor:pointer}.btn--primary{background-color:#ff6b35;color:#fff;border-color:#ff6b35;text-shadow:none;box-shadow:0 2px 8px #0003}.btn--primary:hover{background-color:#e55a2e;border-color:#e55a2e;transform:translateY(-2px);box-shadow:0 6px 16px #ff6b3566}.btn--secondary{background-color:#ffffff26;color:#fff;border-color:#fff;text-shadow:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn--secondary:hover{background-color:#fff;color:#4a5fd1;transform:translateY(-2px);box-shadow:0 6px 16px #fff6}.home__visual{display:flex;justify-content:center;align-items:center;animation:fadeInRight 1s ease-out .3s both}.home__avatar{width:300px;height:300px;border-radius:50%;overflow:hidden;border:4px solid rgba(255,255,255,.3);box-shadow:0 10px 30px #0000004d;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.home__avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:8rem;background:linear-gradient(45deg,#2196f3,#64b5f6);border-radius:50%}@media (max-width: 768px){.home{padding:6rem 1rem 2rem}.home__container{grid-template-columns:1fr;gap:2rem;text-align:center}.home__title{font-size:2.5rem}.home__subtitle{font-size:1.5rem}.home__avatar{width:200px;height:200px}.home__avatar-placeholder{font-size:5rem}.home__cta{justify-content:center}}.about{padding:5rem 2rem;background-color:#fff}.about__container{max-width:1200px;margin:0 auto}.about__header{text-align:center;margin-bottom:4rem}.section-title{font-size:2.5rem;font-weight:700;margin-bottom:1rem;color:#1a1a1a;position:relative}.section-title:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:60px;height:3px;background-color:#ff6b35;border-radius:2px}.section-subtitle{font-size:1.2rem;color:#444;max-width:600px;margin:0 auto;line-height:1.6}.about__content{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}.about__text{animation:fadeInLeft 1s ease-out}.about__skills{animation:fadeInRight 1s ease-out}.about__heading{font-size:1.5rem;font-weight:600;margin-bottom:1.5rem;color:#1a1a1a}.about__text p{font-size:1rem;line-height:1.7;color:#333;margin-bottom:1.5rem}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.skill-item{background:linear-gradient(135deg,#f8f9fa,#e9ecef);padding:1rem;border-radius:.75rem;text-align:center;box-shadow:0 3px 12px #0000001a;transition:all .3s ease;border:2px solid #dee2e6}.skill-item:hover{transform:translateY(-3px);box-shadow:0 8px 25px #ff6b3533;border-color:#ff6b35;background:linear-gradient(135deg,#fff,#f8f9fa)}.skill-name{font-weight:600;color:#1a1a1a;font-size:.95rem}@media (max-width: 768px){.about{padding:3rem 1rem}.about__content{grid-template-columns:1fr;gap:2rem}.section-title{font-size:2rem}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}}.experience{padding:5rem 2rem;background-color:#f8f9fa}.experience__container{max-width:1000px;margin:0 auto}.experience__header{text-align:center;margin-bottom:4rem}.timeline{position:relative;padding:2rem 0}.timeline:before{content:"";position:absolute;left:50%;top:0;bottom:0;width:3px;background:linear-gradient(to bottom,#ff6b35,#e55a2e);transform:translate(-50%)}.timeline-item{position:relative;margin-bottom:3rem;width:100%}.timeline-item:nth-child(odd) .timeline-content{margin-left:0;margin-right:50%;padding-right:2rem;text-align:right}.timeline-item:nth-child(2n) .timeline-content{margin-left:50%;margin-right:0;padding-left:2rem;text-align:left}.timeline-marker{position:absolute;left:50%;top:1.5rem;width:24px;height:24px;background-color:#ff6b35;border:4px solid white;border-radius:50%;transform:translate(-50%);z-index:10;box-shadow:0 0 0 4px #ff6b3540}.timeline-content{position:relative}.experience-card{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 6px 20px #0000001a;border:2px solid #e9ecef;transition:all .3s ease;animation:fadeInUp .6s ease-out}.experience-card:hover{transform:translateY(-5px);box-shadow:0 12px 30px #00000026;border-color:#ff6b35}.experience-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;flex-wrap:wrap;gap:.5rem}.experience-title{font-size:1.3rem;font-weight:700;color:#1a1a1a;margin:0}.experience-period{background-color:#ff6b35;color:#fff;padding:.3rem .8rem;border-radius:1rem;font-size:.85rem;font-weight:600;white-space:nowrap}.experience-company{font-size:1.1rem;font-weight:600;color:#444;margin:0 0 1.5rem;text-align:left}.experience-description{list-style:disc;padding-left:1.2rem;margin:0 0 1.5rem;text-align:left}.experience-description li{margin-bottom:.75rem;color:#333;line-height:1.6;text-align:left}.experience-description li::marker{color:#ff6b35}.experience-technologies{display:flex;flex-wrap:wrap;gap:.5rem}.tech-tag{background-color:#e9ecef;color:#1a1a1a;padding:.3rem .8rem;border-radius:1rem;font-size:.85rem;font-weight:500;border:1px solid #dee2e6;transition:all .3s ease}@media (max-width: 768px){.experience{padding:3rem 1rem}.timeline:before{left:1rem}.timeline-item:nth-child(odd) .timeline-content,.timeline-item:nth-child(2n) .timeline-content{margin-left:3rem;margin-right:0;padding-left:1rem;padding-right:0;text-align:left}.timeline-marker{left:1rem}.experience-card{padding:1.5rem}.experience-header{flex-direction:column;align-items:flex-start}.experience-title{font-size:1.1rem}}.teaching{padding:4.5rem 2rem;background-color:#fff}.teaching__container{max-width:800px;margin:0 auto}.teaching__header{text-align:center;margin-bottom:4rem}.teaching-grid{display:flex;flex-direction:column;gap:2rem}.teaching-card{background:#f8f9fa;padding:2rem;border-radius:12px;box-shadow:0 4px 12px #00000014;border:1px solid #e9ecef;transition:all .3s ease;animation:fadeInUp .6s ease-out}.teaching-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #0000001f;border-color:#ff6b35}.teaching-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.teaching-title-section{flex:1}.teaching-title{font-size:1.4rem;font-weight:700;color:#1a1a1a;margin:0 0 .5rem}.teaching-course{font-size:1.1rem;font-weight:600;color:#ff6b35;margin:0 0 .25rem}.teaching-institution{font-size:1rem;color:#666;margin:0}.teaching-period{background-color:#ff6b35;color:#fff;padding:.4rem 1rem;border-radius:1.2rem;font-size:.9rem;font-weight:600;white-space:nowrap;flex-shrink:0}.teaching-content{display:flex;flex-direction:column;gap:1.5rem}.teaching-description{list-style:disc;padding-left:1.2rem;margin:0;text-align:left}.teaching-description li{margin-bottom:.5rem;color:#333;line-height:1.6;text-align:left}.teaching-description li::marker{color:#ff6b35}.teaching-stats{display:flex;gap:2rem;padding:1rem;background-color:#fff;border-radius:8px;border:1px solid #e9ecef}.stat-item{text-align:center}.stat-number{display:block;font-size:2rem;font-weight:700;color:#ff6b35;line-height:1;margin-bottom:.25rem}.stat-label{font-size:.9rem;color:#666;font-weight:500}.teaching-topics{border-top:1px solid #e9ecef;padding-top:1.5rem}.topics-title{font-size:1rem;font-weight:600;color:#1a1a1a;margin:0 0 1rem}.topics-list{display:flex;flex-wrap:wrap;gap:.5rem}.topic-tag{background-color:#e9ecef;color:#1a1a1a;padding:.4rem .8rem;border-radius:1rem;font-size:.85rem;font-weight:500;border:1px solid #dee2e6;transition:all .3s ease}.topic-tag:hover{background-color:#ff6b35;color:#fff;border-color:#ff6b35}@media (max-width: 768px){.teaching{padding:3rem 1rem}.teaching-header{flex-direction:column;align-items:flex-start;gap:1rem}.teaching-card{padding:1.5rem}.teaching-title{font-size:1.2rem}.teaching-course{font-size:1rem}.teaching-stats{flex-direction:column;gap:1rem;text-align:center}.stat-number{font-size:1.5rem}}.education{padding:4.5rem 2rem;background-color:#fff}.education__container{max-width:800px;margin:0 auto}.education__header{text-align:center;margin-bottom:4rem}.education-grid{display:flex;flex-direction:column;gap:1.5rem}.education-item{padding:1.5rem 0;border-bottom:1px solid #e9ecef;transition:all .3s ease}.education-item:last-child{border-bottom:none}.education-item:hover{background-color:#fafafa;padding-left:1rem;padding-right:1rem;margin-left:-1rem;margin-right:-1rem;border-radius:8px}.education-item.bachelor{background:linear-gradient(135deg,#fff9f3,#fff);border-left:4px solid #ff6b35;padding-left:1.5rem;margin-left:-1.5rem}.education-item.bachelor:hover{background:linear-gradient(135deg,#fff5eb,#fafafa)}.education-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;flex-wrap:wrap;gap:.5rem}.education-title{font-size:1.1rem;font-weight:700;color:#1a1a1a;margin:0;flex:1;min-width:120px;line-height:1.2}.education-period{background-color:#ff6b35;color:#fff;padding:.2rem .6rem;border-radius:.75rem;font-size:.65rem;font-weight:600;white-space:nowrap;flex-shrink:0}.education-school{font-size:1rem;font-weight:600;color:#444;margin:0 0 .75rem}.education-gpa{margin-bottom:.75rem;color:#ff6b35;font-size:.85rem}.education-section{margin-bottom:.75rem}.education-section:last-child{margin-bottom:0}.education-section-title{font-size:.85rem;font-weight:600;color:#1a1a1a;margin-bottom:.5rem;border-bottom:1px solid #f1f3f4;padding-bottom:.2rem}.coursework-list{list-style:disc;padding-left:1rem;margin:0;color:#333}.coursework-list li{margin-bottom:.25rem;font-size:.8rem;line-height:1.4}@media (max-width: 768px){.education{padding:4rem 1.5rem}.education-grid{gap:1.5rem}.education-row.bachelor-row{grid-template-columns:1fr}.education-row.other-schools{grid-template-columns:1fr;gap:1.5rem}.education-card{padding:1rem;min-height:180px}.education-header{flex-direction:column;align-items:flex-start;gap:.5rem}.education-title{font-size:1rem;min-width:unset}.education-icon{font-size:1.3rem}.education-school{font-size:.9rem}}.projects{padding:5rem 2rem;background-color:#f8f9fa}.projects__container{max-width:1200px;margin:0 auto}.projects__header{text-align:center;margin-bottom:4rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem;margin-top:2rem}.project-card{background:#fff;border-radius:15px;overflow:hidden;box-shadow:0 6px 20px #0000001a;transition:all .3s ease;border:2px solid #e9ecef;animation:fadeInUp .6s ease-out}.project-card:hover{transform:translateY(-8px);box-shadow:0 16px 40px #00000026;border-color:#ff6b35}.project-image{position:relative;height:200px;overflow:hidden;background:linear-gradient(135deg,#4a5fd1,#5c3a8c)}.project-image-img{width:100%;height:100%;object-fit:cover;display:block}.project-image:after{content:"";position:absolute;inset:0;background:#0000004d;pointer-events:none;z-index:1}.project-image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:4rem;color:#fff;background:#0000001a;position:absolute;top:0;left:0}.project-overlay{position:absolute;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease;z-index:2}.project-card:hover .project-overlay{opacity:1}.project-links{display:flex;gap:1rem}.project-link{padding:.75rem 1.5rem;border-radius:.5rem;text-decoration:none;font-weight:600;transition:all .3s ease;border:2px solid;display:inline-block}.project-link--live{background-color:#ff6b35;color:#fff;border-color:#ff6b35}.project-link--live:hover{background-color:#e55a2e;border-color:#e55a2e;transform:scale(1.05)}.project-link--github{background-color:transparent;color:#fff;border-color:#fff}.project-link--github:hover{background-color:#fff;color:#333;transform:scale(1.05)}.project-content{padding:2rem}.project-title{font-size:1.5rem;font-weight:700;margin-bottom:1rem;color:#1a1a1a}.project-description{font-size:1rem;line-height:1.6;color:#333;margin-bottom:1.5rem}.project-technologies{display:flex;flex-wrap:wrap;gap:.5rem}.tech-tag{background-color:#f1f3f4;color:#1a1a1a;padding:.3rem .8rem;border-radius:1rem;font-size:.85rem;font-weight:500;border:1px solid #d1d5db;transition:all .3s ease}.tech-tag:hover{background-color:#ff6b35;color:#fff;border-color:#ff6b35}@media (max-width: 768px){.projects{padding:3rem 1rem}.projects-grid{grid-template-columns:1fr;gap:1.5rem}.project-content{padding:1.5rem}.project-links{flex-direction:column;gap:.5rem}.project-link{text-align:center;padding:.5rem 1rem}}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6;color:#333;background-color:#fff}.app{min-height:100vh}main{padding-top:0}.section{padding:5rem 2rem}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.text-center{text-align:center}.btn{display:inline-block;padding:.75rem 1.5rem;border-radius:.5rem;text-decoration:none;font-weight:600;transition:all .3s ease;border:2px solid transparent;cursor:pointer;font-size:1rem}.btn--primary{background-color:#007bff;color:#fff;border-color:#007bff}.btn--primary:hover{background-color:#0056b3;border-color:#0056b3;transform:translateY(-2px);box-shadow:0 4px 12px #007bff4d}.btn--secondary{background-color:transparent;color:#007bff;border-color:#007bff}.btn--secondary:hover{background-color:#007bff;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #007bff4d}@media (max-width: 768px){.section{padding:3rem 1rem}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes fadeInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}
