@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=JetBrains+Mono:wght@400;500&display=swap";:root{--font-display: "DM Sans", system-ui, sans-serif;--font-mono: "JetBrains Mono", monospace}[data-theme=dark]{--bg: #0f1216;--text: #e6edf3;--text-muted: #8b949e;--surface: #161b22;--border: rgba(255, 255, 255, .08);--accent: #f59e0b;--accent-muted: rgba(245, 158, 11, .15)}[data-theme=light]{--bg: #fffcf8;--text: #1a1a1a;--text-muted: #5c5c5c;--surface: #f5f2ed;--border: rgba(0, 0, 0, .08);--accent: #b45309;--accent-muted: rgba(180, 83, 9, .12)}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:var(--font-display);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg);color:var(--text);transition:background .2s,color .2s}#root{min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit}.header{position:fixed;top:0;left:0;right:0;z-index:100;padding:.75rem 1.5rem;background:var(--header-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);transition:background .2s,border-color .2s}.header.dark{--header-bg: rgba(15, 18, 22, .9);--border: rgba(255, 255, 255, .06)}.header.light{--header-bg: rgba(255, 252, 248, .92);--border: rgba(0, 0, 0, .08)}.header-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.logo{font-family:var(--font-display);font-weight:700;font-size:1.25rem;color:var(--accent);text-decoration:none;letter-spacing:-.02em}.nav{display:flex;gap:.25rem}.nav-link{padding:.5rem .75rem;font-size:.9rem;font-weight:500;color:var(--text-muted);background:none;border:none;border-radius:6px;cursor:pointer;transition:color .2s,background .2s}.nav-link:hover{color:var(--text)}.nav-link.active{color:var(--accent);background:var(--accent-muted)}.header-actions{display:flex;align-items:center;gap:.5rem}.theme-toggle{padding:.4rem .6rem;font-size:1.1rem;background:var(--surface);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:transform .2s,background .2s}.theme-toggle:hover{transform:scale(1.05)}.mobile-menu-btn{display:none;flex-direction:column;gap:5px;padding:.5rem;background:none;border:none;cursor:pointer}.mobile-menu-btn span{width:22px;height:2px;background:var(--text);border-radius:1px;transition:transform .3s,opacity .3s}@media(max-width:768px){.nav{position:fixed;top:56px;left:0;right:0;flex-direction:column;padding:1rem;background:var(--header-bg);border-bottom:1px solid var(--border);gap:.25rem;transform:translateY(-100%);opacity:0;pointer-events:none;transition:transform .3s,opacity .3s}.nav.open{transform:translateY(0);opacity:1;pointer-events:auto}.nav-link{width:100%;text-align:left;padding:.75rem 1rem}.mobile-menu-btn{display:flex}}.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;padding:6rem 1.5rem 4rem;overflow:hidden}.hero-content{max-width:640px;text-align:center;position:relative;z-index:1}.hero-location{font-size:.9rem;color:var(--text-muted);margin-bottom:.5rem}.hero-name{font-family:var(--font-display);font-size:clamp(2.25rem,6vw,3.5rem);font-weight:700;letter-spacing:-.03em;line-height:1.1;color:var(--text);margin:0 0 .5rem}.hero-title{font-size:1.15rem;color:var(--accent);font-weight:600;margin:0 0 1rem}.hero-bio{font-size:1rem;color:var(--text-muted);line-height:1.6;margin:0 0 2rem}.hero-links{display:flex;flex-wrap:wrap;gap:.75rem 1.25rem;justify-content:center}.hero-link{display:inline-flex;align-items:center;padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:8px;text-decoration:none;transition:background .2s,border-color .2s,color .2s}.hero-link:hover{background:var(--accent-muted);border-color:var(--accent);color:var(--accent)}.hero-accent{position:absolute;width:60vw;height:60vw;max-width:400px;max-height:400px;top:50%;left:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,var(--accent-muted) 0%,transparent 70%);opacity:.4;pointer-events:none}.stats{padding:2.5rem 1.5rem;background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.stats-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.5rem 2rem}.stat-item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.2rem}.stat-value{font-family:var(--font-display);font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;color:var(--accent);letter-spacing:-.03em;line-height:1}.stat-label{font-size:.9rem;font-weight:600;color:var(--text);margin-top:.25rem}.stat-sublabel{font-size:.78rem;color:var(--text-muted);line-height:1.3}@media(max-width:480px){.stats-inner{grid-template-columns:repeat(2,1fr);gap:1.25rem 1rem}}.section{padding:4rem 1.5rem}.section-inner{max-width:720px;margin:0 auto}.section-title{font-family:var(--font-display);font-size:1.75rem;font-weight:700;letter-spacing:-.02em;color:var(--text);margin:0 0 1.5rem;padding-bottom:.5rem;border-bottom:2px solid var(--accent);display:inline-block}.about-narrative{display:flex;flex-direction:column;gap:1rem}.about-text{font-size:1.05rem;line-height:1.75;color:var(--text-muted);margin:0}.about-text strong{color:var(--text);font-weight:600}.currently-inner{max-width:720px}.currently-intro{font-size:1rem;color:var(--text-muted);margin:-.5rem 0 1.75rem}.currently-grid{display:flex;flex-direction:column;gap:1rem}.currently-card{display:flex;gap:1rem;align-items:flex-start;padding:1.25rem 1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:12px;transition:border-color .2s}.currently-card:hover{border-color:var(--accent)}.currently-icon{font-size:1.35rem;line-height:1;flex-shrink:0;margin-top:.1rem}.currently-body{flex:1}.currently-title{font-size:1rem;font-weight:600;color:var(--text);margin:0 0 .35rem}.currently-desc{font-size:.9rem;color:var(--text-muted);line-height:1.65;margin:0}.skills-inner{max-width:900px}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem;margin-bottom:3rem}.skill-group{padding:1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:10px}.skill-category{font-size:.95rem;font-weight:600;color:var(--accent);margin:0 0 .75rem}.skill-list{margin:0;padding-left:1.25rem;font-size:.9rem;color:var(--text-muted);line-height:1.6}.skill-list li{margin-bottom:.25rem}.open-source-title{margin-top:.5rem}.open-source{display:flex;flex-direction:column;gap:1.25rem}.open-source-block{padding:1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:10px}.open-source-heading{font-size:1rem;font-weight:600;color:var(--text);margin:0 0 .5rem}.open-source-block ul{margin:0;padding-left:1.25rem;font-size:.9rem;color:var(--text-muted);line-height:1.6}.open-source-block li{margin-bottom:.25rem}.experience-inner{max-width:720px}.timeline{display:flex;flex-direction:column;gap:2rem}.job{padding:1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:12px;border-left:3px solid var(--accent)}.job-header{margin-bottom:1rem}.job-role{font-size:1.1rem;font-weight:600;color:var(--text);margin:0 0 .25rem}.job-company{font-size:.95rem;color:var(--accent);margin:0}.job-subtitle{font-size:.85rem;color:var(--text-muted);margin:.15rem 0 0}.job-period{font-size:.85rem;color:var(--text-muted);margin:.5rem 0 0}.job-highlights{margin:0 0 .75rem;padding-left:1.25rem;font-size:.9rem;color:var(--text-muted);line-height:1.6}.job-highlights li{margin-bottom:.35rem}.job-apps{font-size:.9rem;color:var(--text-muted);margin:.75rem 0 0}.job-apps strong{color:var(--text);display:block;margin-bottom:.35rem}.job-apps-list{margin:0;padding-left:0;list-style:none}.job-apps-list li{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem .5rem;margin-bottom:.25rem}.job-app-name{font-weight:500;color:var(--text)}.job-app-links{display:inline-flex;align-items:center;gap:.35rem}.job-app-sep{color:var(--text-muted);font-weight:300}.store-link{font-size:.85rem;color:var(--accent);text-decoration:none}.store-link:hover{text-decoration:underline}.store-coming-soon{font-size:.85rem;color:var(--text-muted);font-style:italic}.education-inner{max-width:720px}.education-list{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2.5rem}.edu-card{padding:1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:10px}.edu-degree{font-size:1.05rem;font-weight:600;color:var(--text);margin:0 0 .25rem}.edu-institution{font-size:.95rem;color:var(--accent);margin:0}.edu-period{font-size:.85rem;color:var(--text-muted);margin:.5rem 0}.edu-highlights{margin:0;padding-left:1.25rem;font-size:.9rem;color:var(--text-muted);line-height:1.5}.edu-highlights li{margin-bottom:.2rem}.project-title,.achievements-title{margin-top:.5rem}.fyp-card{padding:1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:2rem}.fyp-name{font-size:1.05rem;font-weight:600;color:var(--text);margin:0 0 .5rem}.fyp-desc{font-size:.95rem;color:var(--text-muted);line-height:1.6;margin:0}.achievements-list{margin:0;padding-left:1.25rem;font-size:.95rem;color:var(--text-muted);line-height:1.7}.achievements-list li{margin-bottom:.35rem}.project-inner{max-width:860px}.project-intro{font-size:1rem;color:var(--text-muted);line-height:1.65;margin:-.5rem 0 2rem}.projects-list{display:flex;flex-direction:column;gap:2rem}.project-card{padding:2rem;background:var(--surface);border:1px solid var(--border);border-radius:14px;border-left:4px solid var(--accent);display:flex;flex-direction:column;gap:1.5rem}.project-card-header{display:flex;flex-direction:column;gap:.35rem}.project-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.project-badge{display:inline-block;font-size:.72rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.06em;background:var(--accent-muted);padding:.2rem .6rem;border-radius:4px}.project-category{font-size:.8rem;color:var(--text-muted)}.project-name{font-size:1.35rem;font-weight:700;color:var(--text);margin:.25rem 0 0;letter-spacing:-.02em}.project-subtitle{font-size:.95rem;color:var(--accent);margin:0;font-weight:500}.project-role-period{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin:.25rem 0 0}.project-role{font-size:.82rem;color:var(--text-muted)}.project-period{font-size:.82rem;color:var(--text-muted);font-family:var(--font-mono)}.project-period:before{content:"·";margin-right:.75rem;color:var(--border)}.project-case{display:flex;flex-direction:column;gap:1.25rem}.case-block{display:flex;flex-direction:column;gap:.4rem}.case-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin:0}.case-text{font-size:.92rem;color:var(--text-muted);line-height:1.7;margin:0}.case-impact-list{margin:0;padding-left:1.2rem;font-size:.92rem;color:var(--text-muted);line-height:1.65;display:flex;flex-direction:column;gap:.25rem}.project-card-footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;padding-top:1rem;border-top:1px solid var(--border)}.project-stack{display:flex;flex-wrap:wrap;gap:.4rem}.stack-tag{font-size:.76rem;font-family:var(--font-mono);color:var(--text-muted);background:var(--bg);border:1px solid var(--border);padding:.2rem .55rem;border-radius:4px}.project-store-links{display:flex;flex-wrap:wrap;gap:.5rem .75rem;flex-shrink:0;align-items:center}.project-app-group{display:flex;align-items:center;gap:.35rem}.project-app-name{font-size:.78rem;color:var(--text-muted);font-weight:500}.store-link-btn{font-size:.8rem;font-weight:600;color:var(--accent);border:1px solid var(--accent);padding:.25rem .75rem;border-radius:6px;text-decoration:none;transition:background .15s,color .15s}.store-link-btn:hover{background:var(--accent);color:var(--bg);text-decoration:none}@media(max-width:600px){.project-card{padding:1.5rem 1.25rem}.project-card-footer{flex-direction:column;align-items:flex-start}}.testimonials-inner{max-width:900px}.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem;margin-bottom:1rem}.testimonial-card{margin:0;padding:1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:12px;display:flex;flex-direction:column;gap:1rem;transition:border-color .2s}.testimonial-card:hover{border-color:var(--accent)}.testimonial-quote{font-size:.95rem;line-height:1.7;color:var(--text-muted);margin:0;position:relative;padding-left:1.25rem}.testimonial-mark{position:absolute;left:0;top:-.2rem;font-size:2rem;line-height:1;color:var(--accent);font-family:Georgia,serif;font-weight:700}.testimonial-author{display:flex;flex-direction:column;gap:.2rem;padding-top:.75rem;border-top:1px solid var(--border)}.testimonial-name{font-size:.9rem;font-weight:600;color:var(--text)}.testimonial-role{font-size:.82rem;color:var(--text-muted)}.testimonials-note{font-size:.78rem;color:var(--text-muted);font-style:italic;margin:.5rem 0 0}.contact-inner{max-width:560px;text-align:center}.contact-intro{font-size:1rem;color:var(--text-muted);margin:0 0 1.5rem}.contact-links{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:3rem}.contact-link{padding:.6rem 1.2rem;font-size:.95rem;font-weight:500;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:8px;text-decoration:none;transition:background .2s,border-color .2s,color .2s}.contact-link:hover{background:var(--accent-muted);border-color:var(--accent);color:var(--accent)}.footer{padding-top:1.5rem;border-top:1px solid var(--border)}.footer p{font-size:.85rem;color:var(--text-muted);margin:0}.app{min-height:100vh;background:var(--bg);color:var(--text)}main{padding-top:0}
