@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,300&family=DM+Mono:wght@400;500&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f0a0a;--surface:#1a1212;--card:#241818;--border:#3d1f1f;--border2:#4d2828;--cyan:#a03333;--cyan2:#8a2828;--gold:#c9b896;--text:#f5efe6;--muted:#a89484;--dim:#6f5c4d;--white:#fff;--green:#7a8a65;--purple:#b86b6b}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:DM Sans,sans-serif;line-height:1.6;overflow-x:hidden}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}nav{z-index:100;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);background:#0f0a0ad9;justify-content:space-between;align-items:center;padding:1rem 3rem;display:flex;position:fixed;top:0;left:0;right:0}.nav-logo{letter-spacing:.08em;color:var(--cyan);font-family:Space Grotesk,sans-serif;font-size:1.1rem;font-weight:800}.nav-logo span{color:var(--gold)}.nav-links{gap:2rem;list-style:none;display:flex}.nav-links a{letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-size:.8rem;font-weight:500;text-decoration:none;transition:color .2s}.nav-links a:hover{color:var(--cyan)}#hero{align-items:center;min-height:100vh;padding:6rem 3rem 4rem;display:flex;position:relative;overflow:hidden}.hero-grid{background-image:linear-gradient(var(--border) 1px, transparent 1px), linear-gradient(90deg, var(--border) 1px, transparent 1px);opacity:.18;background-size:60px 60px;position:absolute;inset:0}.hero-glow{pointer-events:none;background:radial-gradient(circle,#a033331f 0%,#0000 65%);width:700px;height:700px;position:absolute;top:-20%;left:30%}.hero-glow2{pointer-events:none;background:radial-gradient(circle,#c9b89614 0%,#0000 65%);width:500px;height:500px;position:absolute;bottom:-10%;right:-5%}.hero-inner{z-index:1;grid-template-columns:1fr 360px;align-items:center;gap:4rem;width:100%;max-width:1200px;margin:0 auto;display:grid;position:relative}.hero-eyebrow{letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);align-items:center;gap:.75rem;margin-bottom:1.2rem;font-family:DM Mono,monospace;font-size:.78rem;display:flex}.hero-eyebrow:before{content:"";background:var(--cyan);width:36px;height:1px;display:block}.hero-name{letter-spacing:-.02em;color:var(--white);margin-bottom:.5rem;font-family:Space Grotesk,sans-serif;font-size:clamp(3rem,6vw,5.5rem);font-weight:800;line-height:1}.hero-name .accent{color:var(--cyan)}.hero-title{color:var(--gold);letter-spacing:.02em;margin-bottom:1.5rem;font-family:Space Grotesk,sans-serif;font-size:clamp(1.1rem,2.5vw,1.6rem);font-weight:600}.hero-desc{color:var(--muted);max-width:615px;margin-bottom:2.5rem;font-size:1rem;line-height:1.75}.hero-badges{flex-wrap:wrap;gap:.6rem;margin-bottom:2.5rem;display:flex}.badge{letter-spacing:.06em;border:1px solid var(--border2);color:var(--muted);background:#a033330a;border-radius:2px;padding:.3rem .8rem;font-family:DM Mono,monospace;font-size:.72rem;transition:all .2s}.badge:hover{border-color:var(--cyan);color:var(--cyan);background:#a0333314}.hero-cta{flex-wrap:wrap;gap:1rem;display:flex}.btn{letter-spacing:.08em;text-transform:uppercase;cursor:pointer;border:none;border-radius:3px;align-items:center;gap:.5rem;padding:.75rem 1.75rem;font-family:Space Grotesk,sans-serif;font-size:.82rem;font-weight:700;text-decoration:none;transition:all .25s;display:inline-flex}.btn-primary{background:var(--cyan);color:var(--bg)}.btn-primary:hover{background:var(--cyan2);transform:translateY(-2px);box-shadow:0 8px 24px #a0333340}.btn-outline{border:1px solid var(--border2);color:var(--text);background:0 0}.btn-outline:hover{border-color:var(--cyan);color:var(--cyan);transform:translateY(-2px)}.hero-photo-wrap{flex-direction:column;align-items:center;gap:1.5rem;display:flex}.headshot-frame{width:260px;height:260px;position:relative}.headshot-frame:before{content:"";border:2px solid var(--cyan);opacity:.4;border-radius:50%;animation:8s linear infinite spin;position:absolute;inset:-8px}.headshot-frame:after{content:"";border:1px dashed var(--border2);border-radius:50%;animation:16s linear infinite reverse spin;position:absolute;inset:-16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.headshot-inner{background:linear-gradient(135deg, var(--surface), var(--card));border:3px solid var(--border2);z-index:1;border-radius:50%;width:260px;height:260px;position:relative;overflow:hidden}.headshot-img{object-fit:cover;object-position:center top;transform-origin:50% 25%;filter:grayscale();width:100%;height:100%;transition:filter .6s;display:block;transform:scale(1.3)}.headshot-frame:hover .headshot-img{filter:grayscale(0%)}.stat-pills{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.stat-pill{text-align:center;background:var(--card);border:1px solid var(--border);border-radius:4px;min-width:80px;padding:.75rem 1.25rem}.stat-pill-number{color:var(--cyan);font-family:Space Grotesk,sans-serif;font-size:1.6rem;font-weight:800;line-height:1}.stat-pill-label{letter-spacing:.1em;color:var(--dim);text-transform:uppercase;margin-top:.25rem;font-family:DM Mono,monospace;font-size:.65rem}section{padding:5rem 3rem}#experience,#skills,#interests{background:var(--bg)}#projects,#education,#certifications{background:var(--surface)}.container{width:100%;max-width:1200px;margin:0 auto}.section-header{margin-bottom:3.5rem}.section-label{letter-spacing:.2em;text-transform:uppercase;color:var(--cyan);align-items:center;gap:.75rem;margin-bottom:.75rem;font-family:DM Mono,monospace;font-size:.72rem;display:flex}.section-label:before{content:"";background:var(--cyan);width:24px;height:1px;display:block}.section-title{color:var(--white);letter-spacing:-.02em;font-family:Space Grotesk,sans-serif;font-size:clamp(2rem,4vw,3rem);font-weight:800;line-height:1.1}.section-title .accent{color:var(--cyan)}.section-subtitle{color:var(--muted);margin-top:.75rem;font-size:.9rem}.timeline{padding-left:1.75rem;position:relative}.timeline:before{content:"";background:linear-gradient(to bottom, var(--cyan), var(--purple), var(--gold), transparent);width:1px;position:absolute;top:6px;bottom:6px;left:1px}.timeline-item{cursor:pointer;margin-bottom:3.5rem;position:relative}.timeline-item:before{content:"";border:2px solid var(--cyan);background:var(--bg);z-index:2;border-radius:50%;width:12px;height:12px;transition:all .3s;position:absolute;left:-2rem}.timeline-item:hover:before,.timeline-item.active:before{background:var(--cyan);box-shadow:0 0 16px var(--cyan);transform:scale(1.3)}.timeline-card{background:var(--card);border:1px solid var(--border);border-left:3px solid #0000;border-radius:6px;padding:1.75rem 2rem;transition:all .3s}.timeline-item:hover .timeline-card,.timeline-item.active .timeline-card{border-left-color:var(--cyan);transform:translate(4px);box-shadow:0 8px 32px #0006}.timeline-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.75rem;display:flex}.timeline-company{color:var(--white);font-family:Space Grotesk,sans-serif;font-size:1.15rem;font-weight:700}.timeline-period{letter-spacing:.08em;color:var(--gold);white-space:nowrap;background:#c9b89614;border:1px solid #c9b89633;border-radius:2px;padding:.25rem .75rem;font-family:DM Mono,monospace;font-size:.72rem}.timeline-role{color:var(--cyan);margin-bottom:.25rem;font-size:.9rem;font-weight:500}.timeline-location{color:var(--dim);letter-spacing:.06em;margin-bottom:1rem;font-family:DM Mono,monospace;font-size:.78rem}.timeline-bullets{border-top:1px solid var(--border);margin-top:1rem;padding-top:1rem;list-style:none}.timeline-bullets li{color:var(--muted);margin-bottom:.6rem;padding-left:1.25rem;font-size:.87rem;line-height:1.65;position:relative}.timeline-bullets li:before{content:"›";color:var(--cyan);font-size:1rem;line-height:1.5;position:absolute;left:0}.toggle-hint{color:var(--dim);letter-spacing:.1em;align-items:center;gap:.4rem;margin-top:.75rem;font-family:DM Mono,monospace;font-size:.67rem;transition:color .2s;display:flex}.timeline-item:hover .toggle-hint{color:var(--cyan)}.toggle-icon{transition:transform .3s;display:inline-block}.timeline-item.active .toggle-icon{transform:rotate(90deg)}.edu-grid{grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:1.5rem;display:grid}.edu-card{background:var(--card);border:1px solid var(--border);border-radius:6px;padding:2rem;transition:all .3s;position:relative;overflow:hidden}.edu-card:before{content:"";background:linear-gradient(90deg, var(--cyan), var(--purple));height:3px;position:absolute;top:0;left:0;right:0}.edu-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px #0006}.edu-degree{color:var(--white);margin-bottom:.4rem;font-family:Space Grotesk,sans-serif;font-size:1.05rem;font-weight:700}.edu-school{color:var(--cyan);margin-bottom:.25rem;font-size:.9rem}.edu-subloc{color:var(--muted);letter-spacing:.06em;margin-top:.25rem;font-family:DM Mono,monospace;font-size:.8rem}.edu-meta{flex-wrap:wrap;gap:1rem;margin-top:.75rem;display:flex}.edu-chip{letter-spacing:.06em;border:1px solid var(--border2);color:var(--muted);background:#a033330f;border-radius:2px;padding:.25rem .7rem;font-family:DM Mono,monospace;font-size:.7rem}.edu-chip.gold{color:var(--gold);background:#c9b8960f;border-color:#c9b89640}.edu-watermark{color:#a033330a;-webkit-user-select:none;user-select:none;font-family:Space Grotesk,sans-serif;font-size:5rem;font-weight:800;line-height:1;position:absolute;bottom:-10px;right:-10px}.skills-layout{grid-template-columns:1fr 1fr;align-items:start;gap:3rem;display:grid}.skill-category{margin-bottom:2.5rem}.skill-cat-label{letter-spacing:.14em;text-transform:uppercase;color:var(--gold);align-items:center;gap:.5rem;margin-bottom:1rem;font-family:DM Mono,monospace;font-size:.72rem;display:flex}.skill-cat-label:after{content:"";background:var(--border);flex:1;height:1px}.skill-pills{flex-wrap:wrap;gap:.5rem;display:flex}.skill-pill{border:1px solid var(--border);color:var(--text);background:var(--card);cursor:default;border-radius:3px;padding:.35rem .85rem;font-family:DM Mono,monospace;font-size:.75rem;transition:all .2s}.skill-pill:hover{border-color:var(--cyan);color:var(--cyan);background:#a033330f;transform:translateY(-1px)}.skill-pill.lang{color:var(--purple);background:#b86b6b0d;border-color:#b86b6b4d}.skill-pill.lang:hover{border-color:var(--purple);color:var(--purple);background:#b86b6b1f}.skill-pill.fw{color:var(--green);background:#c9b8960d;border-color:#c9b8964d}.skill-pill.fw:hover{border-color:var(--green);color:var(--green);background:#c9b8961f}.skill-pill.cloud{color:var(--cyan);background:#a033330d;border-color:#a033334d}.skill-pill.cloud:hover{border-color:var(--cyan);color:var(--cyan);background:#a033331f}.skill-pill.tool{color:var(--gold);background:#c9b8960d;border-color:#c9b8964d}.skill-pill.tool:hover{border-color:var(--gold);color:var(--gold);background:#c9b8961f}.chart-wrap{background:var(--card);border:1px solid var(--border);border-radius:6px;padding:2rem;position:relative}.chart-title{color:var(--white);text-align:center;margin-bottom:1.5rem;font-family:Space Grotesk,sans-serif;font-size:1rem;font-weight:700}.prof-bars{flex-direction:column;gap:1rem;display:flex}.prof-meta{justify-content:space-between;align-items:center;margin-bottom:.35rem;display:flex}.prof-name{color:var(--text);font-size:.82rem;font-weight:500}.prof-pct{color:var(--muted);font-family:DM Mono,monospace;font-size:.72rem}.prof-track{background:var(--border);border-radius:2px;height:4px;overflow:hidden}.prof-fill{border-radius:2px;height:100%;transition:width 1.2s cubic-bezier(.4,0,.2,1)}.certs-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem;display:grid}.cert-card{background:var(--card);border:1px solid var(--border);border-radius:6px;align-items:flex-start;gap:1rem;padding:1.5rem;transition:all .3s;display:flex}.cert-card:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:0 12px 32px #00000059}.cert-icon{border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.3rem;display:flex}.cert-name{color:var(--white);font-size:.88rem;font-weight:600;line-height:1.3}.cert-issuer{color:var(--dim);letter-spacing:.06em;margin-top:.3rem;font-family:DM Mono,monospace;font-size:.68rem}#interests{padding-bottom:6rem}.interests-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;display:grid}.interest-card{background:var(--card);border:1px solid var(--border);text-align:center;cursor:default;border-radius:6px;padding:1.5rem;transition:all .3s}.interest-card:hover{border-color:var(--cyan);transform:translateY(-3px);box-shadow:0 0 24px #a0333314}.interest-icon{margin-bottom:.75rem;font-size:2.2rem}.interest-label{color:var(--text);letter-spacing:.02em;font-family:Space Grotesk,sans-serif;font-size:.88rem;font-weight:700}footer{background:var(--surface);border-top:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:2.5rem 3rem;display:flex}.footer-name{color:var(--white);font-family:Space Grotesk,sans-serif;font-size:1rem;font-weight:800}.footer-contact{color:var(--muted);flex-wrap:wrap;gap:2rem;font-family:DM Mono,monospace;font-size:.75rem;display:flex}.footer-contact a{color:var(--muted);text-decoration:none;transition:color .2s}.footer-contact a:hover{color:var(--cyan)}.footer-copy{color:var(--dim);font-family:DM Mono,monospace;font-size:.68rem}.projects-showcase{flex-direction:column;gap:2rem;display:flex}.project-tabs-wrap{position:relative}.project-tabs{background:var(--card);border:1px solid var(--border);border-radius:6px;flex-wrap:wrap;gap:.5rem;padding:.5rem;display:flex}.project-tab{min-width:160px;color:var(--muted);text-align:left;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:4px;flex:1;align-items:center;gap:.6rem;padding:.85rem 1rem;font-family:inherit;font-size:.82rem;font-weight:500;transition:all .25s;display:flex}.project-tab:hover{color:var(--text);border-color:var(--border2);background:#a033330a}.project-tab.active{border-color:var(--cyan);color:var(--white);background:#a0333314;box-shadow:0 4px 12px #a033331a}.project-tab-num{letter-spacing:.08em;color:var(--dim);flex-shrink:0;font-family:DM Mono,monospace;font-size:.7rem}.project-tab.active .project-tab-num{color:var(--cyan)}.project-tab-icon{flex-shrink:0;font-size:1.1rem}.project-tab-label{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.project-dots{justify-content:center;align-items:center;gap:8px;margin-top:-.5rem;margin-bottom:.5rem;display:none}.project-dot{background:var(--dim);cursor:pointer;opacity:.5;border:none;border-radius:50%;width:6px;height:6px;padding:0;transition:all .25s;position:relative}.project-dot:before{content:"";position:absolute;inset:-8px}.project-dot:hover{opacity:.8}.project-dot.active{background:var(--cyan);opacity:1;width:8px;height:8px}.project-panel-wrap{background:var(--card);border:1px solid var(--border);border-radius:8px;min-height:480px;overflow:hidden}.project-panel{grid-template-columns:minmax(280px,1fr) 1.4fr;gap:0;animation:.5s panelFade;display:grid}@keyframes panelFade{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.project-visual{background:linear-gradient(135deg, var(--surface), var(--bg));border-right:1px solid var(--border);justify-content:center;align-items:center;min-height:320px;padding:1.25rem;display:flex;position:relative;overflow:hidden}.project-visual img{object-fit:contain;width:auto;max-width:100%;height:auto;max-height:100%;display:block}.project-visual-placeholder{text-align:center;flex-direction:column;align-items:center;gap:.75rem;padding:2rem;display:flex}.project-visual-icon{opacity:.35;filter:grayscale(20%);font-size:4rem}.project-visual-hint{letter-spacing:.12em;text-transform:uppercase;color:var(--dim);font-family:DM Mono,monospace;font-size:.68rem}.project-status-badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);letter-spacing:.1em;text-transform:uppercase;background:#0f0a0ad9;border:1px solid;border-radius:3px;align-items:center;gap:.4rem;padding:.3rem .75rem;font-family:DM Mono,monospace;font-size:.68rem;font-weight:500;display:inline-flex;position:absolute;top:1rem;right:1rem}.status-dot{border-radius:50%;width:6px;height:6px;display:inline-block;position:relative}.status-dot:after{content:"";background:inherit;opacity:.4;border-radius:50%;animation:2s ease-out infinite pulse;position:absolute;inset:-2px}.project-details{flex-direction:column;gap:1rem;padding:2rem 2.25rem;display:flex}.project-meta-top{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);flex-wrap:wrap;align-items:center;gap:.5rem;font-family:DM Mono,monospace;font-size:.7rem;display:flex}.project-category{color:var(--cyan)}.project-meta-divider{color:var(--dim)}.project-org{color:var(--muted)}.project-title{color:var(--white);letter-spacing:-.01em;font-family:Space Grotesk,sans-serif;font-size:clamp(1.4rem,2.5vw,1.85rem);font-weight:700;line-height:1.15}.project-summary{color:var(--text);font-size:.95rem;line-height:1.65}.project-impact{border:1px solid #c9b89640;border-left:3px solid var(--gold);background:#c9b89614;border-radius:4px;align-self:flex-start;align-items:center;gap:.65rem;padding:.75rem 1rem;display:inline-flex}.project-impact-icon{font-size:1.1rem}.project-impact-text{color:var(--gold);font-size:.87rem;font-weight:600}.project-section{margin-top:.25rem}.project-section-label{letter-spacing:.14em;text-transform:uppercase;color:var(--gold);align-items:center;gap:.5rem;margin-bottom:.6rem;font-family:DM Mono,monospace;font-size:.68rem;display:flex}.project-section-label:after{content:"";background:var(--border);flex:1;height:1px}.project-highlights{flex-direction:column;gap:.45rem;list-style:none;display:flex}.project-highlights li{color:var(--muted);padding-left:1.25rem;font-size:.85rem;line-height:1.55;position:relative}.project-highlights li:before{content:"›";color:var(--cyan);font-size:1rem;line-height:1.4;position:absolute;left:0}.project-footer{border-top:1px solid var(--border);flex-direction:column;gap:1rem;margin-top:auto;padding-top:1rem;display:flex}.project-meta-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.project-meta-label{letter-spacing:.12em;text-transform:uppercase;color:var(--dim);margin-bottom:.25rem;font-family:DM Mono,monospace;font-size:.65rem}.project-meta-value{color:var(--text);font-size:.85rem;font-weight:500}.project-tech{flex-wrap:wrap;gap:.4rem;display:flex}.project-tech-pill{border:1px solid var(--border2);color:var(--text);background:#a033330d;border-radius:2px;padding:.25rem .65rem;font-family:DM Mono,monospace;font-size:.7rem}.project-links{flex-wrap:wrap;gap:.75rem;display:flex}.project-link{background:var(--cyan);color:var(--bg);letter-spacing:.05em;text-transform:uppercase;border-radius:3px;align-items:center;padding:.45rem 1rem;font-family:Space Grotesk,sans-serif;font-size:.78rem;font-weight:700;text-decoration:none;transition:all .2s;display:inline-flex}.project-link:hover{background:var(--cyan2);transform:translateY(-1px)}.fade-up{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(28px)}.fade-up.visible{opacity:1;transform:translateY(0)}.live-dot{background:var(--green);border-radius:50%;width:8px;height:8px;margin-right:.4rem;display:inline-block;position:relative}.live-dot:after{content:"";background:var(--green);opacity:.4;border-radius:50%;animation:2s ease-out infinite pulse;position:absolute;inset:-3px}@keyframes pulse{0%{opacity:.4;transform:scale(1)}to{opacity:0;transform:scale(2.5)}}@media (width<=900px){nav{padding:1rem 1.5rem}.nav-links{display:none}section{padding:4rem 1.5rem}#hero{padding:5rem 1.5rem 3rem}.hero-inner{grid-template-columns:1fr}.hero-photo-wrap{order:-1}.skills-layout{grid-template-columns:1fr}footer{padding:2rem 1.5rem}.project-tabs{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;overflow-x:auto}.project-tabs::-webkit-scrollbar{display:none}.project-tab{flex:none;min-width:180px}.project-dots{display:flex}.project-panel{grid-template-columns:1fr}.project-visual{border-right:none;border-bottom:1px solid var(--border);min-height:220px}.project-details{padding:1.5rem}.project-meta-row{grid-template-columns:1fr;gap:.75rem}}
