@import"https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,400;1,500;1,600&family=Inter:wght@300;400;500;600&display=swap";:root,[data-theme=dark]{--bg: #0a0a0a;--surface: #121212;--surface-2: #1a1a1a;--border: rgba(255, 255, 255, .1);--accent: #16a34a;--accent-2: #22c55e;--accent-glow: rgba(22, 163, 74, .15);--text: #ffffff;--muted: #a3a3a3;--font-display: "Playfair Display", serif;--font-body: "Inter", sans-serif;--radius: 8px;--radius-sm: 4px;--transition: .35s cubic-bezier(.4, 0, .2, 1);--max-width: 1200px}[data-theme=light]{--bg: #fafafa;--surface: #ffffff;--surface-2: #f4f4f5;--border: rgba(0, 0, 0, .08);--accent: #16a34a;--accent-2: #15803d;--accent-glow: rgba(22, 163, 74, .1);--text: #171717;--muted: #525252}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}@media(pointer:fine){html,a,button,[role=button]{cursor:none!important}}.custom-cursor-container{pointer-events:none;position:fixed;inset:0;z-index:99999}.cursor-dot-new{position:absolute;top:0;left:0;width:6px;height:6px;background:var(--accent-2);border-radius:50%;margin-top:-3px;margin-left:-3px;box-shadow:0 0 10px var(--accent-2);z-index:2}.cursor-ring-new{position:absolute;top:0;left:0;width:40px;height:40px;margin-top:-20px;margin-left:-20px;background:#ffffff08;border:1px solid rgba(108,99,255,.4);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:width .3s,height .3s,margin .3s,border-color .3s}.cursor-ring-new .cross-h,.cursor-ring-new .cross-v{position:absolute;background:var(--accent);opacity:.5}.cursor-ring-new .cross-h{width:8px;height:1px}.cursor-ring-new .cross-v{width:1px;height:8px}.cursor-ring-new .corner{position:absolute;width:4px;height:4px;border:1px solid var(--accent-2);opacity:.6}.cursor-ring-new .tr{top:8px;right:8px;border-left:0;border-bottom:0}.cursor-ring-new .bl{bottom:8px;left:8px;border-right:0;border-top:0}body:has(a:hover,button:hover,.btn:hover) .cursor-ring-new{width:60px;height:60px;margin-top:-30px;margin-left:-30px;border-color:var(--accent-2);background:#6c63ff1a}.cursor-clicking .cursor-ring-new{transform:scale(.8)!important;background:var(--accent-glow)}body{background:var(--bg);color:var(--text);font-family:var(--font-body);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;transition:background .4s ease,color .4s ease}a{color:inherit;text-decoration:none}img,canvas{display:block;max-width:100%}button{font-family:inherit;cursor:pointer;border:none;outline:none}ul{list-style:none}h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.15;letter-spacing:-.01em}h1{font-size:clamp(2.8rem,7vw,5.8rem)}h2{font-size:clamp(2.2rem,4.5vw,3.4rem);letter-spacing:-.02em}h3{font-size:clamp(1.1rem,2vw,1.5rem)}.container{max-width:var(--max-width);margin:0 auto;padding:0 2rem}.section{padding:120px 0}.section-label{display:inline-block;font-size:.8rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem;padding:.3rem .8rem;border:1px solid var(--accent);border-radius:100px;background:var(--accent-glow)}.section-title{margin-bottom:1rem;background:linear-gradient(120deg,var(--text),var(--muted));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.section-subtitle{color:var(--muted);font-size:1.1rem;max-width:560px;margin-bottom:4rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.8rem;border-radius:var(--radius-sm);font-weight:500;font-size:.95rem;transition:var(--transition);position:relative;overflow:hidden}.btn-primary{background:var(--text);color:var(--bg);border:1px solid var(--text)}.btn-primary:hover{transform:translateY(-2px);background:var(--bg);color:var(--text)}.btn-outline{background:transparent;color:var(--text);border:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.btn-outline:hover{border-color:var(--text);background:var(--surface-2);transform:translateY(-2px)}.btn-resume{background:transparent;color:var(--text);border:1px solid var(--border);text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.8rem;border-radius:var(--radius-sm);font-weight:500;font-size:.95rem;transition:var(--transition)}.btn-resume:hover{transform:translateY(-2px);border-color:var(--text);background:var(--surface-2)}:focus-visible{outline:3px solid var(--accent);outline-offset:3px;border-radius:4px}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1.2rem 0;transition:var(--transition)}.navbar.scrolled{background:#0a0e1ad9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);padding:.8rem 0}.navbar .container{display:flex;align-items:center;justify-content:space-between}.nav-logo{font-family:var(--font-display);font-size:1.5rem;font-weight:800;background:linear-gradient(135deg,var(--accent),var(--accent-2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav-links{display:flex;align-items:center;gap:2.5rem}.nav-links a{font-size:.95rem;color:var(--muted);font-weight:500;transition:color var(--transition);position:relative}.nav-links a:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--accent);border-radius:2px;transition:width var(--transition)}.nav-links a:hover{color:var(--text)}.nav-links a:hover:after{width:100%}.theme-toggle{background:var(--surface);border:1px solid var(--border);border-radius:100px;width:38px;height:38px;display:flex;align-items:center;justify-content:center;font-size:1rem;cursor:pointer;transition:var(--transition);flex-shrink:0}.theme-toggle:hover{border-color:var(--accent);box-shadow:0 0 14px var(--accent-glow);transform:scale(1.08)}.nav-cta{padding:.6rem 1.4rem;background:var(--text);color:var(--bg)!important;border:1px solid var(--text);border-radius:var(--radius-sm);font-weight:500;font-size:.9rem;transition:var(--transition)!important}.nav-cta:hover{transform:translateY(-2px);background:var(--bg);color:var(--text)!important}.nav-cta:after{display:none!important}.hamburger{display:none;flex-direction:column;gap:5px;background:transparent;padding:4px}.hamburger span{display:block;width:24px;height:2px;background:var(--text);border-radius:2px;transition:var(--transition)}.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;background:var(--bg)}.hero-bg{display:none}.hero .container{display:grid;grid-template-columns:1fr;max-width:800px;margin:0 auto;gap:4rem;align-items:center;position:relative;z-index:2;padding-top:80px}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem 1rem;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.85rem;font-weight:500;color:var(--text);margin-bottom:1.5rem}.hero-badge-dot{width:8px;height:8px;border-radius:50%;background:var(--accent)}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.hero-title{font-size:clamp(2.8rem,6vw,5.2rem);font-weight:500;font-family:var(--font-display);line-height:1.05;margin-bottom:1.5rem;letter-spacing:-.01em;color:var(--text)}.hero-title .accent{color:var(--accent);font-style:italic}.hero-subtitle{font-size:1.15rem;color:var(--muted);max-width:480px;margin-bottom:2.5rem;line-height:1.7}.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap}.hero-stats{display:flex;gap:2.5rem;margin-top:3rem}.hero-stat-num{font-family:var(--font-display);font-size:2rem;font-weight:800;background:linear-gradient(135deg,var(--accent),var(--accent-2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-stat-label{font-size:.85rem;color:var(--muted)}.hero-content{position:relative;z-index:2}.hero-canvas{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:0;pointer-events:none}#hero-canvas{width:100%!important;height:100%!important;outline:none}.about .container{display:grid;grid-template-columns:1fr 1.6fr;gap:6rem;align-items:start}.about-avatar-wrap{position:relative;width:220px;height:220px;margin-bottom:2rem;flex-shrink:0}.about-avatar-img{width:220px;height:220px;border-radius:50%;object-fit:cover;object-position:center top;box-shadow:0 0 0 4px var(--surface),0 0 0 7px var(--accent),0 0 50px #6c63ff66;display:block}.about-avatar-wrap:after{content:"";position:absolute;inset:-10px;border-radius:50%;background:conic-gradient(from 0deg,var(--accent),var(--accent-2),var(--accent));z-index:-1;opacity:.35;animation:ring-spin 8s linear infinite;filter:blur(8px)}.about-bio{color:var(--muted);font-size:1.05rem;line-height:1.8;margin-bottom:2rem}.about-strengths{display:flex;flex-direction:column;gap:1.2rem}.strength-card{display:flex;gap:1rem;align-items:flex-start;padding:1.2rem 1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:var(--transition)}.strength-card:hover{border-color:#6c63ff66;background:var(--surface-2);transform:translate(4px)}.strength-icon{font-size:1.6rem;flex-shrink:0}.strength-title{font-weight:600;margin-bottom:.25rem;font-size:1rem}.strength-desc{color:var(--muted);font-size:.88rem}.timeline{padding-top:5rem}.timeline-title{font-family:var(--font-display);font-size:1.3rem;font-weight:700;margin-bottom:2.5rem;color:var(--muted)}.research-grid{display:flex;flex-direction:column;gap:1.2rem}.research-card{padding:1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;transition:var(--transition)}.research-card:hover{border-color:var(--accent-2);transform:translateY(-4px)}.research-tags{display:flex;gap:.5rem;margin-bottom:.75rem}.research-tag{font-size:.65rem;font-weight:700;color:var(--accent-2);text-transform:uppercase;letter-spacing:.05em;background:#00d9ff1a;padding:.15rem .4rem;border-radius:4px}.research-title{font-size:1.05rem;font-weight:700;color:var(--text);margin-bottom:.4rem;line-height:1.4}.research-desc{font-size:.88rem;color:var(--muted);margin-bottom:1rem;line-height:1.6}.research-more{font-size:.75rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.05em}.timeline-items{display:flex;flex-direction:column;gap:0}.timeline-item{display:flex;gap:1.5rem;align-items:flex-start;padding-bottom:1.8rem;position:relative}.timeline-item:not(:last-child):before{content:"";position:absolute;left:55px;top:28px;bottom:0;width:1px;background:var(--border)}.timeline-year{min-width:70px;font-family:var(--font-display);font-size:.8rem;font-weight:700;color:var(--accent);padding-top:6px;text-align:right}.timeline-dot{width:12px;height:12px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:7px;box-shadow:0 0 12px var(--accent)}.timeline-event{color:var(--muted);font-size:.95rem;padding-top:4px}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:0;padding:2.5rem 2rem;position:relative;overflow:hidden;transition:border-color var(--transition),background var(--transition);cursor:pointer}.project-card:hover{border-color:var(--text);background:var(--surface-2)}.project-num{font-family:var(--font-display);font-size:3rem;font-weight:500;color:var(--border);position:absolute;top:1rem;right:1.5rem;line-height:1;-webkit-user-select:none;user-select:none}.project-title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;margin-bottom:.75rem;color:var(--text)}.project-desc{color:var(--muted);font-size:.9rem;line-height:1.65;margin-bottom:1.5rem}.project-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.tag{padding:.25rem .7rem;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.78rem;font-weight:500;color:var(--muted)}.project-links{display:flex;gap:1rem}.project-link{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;font-weight:600;color:var(--muted);transition:color var(--transition)}.project-link:hover{color:var(--accent)}.project-link svg{width:16px;height:16px}.project-story{display:flex;flex-direction:column;gap:.7rem;margin-bottom:1.5rem;padding:1.2rem 0;background:transparent;border-top:1px solid var(--border);border-bottom:1px solid var(--border);border-radius:0}.story-block{display:flex;flex-direction:column;gap:.2rem}.story-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em}.story-text{color:var(--muted);font-size:.82rem;line-height:1.55}.arch-hint{font-size:.7rem;color:var(--accent-2);font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-top:1rem;display:flex;align-items:center;gap:.4rem;opacity:.7}.arch-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.arch-label{font-size:.75rem;font-weight:800;color:var(--accent);text-transform:uppercase;letter-spacing:.1em}.arch-close{background:transparent;border:none;color:var(--muted);cursor:pointer;font-size:1rem;padding:.2rem;transition:color .2s}.arch-close:hover{color:#ff6584}.arch-svg{width:100%;height:auto;margin:1rem 0;background:#0003;border-radius:8px;padding:1rem;border:1px solid var(--border)}.shadow-glow{filter:drop-shadow(0 0 8px rgba(108,99,255,.2))}.tradeoff-block{background:#f59e0b0d!important;border-color:#f59e0b33!important;margin-top:1rem}.project-card.arch-view{grid-column:span 1;min-height:450px;border-color:var(--accent);box-shadow:0 0 30px #6c63ff26}@media(min-width:992px){.project-card.arch-view{grid-column:span 2}}.floating-email{position:fixed;bottom:0;left:0;right:0;z-index:900;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.75rem 1.5rem;background:#0a0e1aeb;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid var(--border);font-size:.85rem;color:var(--muted);transition:var(--transition);text-decoration:none}.floating-email:hover{background:#6c63ff1f;border-top-color:#6c63ff66;color:var(--text)}.floating-email-text{font-family:var(--font-body);font-size:.85rem}.floating-email-cta{padding:.3rem .9rem;background:linear-gradient(135deg,var(--accent),#8b84ff);color:#fff;border-radius:100px;font-size:.8rem;font-weight:700;margin-left:.25rem;white-space:nowrap}.fab-contact{position:fixed;right:1.5rem;bottom:4rem;z-index:950;width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#8b84ff);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 24px #6c63ff73;cursor:pointer;opacity:0;transform:scale(.8) translateY(10px);transition:opacity .3s ease,transform .3s ease,box-shadow .3s ease;pointer-events:none}.fab-contact.fab-visible{opacity:1;transform:scale(1) translateY(0);pointer-events:auto}.fab-contact:hover{box-shadow:0 6px 36px #6c63ffa6;transform:scale(1.08) translateY(-2px)}main{padding-bottom:52px}@media(min-width:769px){.floating-email{justify-content:flex-end;padding-right:6rem}}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem}.skill-category{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.8rem;transition:var(--transition)}.skill-category:hover{border-color:#6c63ff4d;background:var(--surface-2)}.skill-category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.2rem}.skill-category-title{font-family:var(--font-display);font-size:.8rem;font-weight:700;text-transform:uppercase;color:var(--muted)}.skill-level-badge{font-size:.65rem;font-weight:800;padding:.2rem .5rem;border-radius:4px;text-transform:uppercase;letter-spacing:.05em}.skill-level-badge.expert{background:#6c63ff26;color:var(--accent);border:1px solid rgba(108,99,255,.3)}.skill-level-badge.proficient{background:#94a3b81a;color:var(--muted);border:1px solid rgba(148,163,184,.2)}.skill-tags{display:flex;flex-wrap:wrap;gap:.5rem}.skill-tag{padding:.35rem .85rem;background:var(--surface-2);border:1px solid var(--border);border-radius:100px;font-size:.85rem;font-weight:500;color:var(--text);transition:var(--transition)}.skill-tag:hover{border-color:var(--accent);color:var(--accent);background:#6c63ff14;transform:translateY(-2px)}.experience-list{display:flex;flex-direction:column;gap:1.5rem;max-width:800px}.exp-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;transition:var(--transition)}.exp-card:hover{border-color:#6c63ff59;background:var(--surface-2)}.exp-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;flex-wrap:wrap;gap:.5rem}.exp-role{font-family:var(--font-display);font-size:1.1rem;font-weight:700}.exp-period{font-size:.85rem;color:var(--accent);font-weight:600;padding:.25rem .75rem;background:#6c63ff1a;border:1px solid rgba(108,99,255,.2);border-radius:100px;white-space:nowrap}.exp-company{color:var(--muted);font-size:.9rem;margin-bottom:1rem;font-weight:500}.exp-points{display:flex;flex-direction:column;gap:.4rem}.exp-point{display:flex;gap:.75rem;align-items:flex-start;color:var(--muted);font-size:.9rem;line-height:1.6}.exp-point:before{content:"▸";color:var(--accent);flex-shrink:0;font-size:.8rem;margin-top:2px}.contact-wrap{display:grid;grid-template-columns:1fr 1.2fr;gap:5rem;align-items:start}.contact-info h3{font-size:1.4rem;margin-bottom:1rem}.contact-info p{color:var(--muted);font-size:1rem;line-height:1.7;margin-bottom:2rem}.contact-meta{display:flex;flex-direction:column;gap:.8rem;margin-bottom:2rem}.contact-meta-item{display:flex;align-items:center;gap:.75rem;color:var(--muted);font-size:.95rem}.contact-meta-icon{width:36px;height:36px;border-radius:50%;background:var(--surface-2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}.social-links{display:flex;gap:.75rem}.social-link{width:44px;height:44px;border-radius:50%;background:var(--surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.95rem;transition:var(--transition)}.social-link:hover{border-color:var(--accent);background:#6c63ff1a;transform:translateY(-3px)}.contact-form{display:flex;flex-direction:column;gap:1.2rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-size:.85rem;font-weight:600;color:var(--muted);letter-spacing:.03em}.form-group input,.form-group textarea{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.85rem 1.1rem;color:var(--text);font-family:var(--font-body);font-size:.95rem;transition:border-color var(--transition),box-shadow var(--transition);outline:none;resize:none}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.form-group ::placeholder{color:#475569}.footer{border-top:1px solid var(--border);padding:2rem 0;text-align:center}.footer p{color:var(--muted);font-size:.9rem}.footer span{color:var(--accent)}.reveal{opacity:0;transform:translateY(16px);transition:opacity .45s ease,transform .45s ease}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.05s}.reveal-delay-2{transition-delay:.1s}.reveal-delay-3{transition-delay:.15s}.reveal-delay-4{transition-delay:.2s}.reveal-delay-5{transition-delay:.25s}@media(max-width:900px){.hero .container{grid-template-columns:1fr}.hero-canvas-wrap{height:320px}.about .container,.contact-wrap{grid-template-columns:1fr;gap:3rem}.projects-grid{grid-template-columns:1fr}}@media(max-width:768px){.nav-links{display:none}.nav-links.mobile-open{display:flex;flex-direction:column;position:fixed;inset:0;background:#0a0e1afa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);align-items:center;justify-content:center;gap:2.5rem;font-size:1.3rem;z-index:999}.hamburger{display:flex;z-index:1000}.section{padding:80px 0}.hero-stats{gap:1.5rem}}@media(max-width:480px){.hero-ctas{flex-direction:column}.hero-stats{flex-wrap:wrap}.skills-grid{grid-template-columns:1fr}}.contact-toast{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);background:var(--surface-2);border:1px solid var(--accent);padding:1rem 1.5rem;border-radius:50px;display:flex;align-items:center;gap:1rem;box-shadow:0 10px 40px #00000080,0 0 20px var(--accent-glow);z-index:2000;min-width:320px}.toast-icon{font-size:1.25rem}.toast-text{font-size:.9rem;color:var(--text)}.toast-text strong{color:var(--accent)}.toast-close{background:transparent;border:none;color:var(--muted);cursor:pointer;margin-left:auto;font-size:1rem}.btn-loading{opacity:.8!important;cursor:wait!important;background:linear-gradient(90deg,var(--accent),var(--accent-2),var(--accent))!important;background-size:200% 100%!important;animation:bg-slide 2s linear infinite!important}@keyframes bg-slide{0%{background-position:0% 0%}to{background-position:200% 0%}}
