@import"https://fonts.googleapis.com/css2?family=Syne:wght@500;600;700;800&family=DM+Sans:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap";:root{color-scheme:dark;--font-heading: "Syne", sans-serif;--font-body: "DM Sans", sans-serif;--font-mono: "JetBrains Mono", monospace;--bg-deep: #05070a;--bg: #0a0d12;--bg-elevated: #0f1318;--bg-soft: #141a22;--text: #f0f4f8;--text-secondary: #94a3b8;--muted: #64748b;--accent: #00e5ff;--accent-dim: #00b8cc;--accent-glow: rgba(0, 229, 255, .15);--accent-glow-strong: rgba(0, 229, 255, .3);--accent-secondary: #a78bfa;--accent-secondary-glow: rgba(167, 139, 250, .15);--data-green: #34d399;--data-green-glow: rgba(52, 211, 153, .15);--line: rgba(148, 163, 184, .1);--line-accent: rgba(0, 229, 255, .2);--shadow: 0 25px 50px -12px rgba(0, 0, 0, .5);--shadow-accent: 0 0 30px rgba(0, 229, 255, .15);--shadow-card: 0 4px 24px rgba(0, 0, 0, .4);--grid-color: rgba(0, 229, 255, .03);--dot-color: rgba(0, 229, 255, .08)}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg-deep);color:var(--text);min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-shell{min-height:100vh;display:flex;flex-direction:column;position:relative;background:radial-gradient(circle at center,var(--dot-color) 1px,transparent 1px),radial-gradient(ellipse at top,rgba(0,229,255,.03) 0%,transparent 50%),var(--bg-deep);background-size:24px 24px,100% 100%,100% 100%}.app-shell:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,229,255,.01) 2px,rgba(0,229,255,.01) 4px);pointer-events:none;z-index:1000}.page{flex:1;position:relative;z-index:1}.page-content{display:flex;flex-direction:column;gap:0}h1,h2,h3{font-family:var(--font-heading);font-weight:700;letter-spacing:-.02em;line-height:1.1}h1{font-size:clamp(2.5rem,5vw,4rem);font-weight:800}h2{font-size:clamp(1.75rem,3vw,2.5rem)}h3{font-size:1.15rem;font-weight:600}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.container{width:min(1140px,90vw);margin:0 auto;padding:0 1rem}.navbar{position:sticky;top:0;z-index:100;background:#05070ad9;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%)}.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;position:relative}.brand{font-family:var(--font-heading);font-size:1.3rem;font-weight:700;letter-spacing:-.02em;color:var(--text);position:relative}.brand:after{content:"_";color:var(--accent);animation:blink 1s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes glow-pulse{0%,to{text-shadow:0 0 20px rgba(0,229,255,.3)}50%{text-shadow:0 0 40px rgba(0,229,255,.5),0 0 60px rgba(0,229,255,.2)}}.nav-links{display:flex;align-items:center;gap:.5rem}.nav-links a{font-family:var(--font-mono);font-size:.8rem;color:var(--text-secondary);padding:.5rem 1rem;border-radius:6px;transition:all .2s ease;position:relative}.nav-links a:before{content:">";margin-right:.4rem;color:var(--muted);opacity:0;transition:opacity .2s ease}.nav-links a:hover:before,.nav-links a.active:before{opacity:1}.nav-links a:hover,.nav-links a.active{color:var(--accent);background:var(--accent-glow)}.nav-cta{font-family:var(--font-mono);font-size:.8rem;padding:.6rem 1.2rem;border-radius:6px;background:var(--accent);color:var(--bg-deep);font-weight:500;transition:all .2s ease;box-shadow:0 0 20px var(--accent-glow)}.nav-cta:hover{box-shadow:0 0 30px var(--accent-glow-strong);transform:translateY(-1px)}.nav-toggle{display:none;background:transparent;border:1px solid var(--line);border-radius:6px;padding:.5rem;cursor:pointer;flex-direction:column;gap:4px}.nav-toggle span{display:block;width:18px;height:2px;background:var(--accent);transition:all .2s ease}.hero{padding:8rem 0 6rem;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;top:10%;right:-5%;width:500px;height:500px;background:radial-gradient(circle at 30% 30%,var(--accent-glow) 0%,transparent 50%),radial-gradient(circle at 70% 70%,var(--accent-secondary-glow) 0%,transparent 50%);filter:blur(60px);opacity:.6;pointer-events:none}.hero-grid{display:grid;gap:3rem;grid-template-columns:1fr;align-items:center;position:relative;z-index:1}.hero-copy h1{font-size:clamp(2.8rem,6vw,4.5rem);line-height:1;margin:1.5rem 0;background:linear-gradient(135deg,var(--text) 0%,var(--text-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-copy h1 span{display:block;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 30px rgba(0,229,255,.3))}.eyebrow{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.15em;font-size:.75rem;color:var(--accent);display:inline-flex;align-items:center;gap:.75rem;padding:.5rem 1rem;background:var(--accent-glow);border:1px solid var(--line-accent);border-radius:4px}.eyebrow:before{content:"//";opacity:.5}.lead{font-size:1.1rem;color:var(--text-secondary);max-width:38rem;line-height:1.7}.hero-actions{margin:2.5rem 0;display:flex;flex-wrap:wrap;gap:1rem}.hero-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.5rem}.hero-meta span{font-family:var(--font-mono);padding:.4rem .8rem;border-radius:4px;border:1px solid var(--line);color:var(--text-secondary);font-size:.75rem;background:var(--bg-elevated);transition:all .2s ease}.hero-meta span:hover{border-color:var(--line-accent);background:var(--accent-glow);color:var(--accent)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.75rem;border-radius:6px;border:1px solid transparent;font-family:var(--font-mono);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .25s ease;position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s ease}.btn:hover:before{left:100%}.btn.primary{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dim) 100%);color:var(--bg-deep);box-shadow:var(--shadow-accent)}.btn.primary:hover{transform:translateY(-2px);box-shadow:0 0 40px var(--accent-glow-strong)}.btn.ghost{border:1px solid var(--line-accent);color:var(--accent);background:transparent}.btn.ghost:hover{background:var(--accent-glow);border-color:var(--accent)}.section{padding:5rem 0;position:relative}.section.alt{background:linear-gradient(180deg,var(--bg) 0%,var(--bg-elevated) 50%,var(--bg) 100%)}.section.alt:before{content:"";position:absolute;left:0;right:0;top:0;height:1px;background:linear-gradient(90deg,transparent,var(--line-accent),transparent)}.section.alt:after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:linear-gradient(90deg,transparent,var(--line-accent),transparent)}.section-label{font-family:var(--font-mono);color:var(--accent);text-transform:uppercase;letter-spacing:.2em;font-size:.7rem;margin-bottom:1rem;display:inline-flex;align-items:center;gap:.5rem}.section-label:before{content:"";width:12px;height:2px;background:var(--accent)}.section-lead{color:var(--text-secondary);max-width:42rem;margin-top:1rem;font-size:1.05rem}.card{background:var(--bg-elevated);border:1px solid var(--line);border-radius:12px;padding:2rem;box-shadow:var(--shadow-card);position:relative;overflow:hidden;transition:all .3s ease;flex:1;display:flex;flex-direction:column}.card:before{content:"";position:absolute;top:0;left:0;width:60px;height:60px;background:linear-gradient(135deg,var(--accent-glow) 0%,transparent 60%);pointer-events:none}.card:after{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),transparent);opacity:0;transition:opacity .3s ease}.card:hover{border-color:var(--line-accent);transform:translateY(-4px);box-shadow:var(--shadow-card),var(--shadow-accent)}.card:hover:after{opacity:1}.card h3{color:var(--text);margin-bottom:.75rem;font-family:var(--font-heading)}.card p{color:var(--text-secondary);font-size:.95rem;line-height:1.6}.card.wide{display:flex;justify-content:space-between;align-items:center;gap:2rem}.stack-space{margin-top:2rem}.card ul{margin-top:1rem;padding-left:0;list-style:none;color:var(--text-secondary)}.card li{margin-bottom:.5rem;padding-left:1.5rem;position:relative;font-size:.9rem}.card li:before{content:"→";position:absolute;left:0;color:var(--accent);font-family:var(--font-mono)}.card>*:last-child{margin-top:auto}.card .text-link{padding-top:1rem}.card ul+.text-link{margin-top:0}.research-grid,.projects-grid,.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:2.5rem}.research-grid>*,.projects-grid>*,.skills-grid>*,.research-grid>*>*,.projects-grid>*>*,.skills-grid>*>*,.research-grid .card,.projects-grid .card,.skills-grid .card{height:100%;display:flex;flex-direction:column}.skills-grid .card{min-height:180px}.research-grid .card{min-height:280px}.projects-grid.stack{grid-template-columns:1fr}.filter-row{margin-top:1.5rem;display:flex;flex-wrap:wrap;gap:.5rem}.filter-button{font-family:var(--font-mono);font-size:.8rem;background:transparent;border:1px solid var(--line);color:var(--text-secondary);padding:.5rem 1rem;border-radius:4px;cursor:pointer;transition:all .2s ease}.filter-button:hover{border-color:var(--line-accent);color:var(--accent)}.filter-button.active{background:var(--accent);border-color:var(--accent);color:var(--bg-deep)}.publication{margin-top:2rem;border:1px solid var(--line);border-radius:12px;padding:1.75rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;background:var(--bg-soft);position:relative;overflow:hidden;transition:all .3s ease}.publication:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--accent),var(--accent-secondary))}.publication:hover{border-color:var(--line-accent)}.publication-title{font-family:var(--font-heading);font-weight:600;color:var(--text)}.publication-sub{color:var(--text-secondary);margin-top:.4rem;font-size:.95rem}.publication-note{font-family:var(--font-mono);color:var(--muted);font-style:normal;margin-top:.75rem;font-size:.8rem;display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .8rem;background:var(--bg-elevated);border-radius:4px;border:1px solid var(--line)}.publication-note:before{content:"⏳"}.badge{font-family:var(--font-mono);padding:.4rem .9rem;border-radius:4px;background:var(--data-green-glow);border:1px solid rgba(52,211,153,.3);color:var(--data-green);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.tag-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.25rem}.tag-row span{font-family:var(--font-mono);padding:.35rem .75rem;background:var(--bg-deep);border:1px solid var(--line);border-radius:4px;font-size:.7rem;color:var(--text-secondary);transition:all .2s ease}.tag-row span:hover{border-color:var(--line-accent);color:var(--accent)}.text-link{font-family:var(--font-mono);display:inline-flex;align-items:center;gap:.5rem;margin-top:1.25rem;padding:.5rem 0;min-height:44px;color:var(--accent);font-size:.85rem;font-weight:500;text-decoration:none;cursor:pointer;transition:all .2s ease;position:relative}.text-link:before{content:"[";opacity:.5}.text-link:after{content:"]→";opacity:.5;transition:transform .2s ease}.text-link:hover{color:var(--text)}.text-link:hover:after{transform:translate(4px)}.link-row{display:flex;flex-wrap:wrap;gap:1.5rem;margin-top:1rem}.link-row .text-link{margin-top:0}.section-brand{margin-top:.75rem;display:inline-flex;align-items:center;gap:.6rem;color:var(--text-secondary);font-size:.9rem}.section-brand img{width:28px;height:28px;object-fit:contain;background:var(--bg-soft);border:1px solid var(--line);border-radius:6px;padding:.25rem}.brand-row{display:flex;align-items:center;gap:1rem;margin-top:1rem}.brand-row.compact{margin-top:0;margin-bottom:.75rem}.brand-logo{width:64px;height:64px;object-fit:contain;background:#f3efe8;border:1px solid var(--line);border-radius:10px;padding:.5rem}.brand-copy{display:flex;flex-direction:column;gap:.2rem}.brand-title{font-weight:600;color:var(--text)}.brand-sub{color:var(--text-secondary);font-size:.9rem}.section-subhead{margin-top:3rem}.logo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-top:1.5rem}.logo-section+.logo-section{margin-top:3rem}.logo-tile{display:grid;place-items:center;padding:1rem;border-radius:10px;border:1px solid var(--line);background:var(--bg-elevated);transition:all .3s ease}.logo-tile:hover{border-color:var(--line-accent);transform:translateY(-2px)}.logo-tile.light{background:#f5f5f5}.logo-tile.dark{background:var(--bg-deep)}.logo-tile img{height:42px;width:100%;object-fit:contain;filter:grayscale(20%);transition:filter .3s ease}.logo-tile:hover img{filter:grayscale(0%)}.logo-tile img.logo-lg{height:54px}.timeline{margin-top:2.5rem;display:grid;gap:1.5rem}.timeline-item{border-left:2px solid var(--line);padding-left:1.5rem;position:relative;transition:all .3s ease}.timeline-item:before{content:"";position:absolute;left:-5px;top:0;width:8px;height:8px;background:var(--accent);border-radius:50%;box-shadow:0 0 10px var(--accent-glow)}.timeline-item:hover{border-color:var(--line-accent)}.timeline-header{display:flex;align-items:center;gap:1rem}.timeline-header img.logo-tile{width:44px;height:44px;object-fit:contain;background:var(--bg-soft);border-radius:8px;padding:.4rem;border:1px solid var(--line)}.timeline-header img.logo-tile.light{background:#f5f5f5}.timeline-header img.logo-tile.dark{background:var(--bg-deep)}.timeline-item span{font-family:var(--font-mono);color:var(--muted);font-size:.8rem}.timeline.compact{margin-top:1.5rem}.case{background:var(--bg-elevated);border:1px solid var(--line);border-radius:16px;padding:2.5rem;box-shadow:var(--shadow-card);position:relative;overflow:hidden;transition:all .3s ease}.case:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent-secondary),transparent);opacity:0;transition:opacity .3s ease}.case:hover{border-color:var(--line-accent)}.case:hover:before{opacity:1}.case-lite{border-radius:12px;border:1px solid var(--line);padding:2rem;background:var(--bg-soft)}.case-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.case-identity{display:flex;align-items:center;gap:1rem}.case-logo{width:44px;height:44px;object-fit:contain;background:var(--bg-soft);border:1px solid var(--line);border-radius:8px;padding:.4rem}.case-logo-light{background:#f5f5f5}.case-logo-lg{width:80px;height:80px;padding:.6rem;border-radius:12px}.case-row{display:grid;grid-template-columns:minmax(100px,140px) 1fr;gap:2.5rem;align-items:start}.case-aside{display:flex;flex-direction:column;gap:1rem;align-items:flex-start}.case-body h2{margin-bottom:.75rem;font-size:1.5rem}.case-body p{color:var(--text-secondary);line-height:1.7}.case-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.5rem;margin-top:2rem}.case-grid h3{font-size:.9rem;color:var(--accent);margin-bottom:.5rem;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em}.case-grid p{font-size:.9rem}.cv-grid{margin-top:2.5rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;align-items:stretch}.cv-grid>*{display:flex;flex-direction:column}.cv-grid>*>*{flex:1;display:flex;flex-direction:column}.cv-grid .card{flex:1;display:flex;flex-direction:column}.logo-card{height:54px;display:flex;align-items:center;justify-content:flex-start;margin-bottom:1rem}.logo-card img{height:46px;width:auto;object-fit:contain}.contact-form{margin-top:2.5rem;display:grid;gap:1.5rem;max-width:560px}.contact-form label{display:grid;gap:.5rem;font-family:var(--font-mono);color:var(--text-secondary);font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}.contact-form input,.contact-form textarea{font-family:var(--font-body);background:var(--bg-elevated);border:1px solid var(--line);border-radius:8px;padding:1rem 1.25rem;color:var(--text);font-size:1rem;transition:all .2s ease}.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.contact-form .btn{margin-top:.5rem;justify-self:start}.form-status{display:flex;flex-direction:column;gap:.35rem;padding:1rem 1.25rem;border-radius:8px;border:1px solid transparent;background:var(--bg-soft);font-size:.95rem}.form-status strong{font-family:var(--font-mono);font-size:.85rem}.form-status.success{border-color:#34d3994d;background:var(--data-green-glow)}.form-status.success strong{color:var(--data-green)}.form-status.error{border-color:#ef44444d;background:#ef44441a}.form-status.error strong{color:#ef4444}.section.cta{text-align:center;padding:6rem 0;position:relative}.section.cta:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:400px;background:radial-gradient(ellipse,var(--accent-glow) 0%,transparent 70%);pointer-events:none}.section.cta h2{font-size:clamp(2rem,4vw,3rem);position:relative}.section.cta p{margin-top:1rem;color:var(--text-secondary);max-width:500px;margin-left:auto;margin-right:auto}.section.cta .btn{margin-top:2rem}.footer{margin-top:0;border-top:1px solid var(--line);padding:3rem 0 2rem;background:var(--bg-deep);position:relative}.footer:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--line-accent),transparent)}.footer-inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.5rem}.footer-title{font-family:var(--font-heading);font-size:1.2rem;font-weight:700}.footer-subtitle{font-family:var(--font-mono);color:var(--muted);font-size:.8rem;margin-top:.4rem}.footer-links{display:flex;gap:1rem}.footer-links a{font-family:var(--font-mono);font-size:.8rem;color:var(--text-secondary);padding:.5rem 1rem;border:1px solid var(--line);border-radius:4px;transition:all .2s ease}.footer-links a:hover{color:var(--accent);border-color:var(--line-accent);background:var(--accent-glow)}.footer-note{text-align:center;font-family:var(--font-mono);color:var(--muted);font-size:.75rem;margin-top:2rem}@media(max-width:768px){.nav-toggle{display:flex}.nav-links{position:absolute;top:calc(100% + 1px);left:0;right:0;background:#05070afa;border-bottom:1px solid var(--line);padding:1.5rem;display:none;flex-direction:column;align-items:stretch;gap:.5rem;z-index:50;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.nav-links.open{display:flex}.nav-links a{padding:.75rem 1rem}.nav-cta{margin-top:.5rem;text-align:center}.hero{padding:5rem 0 4rem}.hero:before{width:300px;height:300px;right:-20%;top:20%}.section{padding:4rem 0}.card,.case,.publication{padding:1.5rem}.projects-grid,.research-grid,.skills-grid,.cv-grid{gap:1rem}.card.wide,.case-header{flex-direction:column;align-items:flex-start}.case-row{grid-template-columns:1fr;gap:1.5rem}.case-aside{flex-direction:row;flex-wrap:wrap;align-items:center}.case-logo-lg{width:64px;height:64px}.publication{flex-direction:column;align-items:flex-start}.footer-inner{flex-direction:column;text-align:center}.footer-links{flex-wrap:wrap;justify-content:center}}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px var(--accent-glow)}50%{box-shadow:0 0 40px var(--accent-glow-strong)}}@keyframes data-flow{0%{background-position:0% 50%}to{background-position:100% 50%}}.gradient-text{background:linear-gradient(135deg,var(--accent),var(--accent-secondary),var(--accent));background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:data-flow 3s linear infinite}.data-grid-container{position:absolute;top:0;right:0;width:55%;height:100%;pointer-events:none;z-index:0}.data-grid-canvas{width:100%;height:100%}.data-grid-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,var(--bg-deep) 0%,transparent 30%,transparent 100%);pointer-events:none}@media(max-width:768px){.data-grid-container{width:100%;opacity:.4}.data-grid-overlay{background:linear-gradient(180deg,transparent 0%,var(--bg-deep) 80%)}}
