@import"https://fonts.googleapis.com/css2?family=DM+Serif+Display&family=DM+Sans:wght@300;400;500;600&family=JetBrains+Mono:wght@400;500&display=swap";:root{color-scheme:dark;--font-heading: "DM Serif Display", serif;--font-body: "DM Sans", sans-serif;--font-mono: "JetBrains Mono", monospace;--bg: #06080a;--bg-elevated: #0d1117;--bg-soft: #161b22;--bg-card: #0d1117;--text: #e6edf3;--text-secondary: #9ca3af;--muted: #6b7280;--accent: #4B8BF5;--accent-dim: #3a6fd8;--accent-glow: rgba(75, 139, 245, .15);--accent-subtle: rgba(75, 139, 245, .06);--line: #1b2332;--line-light: #2d3748;--shadow: 0 4px 24px rgba(0, 0, 0, .5);--shadow-lg: 0 12px 48px rgba(0, 0, 0, .6)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;background-image:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(75,139,245,.04),transparent)}h1,h2,h3{font-family:var(--font-heading);font-weight:400;letter-spacing:-.01em;color:var(--text)}h1{font-size:clamp(2.4rem,4.5vw,3.4rem);line-height:1.1}h2{font-size:clamp(1.7rem,3vw,2.3rem);line-height:1.15}h3{font-size:1.1rem;line-height:1.3;font-family:var(--font-body);font-weight:600}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.app-shell{min-height:100vh;display:flex;flex-direction:column}.page{flex:1}.page-content{display:flex;flex-direction:column}.container{width:min(1100px,90vw);margin:0 auto}.navbar{position:sticky;top:0;z-index:10;background:#06080ae0;border-bottom:1px solid var(--line);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.navbar:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(75,139,245,.3),transparent)}.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:.9rem 0;position:relative}.brand{font-family:var(--font-heading);font-size:1.3rem;color:var(--text)}.nav-links{display:flex;align-items:center;gap:2rem;font-size:.88rem}.nav-links a{color:var(--text-secondary);transition:color .2s ease;font-weight:400}.nav-links a.active,.nav-links a:hover{color:var(--text)}.nav-links a.nav-cta,.nav-links a.nav-cta:hover{padding:.45rem 1.15rem;border-radius:6px;background:var(--accent);color:#fff;font-weight:600;font-size:.82rem;transition:all .2s ease;letter-spacing:.01em}.nav-links a.nav-cta:hover{background:var(--accent-dim);box-shadow:0 0 20px var(--accent-glow)}.nav-toggle{display:none;background:transparent;border:1px solid var(--line);border-radius:6px;padding:.4rem .55rem;color:var(--text);cursor:pointer}.nav-toggle span{display:block;width:18px;height:2px;background:var(--text);margin:3px 0;border-radius:1px}.hero{padding:6rem 0 4.5rem;border-bottom:1px solid var(--line);background:radial-gradient(ellipse 60% 40% at 20% 60%,rgba(75,139,245,.05),transparent),radial-gradient(ellipse 50% 50% at 80% 20%,rgba(75,139,245,.03),transparent)}.hero-grid{display:grid;gap:3rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));align-items:center}.hero-copy h1{margin:.75rem 0}.hero-copy h1 span{display:block;color:var(--accent)}.eyebrow{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.12em;font-size:.7rem;color:var(--accent);font-weight:500}.lead{font-size:1.08rem;color:var(--text-secondary);max-width:36rem;line-height:1.65}.hero-actions{margin:2.5rem 0 0;display:flex;flex-wrap:wrap;gap:.75rem}.hero-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.5rem}.hero-meta span{font-family:var(--font-mono);padding:.3rem .75rem;border-radius:4px;border:1px solid var(--line-light);color:var(--text-secondary);font-size:.72rem;letter-spacing:.02em}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.7rem 1.5rem;border-radius:6px;border:1px solid transparent;font-weight:600;font-size:.88rem;cursor:pointer;transition:all .2s ease}.btn.primary{background:var(--accent);color:var(--bg);font-weight:700}.btn.primary:hover{background:var(--accent-dim);transform:translateY(-1px);box-shadow:0 6px 24px var(--accent-glow),0 2px 8px #4b8bf533}.btn.ghost{border-color:var(--line-light);color:var(--text-secondary);background:transparent}.btn.ghost:hover{border-color:var(--accent);color:var(--text)}.section{padding:4.5rem 0}.section.alt{background:var(--bg-elevated);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.section-label{font-family:var(--font-mono);color:var(--accent);text-transform:uppercase;letter-spacing:.12em;font-size:.7rem;font-weight:500;margin-bottom:.5rem;display:inline-block;padding-left:.75rem;border-left:2px solid var(--accent)}.section-lead{color:var(--text-secondary);max-width:40rem;margin-top:.5rem;line-height:1.65;font-size:1.02rem}.card{background:var(--bg-card);border:1px solid var(--line);border-radius:12px;padding:1.75rem;transition:border-color .3s ease,box-shadow .3s ease,transform .3s ease;position:relative}.card:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:12px;padding:1px;background:linear-gradient(135deg,rgba(75,139,245,.2),transparent 50%);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask-composite:exclude;-webkit-mask-composite:xor;opacity:0;transition:opacity .3s ease;pointer-events:none}.card:hover{border-color:var(--line-light);box-shadow:0 8px 32px #0006,0 0 0 1px #4b8bf514;transform:translateY(-2px)}.card:hover:before{opacity:1}.card h3{color:var(--text)}.card p{color:var(--text-secondary);line-height:1.6;font-size:.92rem;margin-top:.5rem}.card.wide{display:flex;justify-content:space-between;align-items:center;gap:2rem}.stack-space{margin-top:1.5rem}.card ul{margin-top:1rem;padding-left:1.2rem;color:var(--text-secondary);font-size:.92rem}.card li{margin-bottom:.4rem;line-height:1.5}.research-grid,.projects-grid,.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.25rem;margin-top:2rem}.projects-grid.stack{grid-template-columns:1fr}.skills-grid>*,.research-grid>*,.projects-grid>*{height:100%}.skills-grid>*>*,.research-grid>*>*,.projects-grid>*>*{height:100%}.skills-grid .card,.research-grid .card,.projects-grid .card{height:100%;display:flex;flex-direction:column}.skills-grid .card>p,.research-grid .card>p,.projects-grid .card>p{flex:1}.skills-grid .card>.text-link,.research-grid .card>.text-link,.projects-grid .card>.text-link{margin-top:auto}.filter-row{margin-top:1.5rem;display:flex;flex-wrap:wrap;gap:.5rem}.filter-button{background:transparent;border:1px solid var(--line);color:var(--muted);padding:.45rem .9rem;border-radius:6px;cursor:pointer;font-size:.85rem;font-family:inherit;transition:all .2s ease}.filter-button.active{background:var(--accent);border-color:transparent;color:var(--bg);font-weight:600}.publication{margin-top:2rem;border:1px solid var(--line);border-radius:12px;padding:1.5rem 1.75rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;background:var(--bg-soft)}.publication-title{font-weight:600;color:var(--text)}.publication-sub{color:var(--text-secondary);margin-top:.3rem;font-size:.92rem;line-height:1.55}.publication-note{color:var(--accent);font-style:italic;margin-top:.5rem;font-size:.82rem}.badge{padding:.3rem .75rem;border-radius:4px;background:var(--accent-glow);color:var(--accent);font-family:var(--font-mono);font-size:.72rem;font-weight:500;letter-spacing:.02em;white-space:nowrap;border:1px solid rgba(75,139,245,.25)}.tag-row{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1rem}.tag-row span{font-family:var(--font-mono);padding:.25rem .6rem;background:var(--accent-subtle);border:1px solid rgba(75,139,245,.15);border-radius:4px;font-size:.7rem;color:var(--text-secondary);font-weight:400;letter-spacing:.01em}.text-link{display:inline-flex;align-items:center;margin-top:1rem;padding:.5rem 0;min-height:44px;color:var(--accent);font-weight:500;font-size:.88rem;text-decoration:none;cursor:pointer;transition:color .2s ease;gap:.3rem}.text-link:after{content:" →";transition:transform .2s ease;display:inline-block}.text-link:hover{color:var(--text)}.text-link:hover:after{transform:translate(3px)}.text-link:active{opacity:.7}.link-row{display:flex;flex-wrap:wrap;gap:1rem;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(--muted);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:.3rem}.brand-row{display:flex;align-items:center;gap:.9rem;margin-top:.75rem}.brand-row.compact{margin-top:0;margin-bottom:.75rem}.brand-logo{width:56px;height:56px;object-fit:contain;background:#e6edf3;border:1px solid var(--line);border-radius:8px;padding:.35rem}.brand-copy{display:flex;flex-direction:column;gap:.15rem}.brand-title{font-weight:600;font-size:.95rem;color:var(--text)}.brand-sub{color:var(--muted);font-size:.85rem}.section-subhead{margin-top:2.5rem}.logo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;margin-top:1.5rem}.logo-section+.logo-section{margin-top:2rem}.logo-tile{display:grid;place-items:center;padding:.6rem .8rem;border-radius:8px;border:1px solid var(--line);background:var(--bg-elevated);transition:border-color .2s ease}.logo-tile:hover{border-color:var(--line-light)}.logo-tile.light{background:#e6edf3}.logo-tile.dark{background:var(--bg)}.logo-tile img{height:40px;width:100%;object-fit:contain}.logo-tile img.logo-lg{height:52px}.timeline{margin-top:2rem;display:grid;gap:1.25rem}.timeline-item{border-left:2px solid var(--line);padding-left:1.2rem;transition:border-color .2s ease}.timeline-item:hover{border-color:var(--accent)}.timeline-header{display:flex;align-items:center;gap:.9rem}.timeline-header img.logo-tile{width:40px;height:40px;object-fit:contain;background:var(--bg-soft);border-radius:6px;padding:.35rem;border:1px solid var(--line)}.timeline-header img.logo-tile.light{background:#e6edf3}.timeline-header img.logo-tile.dark{background:var(--bg)}.timeline-item span{color:var(--muted);font-size:.85rem}.timeline.compact{margin-top:1.25rem}.section.cta{text-align:center;padding:5rem 0 6rem;background:radial-gradient(ellipse 50% 60% at 50% 100%,rgba(75,139,245,.06),transparent),var(--bg-soft);border-top:1px solid var(--line)}.section.cta h2{font-size:clamp(1.8rem,3vw,2.4rem)}.section.cta p{margin-top:.75rem;color:var(--text-secondary)}.section.cta .btn{margin-top:1.5rem}.case{background:var(--bg-card);border:1px solid var(--line);border-radius:12px;padding:2rem;transition:border-color .3s ease}.case:hover{border-color:var(--line-light)}.case-lite{border-radius:12px;border:1px solid var(--line);padding:1.75rem}.case-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.case-identity{display:flex;align-items:center;gap:1rem}.case-logo{width:40px;height:40px;object-fit:contain;background:var(--bg-soft);border:1px solid var(--line);border-radius:6px;padding:.35rem}.case-logo-light{background:#e6edf3}.case-logo-lg{width:80px;height:80px;padding:.5rem;border-radius:10px}.case-row{display:grid;grid-template-columns:minmax(100px,140px) 1fr;gap:1.75rem;align-items:start}.case-aside{display:flex;flex-direction:column;gap:.75rem;align-items:flex-start}.case-body h2{margin-bottom:.5rem}.case-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.25rem;margin-top:1.25rem}.cv-grid{margin-top:2rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.25rem}.logo-card{height:48px;display:flex;align-items:center;margin-bottom:.75rem}.logo-card img{height:40px;width:auto;object-fit:contain}.contact-form{margin-top:2rem;display:grid;gap:1.25rem;max-width:520px}.contact-form label{display:grid;gap:.5rem;color:var(--text);font-size:.88rem;font-weight:500}.contact-form input,.contact-form textarea{background:var(--bg-soft);border:1px solid var(--line-light);border-radius:8px;padding:.8rem 1rem;color:var(--text);font-family:inherit;font-size:.95rem;transition:border-color .2s ease,box-shadow .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 input::placeholder,.contact-form textarea::placeholder{color:var(--muted)}.contact-form .btn{margin-top:.5rem}.form-status{display:flex;flex-direction:column;gap:.25rem;padding:.75rem 1rem;border-radius:8px;border:1px solid transparent;background:#ffffff0a;color:var(--text);font-size:.9rem}.form-status.success{border-color:#4b8bf566;background:#4b8bf514}.form-status.error{border-color:#ef444466;background:#ef444414}.footer{margin-top:0;border-top:1px solid var(--line);padding:2rem 0;background:var(--bg)}.footer-inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem}.footer-title{font-family:var(--font-heading);font-size:1.1rem;color:var(--text)}.footer-subtitle{color:var(--muted);font-size:.82rem;margin-top:.3rem}.footer-links{display:flex;gap:1.5rem;color:var(--muted);font-size:.88rem}.footer-links a{transition:color .2s ease;position:relative}.footer-links a:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--accent);transition:width .2s ease}.footer-links a:hover{color:var(--accent)}.footer-links a:hover:after{width:100%}.footer-note{text-align:center;color:var(--muted);font-size:.78rem;margin-top:1.25rem}.projects-hero{padding-bottom:1rem}.projects-filter-bar{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.5rem}.filter-chip{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem 1rem;border-radius:6px;border:1px solid var(--line);background:transparent;color:var(--muted);font-size:.85rem;font-family:inherit;cursor:pointer;transition:all .2s ease}.filter-chip:hover{border-color:var(--accent);color:var(--text)}.filter-chip.active{background:var(--accent);border-color:transparent;color:var(--bg);font-weight:600}.filter-count{font-size:.7rem;opacity:.55;font-weight:500}.filter-chip.active .filter-count{opacity:.8}.projects-masonry{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;margin-top:2rem}.project-card{background:var(--bg-card);border:1px solid var(--line);border-radius:12px;padding:1.6rem;display:flex;flex-direction:column;gap:.9rem;transition:border-color .3s ease,box-shadow .3s ease,transform .3s ease}.project-card:hover{border-color:var(--line-light);box-shadow:0 8px 32px #0006,0 0 0 1px #4b8bf514;transform:translateY(-2px)}.project-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.project-card-identity{display:flex;align-items:center;gap:.7rem;min-width:0}.project-card-logo{width:40px;height:40px;object-fit:contain;background:var(--bg-soft);border:1px solid var(--line);border-radius:8px;padding:.3rem;flex-shrink:0}.project-card-logo.case-logo-light{background:#e6edf3}.project-card-icon{width:40px;height:40px;display:grid;place-items:center;background:var(--accent);border-radius:8px;font-family:var(--font-mono);font-size:1rem;font-weight:600;color:var(--bg);flex-shrink:0}.project-card-title{font-family:var(--font-body);font-size:1.1rem;font-weight:600;line-height:1.25;color:var(--text)}.project-card-subtitle{color:var(--muted);font-size:.8rem;margin-top:.1rem}.project-card-summary{color:var(--text-secondary);font-size:.88rem;line-height:1.55}.project-card-sections{display:grid;grid-template-columns:repeat(3,1fr);gap:.85rem;padding-top:.75rem;border-top:1px solid var(--line)}.project-card-section h3{font-family:var(--font-mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:.3rem;font-weight:500}.project-card-section p{font-size:.82rem;color:var(--text-secondary);line-height:1.45}.project-card-footer{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-top:auto;padding-top:.5rem}.project-card-footer .tag-row{margin-top:0}.project-card-link{display:inline-flex;align-items:center;gap:.3rem;color:var(--accent);font-size:.82rem;font-weight:500;white-space:nowrap;transition:color .2s ease}.project-card-link:hover{color:var(--text)}.project-card-link svg{transition:transform .2s ease}.project-card-link:hover svg{transform:translate(2px,-2px)}@media(max-width:768px){.nav-toggle{display:inline-flex;flex-direction:column;justify-content:center}.nav-links{position:absolute;top:calc(100% + 1px);left:0;right:0;background:#06080afa;border-bottom:1px solid var(--line);padding:1rem 1.5rem;display:none;flex-direction:column;align-items:flex-start;gap:.9rem;z-index:20}.nav-links.open{display:flex}.hero{padding:3.5rem 0 2.5rem}.hero-copy h1{font-size:clamp(1.8rem,7vw,2.4rem)}.hero-actions{gap:.5rem}.section{padding:2.5rem 0}.card,.case,.publication{padding:1.25rem}.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}.case-logo-lg{width:64px;height:64px}.projects-masonry{grid-template-columns:1fr;gap:1rem}.project-card{padding:1.25rem}.project-card-sections{grid-template-columns:1fr;gap:.6rem}.project-card-footer{flex-direction:column;align-items:flex-start;gap:.6rem}.publication{flex-direction:column;align-items:flex-start}}
