.app{min-height:100vh;display:flex;flex-direction:column}.header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem 1rem}.header-content{max-width:1000px;margin:0 auto;display:flex;align-items:center;gap:2rem;flex-wrap:wrap}.profile-image{width:150px;height:150px;border-radius:50%;object-fit:cover;border:4px solid rgba(255,255,255,.3)}.header-text h1{font-size:2.5rem;margin-bottom:.5rem}.tagline{font-size:1.2rem;opacity:.9;margin-bottom:1rem}.contact-links{display:flex;flex-wrap:wrap;gap:1rem}.contact-links a{color:#fff;opacity:.9}.contact-links a:hover{opacity:1}.container{max-width:1000px;margin:0 auto;padding:1rem;flex:1}.filter-controls{background:#fff;padding:1.5rem;border-radius:8px;margin-bottom:1.5rem;box-shadow:0 2px 4px #0000001a;position:sticky;top:0;z-index:100}.filter-row{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1rem}.filter-row:last-child{margin-bottom:0}.search-input{flex:1;min-width:200px;padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem}.search-input:focus{outline:none;border-color:#667eea}.filter-label{font-weight:500;color:#666}.tag-filters{display:flex;flex-wrap:wrap;gap:.5rem}.tag-btn{padding:.4rem .8rem;border:2px solid #e0e0e0;border-radius:20px;background:#fff;cursor:pointer;font-size:.9rem;transition:all .2s}.tag-btn:hover{border-color:#667eea}.tag-btn.active{background:#667eea;border-color:#667eea;color:#fff}.tag-mode-select{padding:.4rem .8rem;border:2px solid #e0e0e0;border-radius:6px;font-size:.9rem}.btn-clear{padding:.5rem 1rem;background:#f0f0f0;border:none;border-radius:6px;cursor:pointer;font-size:.9rem}.btn-clear:hover{background:#e0e0e0}.active-filters{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;font-size:.9rem;color:#666}.active-tag{background:#667eea;color:#fff;padding:.2rem .6rem;border-radius:12px;cursor:pointer}.section{background:#fff;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 2px 4px #0000001a}.section-title{font-size:1.5rem;color:#333;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #667eea}.tag{display:inline-block;padding:.15rem .5rem;border-radius:3px;font-size:.7rem;font-weight:500;margin-left:.25rem}.tag-research{background:#e3f2fd;color:#1565c0}.tag-software{background:#e8f5e9;color:#2e7d32}.tag-data-science{background:#fff3e0;color:#ef6c00}.tag-industry{background:#f3e5f5;color:#7b1fa2}.skill-category{margin-bottom:1.5rem}.skill-category h4{font-size:1rem;color:#555;margin-bottom:.5rem;text-transform:capitalize}.skill-list{display:flex;flex-wrap:wrap;gap:.5rem}.skill-item{background:#f0f4f8;padding:.3rem .7rem;border-radius:4px;font-size:.9rem}.education-item{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #eee}.education-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.edu-header{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.edu-degree{font-size:1.2rem;font-weight:600}.edu-dates{color:#666}.edu-institution{color:#555;margin-bottom:.5rem}.edu-thesis{font-style:italic;color:#555;margin-top:.5rem}.coursework-toggle{margin-top:1rem;padding:.5rem 1rem;background:#f0f4f8;border:none;border-radius:6px;cursor:pointer;font-size:.9rem}.coursework-toggle:hover{background:#e0e8f0}.coursework-section{margin-top:1rem;padding-top:1rem;border-top:1px dashed #ddd}.coursework-category{margin-bottom:1rem}.coursework-category h5{font-size:.9rem;color:#667eea;margin-bottom:.5rem;text-transform:capitalize}.course-item{background:#fafafa;padding:.75rem;border-radius:4px;margin-bottom:.5rem;font-size:.9rem}.course-name{font-weight:500}.course-skills{margin-top:.5rem;display:flex;flex-wrap:wrap;gap:.3rem}.course-skill{background:#e8eef4;padding:.15rem .4rem;border-radius:3px;font-size:.75rem}.experience-item{margin-bottom:1.5rem}.exp-header{display:flex;justify-content:space-between;flex-wrap:wrap;margin-bottom:.25rem}.exp-title{font-weight:600;font-size:1.1rem}.exp-dates{color:#666}.exp-institution{color:#555;margin-bottom:.75rem}.exp-project{margin-left:1rem;padding-left:1rem;border-left:3px solid #667eea;margin-bottom:1rem}.project-name{font-weight:500}.project-dates{font-size:.85rem;color:#666}.project-description{margin-top:.5rem;color:#555}.project-card{background:#fafafa;padding:1rem;border-radius:6px;margin-bottom:1rem}.project-card:last-child{margin-bottom:0}.project-header{display:flex;justify-content:space-between;flex-wrap:wrap;margin-bottom:.5rem}.project-title{font-weight:600}.project-type{font-size:.85rem;color:#666}.project-tech{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.5rem}.tech-tag{background:#e0e8f0;padding:.15rem .5rem;border-radius:3px;font-size:.8rem}.publication-item{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #eee}.publication-item:last-child{border-bottom:none}.pub-title{font-weight:500}.pub-authors{color:#555;font-size:.9rem}.pub-venue{color:#667eea;font-size:.9rem}.award-item{margin-bottom:1rem}.award-name{font-weight:500}.award-dates{color:#666;font-size:.9rem}.award-description{color:#555;font-size:.9rem}.highlight{background-color:#fff59d;padding:0 2px;border-radius:2px}.footer{background:#333;color:#fff;text-align:center;padding:1.5rem;margin-top:auto}.empty-state{text-align:center;padding:2rem;color:#666}.navbar{background:#333;padding:1rem;position:sticky;top:0;z-index:200}.nav-content{max-width:1000px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.nav-brand{color:#fff;font-size:1.25rem;font-weight:600;text-decoration:none}.nav-brand:hover{text-decoration:none;opacity:.9}.nav-links{display:flex;gap:2rem}.nav-links a{color:#fffc;text-decoration:none;font-weight:500;transition:color .2s}.nav-links a:hover,.nav-links a.active{color:#fff;text-decoration:none}.nav-links a.active{border-bottom:2px solid #667eea;padding-bottom:2px}.about-page{flex:1}.about-hero{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:4rem 2rem;text-align:center}.about-image{width:180px;height:180px;border-radius:50%;object-fit:cover;border:5px solid rgba(255,255,255,.3);margin-bottom:1.5rem}.about-intro h1{font-size:2.5rem;margin-bottom:.5rem}.about-tagline{font-size:1.2rem;opacity:.9}.about-content{max-width:800px;margin:0 auto;padding:2rem 1rem}.about-section{margin-bottom:3rem}.about-section h2{font-size:1.75rem;color:#333;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #667eea}.about-section p{color:#555;line-height:1.8;margin-bottom:1rem}.about-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-top:1.5rem}.about-card{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.about-card h3{color:#667eea;margin-bottom:.5rem;font-size:1.1rem}.about-card p{color:#666;font-size:.95rem;margin:0}.about-links{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}.about-link{display:inline-block;padding:.75rem 1.5rem;background:#667eea;color:#fff;border-radius:6px;text-decoration:none;font-weight:500;transition:background .2s}.about-link:hover{background:#5a6fd6;text-decoration:none}.about-location{color:#666;font-size:.95rem}.about-cta{text-align:center;margin-top:2rem}.btn-primary{display:inline-block;padding:1rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;text-decoration:none;font-weight:600;font-size:1.1rem;transition:transform .2s,box-shadow .2s}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66;text-decoration:none}.resume-page{flex:1}.demos-page{flex:1;background:#f5f7fa}.demos-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:3rem 2rem;text-align:center}.demos-header h1{font-size:2.5rem;margin-bottom:.5rem}.demos-header p{opacity:.9;font-size:1.1rem}.demos-container{max-width:1200px;margin:0 auto;padding:2rem 1rem;display:grid;grid-template-columns:250px 1fr;gap:2rem}.demos-sidebar{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;height:fit-content;position:sticky;top:80px}.demos-sidebar h3{font-size:1rem;color:#666;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.5px}.demo-list{list-style:none;padding:0;margin:0}.demo-item{width:100%;padding:.75rem 1rem;border:none;background:#f5f7fa;border-radius:6px;cursor:pointer;text-align:left;font-size:.95rem;margin-bottom:.5rem;transition:all .2s}.demo-item:hover{background:#e8ecf2}.demo-item.active{background:#667eea;color:#fff}.demos-note{margin-top:1.5rem;font-size:.85rem;color:#999;font-style:italic}.demo-content{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.demo-info{padding:1.5rem;border-bottom:1px solid #eee}.demo-info h2{margin-bottom:.5rem;color:#333}.demo-info p{color:#666;margin-bottom:1rem}.demo-tech{display:flex;gap:.5rem;flex-wrap:wrap}.tech-badge{background:#e8ecf2;color:#555;padding:.25rem .75rem;border-radius:20px;font-size:.85rem}.fullscreen-btn{margin-top:1rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:500;transition:transform .2s,box-shadow .2s}.fullscreen-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.demo-viewer{background:#1a1a2e;height:70vh;min-height:500px;position:relative;overflow:hidden;border-radius:8px}.demo-iframe{width:100%;height:100%;border:none;display:block}.demo-instructions{padding:1.5rem;background:#fafafa;border-top:1px solid #eee}.demo-instructions h4{font-size:.9rem;color:#666;margin-bottom:.75rem}.demo-instructions ul{list-style:none;padding:0;margin:0;display:flex;gap:2rem;flex-wrap:wrap}.demo-instructions li{font-size:.9rem;color:#555}@media (max-width: 900px){.demos-container{grid-template-columns:1fr}.demos-sidebar{position:static}.demo-instructions ul{flex-direction:column;gap:.5rem}}.filter-controls{top:60px}@media (max-width: 768px){.header-content{flex-direction:column;text-align:center}.header-text h1{font-size:2rem}.contact-links{justify-content:center}.filter-row{flex-direction:column;align-items:stretch}.search-input{min-width:auto}.nav-content{flex-direction:column;gap:1rem}.about-hero{padding:2rem 1rem}.about-intro h1{font-size:2rem}.about-cards{grid-template-columns:1fr}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;line-height:1.6;color:#333;background:#f5f7fa}a{color:#667eea;text-decoration:none}a:hover{text-decoration:underline}#root{min-height:100vh}
