*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #fafafa;--color-bg-subtle: #f0f0f0;--color-text: #111111;--color-text-secondary: #555555;--color-text-tertiary: #757575;--color-accent: #333333;--color-accent-hover: #111111;--color-border: #d4d4d4;--color-border-subtle: #e8e8e8;--orb-color: 60, 60, 60;--font-serif: "Newsreader", Georgia, serif;--font-sans: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--space-4xl: 6rem;--space-5xl: 8rem;--max-width: 760px;--nav-height: 4.5rem;--transition-fast: .15s ease;--transition-base: .3s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--color-bg: #0e0e0e;--color-bg-subtle: #1a1a1a;--color-text: #eeeeee;--color-text-secondary: #999999;--color-text-tertiary: #a3a3a3;--color-accent: #aaaaaa;--color-accent-hover: #cccccc;--color-border: #2a2a2a;--color-border-subtle: #1f1f1f;--orb-color: 120, 120, 120}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0}body{font-family:var(--font-sans);font-weight:400;line-height:1.7;color:var(--color-text);background-color:var(--color-bg);min-height:100vh;margin:0;padding:0}h1,h2,h3,h4,h5,h6{font-family:var(--font-sans);font-weight:500;line-height:1.15;letter-spacing:-.02em}h1{font-size:3.5rem;line-height:1.05;letter-spacing:-.03em}h2{font-size:2rem;margin-bottom:var(--space-lg);letter-spacing:-.02em}h3{font-size:1.375rem;margin-bottom:var(--space-md)}p{margin-bottom:var(--space-lg)}p:last-child{margin-bottom:0}a{color:var(--color-text);text-decoration:underline;text-decoration-color:var(--color-border);text-underline-offset:3px;transition:text-decoration-color var(--transition-fast)}a:hover{text-decoration-color:var(--color-accent)}strong{font-weight:500}em{font-style:italic}small{font-size:.875rem;color:var(--color-text-secondary)}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 var(--space-xl)}main{padding:var(--space-3xl) 0 var(--space-4xl);min-height:calc(100vh - var(--nav-height))}nav{position:sticky;top:0;height:var(--nav-height);display:flex;align-items:center;background:color-mix(in srgb,var(--color-bg) 85%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border-subtle);z-index:100;margin:0}nav .container{display:flex;justify-content:space-between;align-items:center}.nav-brand{font-family:var(--font-mono);font-size:.875rem;font-weight:500;text-decoration:none;color:var(--color-text);letter-spacing:-.02em}.nav-links{display:flex;gap:var(--space-xl);list-style:none}.nav-link{font-family:var(--font-mono);font-size:.8125rem;font-weight:400;color:var(--color-text-tertiary);text-decoration:none;transition:color var(--transition-fast);letter-spacing:-.01em}.nav-link:hover,.nav-link.active{color:var(--color-text)}.nav-link:before{content:"/";opacity:.4;margin-right:1px}.page-header{margin-bottom:var(--space-2xl)}.page-title{margin-bottom:var(--space-sm)}.page-description{color:var(--color-text-secondary);font-size:1.0625rem}.section{margin-bottom:var(--space-4xl)}.section:last-child{margin-bottom:0}.section-title{font-family:var(--font-mono);font-size:.6875rem;font-weight:500;font-style:normal;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-tertiary);margin-bottom:var(--space-xl);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border-subtle)}.card{padding:var(--space-lg);background:var(--color-bg-subtle);border-radius:8px;margin-bottom:var(--space-md)}.item{padding:var(--space-lg) 0;border-bottom:1px solid var(--color-border-subtle)}.item:first-child{padding-top:0}.item:last-child{border-bottom:none;padding-bottom:0}.item-title{font-family:var(--font-serif);font-size:1.125rem;margin-bottom:var(--space-xs)}.item-meta{font-family:var(--font-mono);font-size:.75rem;color:var(--color-text-tertiary);margin-bottom:var(--space-sm);letter-spacing:.02em}.item-description{color:var(--color-text-secondary);font-size:.9375rem}.tags{display:flex;gap:var(--space-sm);flex-wrap:wrap}.tag{font-size:.75rem;font-weight:500;color:var(--color-text-secondary);background:var(--color-bg-subtle);padding:var(--space-xs) var(--space-sm);border-radius:4px;text-decoration:none;transition:background var(--transition-fast),color var(--transition-fast)}.tag:hover{background:var(--color-border);color:var(--color-text)}.post-list{display:flex;flex-direction:column}.post-item{display:block;padding:var(--space-xl) 0;border-bottom:1px solid var(--color-border-subtle);text-decoration:none;transition:padding-left .25s ease}.post-item:hover{padding-left:var(--space-md)}.post-item:first-child{padding-top:0}.post-item:last-child{border-bottom:none}.post-date{font-family:var(--font-mono);font-size:.6875rem;color:var(--color-text-tertiary);font-variant-numeric:tabular-nums;margin-bottom:var(--space-xs);letter-spacing:.03em;text-transform:uppercase}.post-title{font-family:var(--font-serif);font-size:1.5rem;color:var(--color-text);margin-bottom:var(--space-sm);transition:color .2s ease}.post-item:hover .post-title{color:var(--color-accent)}.post-excerpt{font-size:.9375rem;color:var(--color-text-secondary);line-height:1.6}.post-tag{display:inline-block;font-size:.6875rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--color-accent);margin-left:var(--space-sm)}.now-section{margin-bottom:var(--space-2xl)}.now-updated{font-family:var(--font-mono);font-size:.6875rem;color:var(--color-text-tertiary);margin-bottom:var(--space-3xl);letter-spacing:.05em;text-transform:uppercase}.now-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}.now-card{padding:var(--space-xl);background:var(--color-bg);border:1px solid var(--color-border);border-radius:0}.now-card.full-width{grid-column:1 / -1}.now-card-title{font-family:var(--font-mono);font-size:.6875rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-tertiary);margin-bottom:var(--space-md)}.now-card-content{font-size:1rem}.now-card-content p{margin-bottom:var(--space-sm)}.publication{padding:var(--space-lg) 0;border-bottom:1px solid var(--color-border-subtle)}.publication:first-child{padding-top:0}.publication:last-child{border-bottom:none}.publication-title{font-family:var(--font-serif);font-size:1.125rem;margin-bottom:var(--space-xs);line-height:1.4}.publication-authors{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.publication-venue{font-size:.8125rem;color:var(--color-text-tertiary);font-style:italic}.publication-links{margin-top:var(--space-sm);display:flex;gap:var(--space-md)}.publication-link{font-size:.8125rem;color:var(--color-accent);text-decoration:none}.publication-link:hover{text-decoration:underline}.timeline{position:relative}.timeline-item{position:relative;padding-left:var(--space-2xl);padding-bottom:var(--space-2xl)}.timeline-item:last-child{padding-bottom:0}.timeline-item:before{content:"";position:absolute;left:0;top:8px;width:8px;height:8px;border-radius:50%;background:var(--color-text);border:2px solid var(--color-bg);box-shadow:0 0 0 1px var(--color-text)}.timeline-item:after{content:"";position:absolute;left:3.5px;top:20px;bottom:0;width:1px;background:var(--color-border)}.timeline-item:last-child:after{display:none}.timeline-date{font-family:var(--font-mono);font-size:.6875rem;font-style:normal;color:var(--color-text-tertiary);margin-bottom:var(--space-xs);letter-spacing:.05em;text-transform:uppercase}.timeline-title{font-family:var(--font-sans);font-size:1.125rem;font-weight:500;margin-bottom:var(--space-xs)}.timeline-org{font-size:.9375rem;color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.timeline-description{font-size:.9375rem;color:var(--color-text-secondary)}.timeline-tech{font-family:var(--font-mono);font-size:.6875rem;color:var(--color-text-tertiary);margin-top:var(--space-sm);letter-spacing:.01em}footer{padding:var(--space-xl) 0;border-top:1px solid var(--color-border);margin-top:var(--space-5xl);position:relative}footer:before{display:none}footer .container{display:flex;justify-content:space-between;align-items:center}.footer-text{font-family:var(--font-mono);font-size:.75rem;color:var(--color-text-tertiary);font-style:normal;letter-spacing:.02em}.footer-links{display:flex;gap:var(--space-lg)}.footer-link{font-family:var(--font-mono);font-size:.75rem;color:var(--color-text-tertiary);text-decoration:none;transition:color var(--transition-fast)}.intro{margin-bottom:var(--space-5xl)}.intro-title{font-family:var(--font-sans);font-size:2.75rem;font-weight:500;margin-bottom:var(--space-xl);letter-spacing:-.04em;line-height:1.05}.intro-bio{font-size:1rem;color:var(--color-text-secondary);line-height:1.75}.intro-bio strong{color:var(--color-text)}.status{display:inline-flex;margin-right:var(--space-md);align-items:center;gap:var(--space-sm);font-family:var(--font-mono);font-size:.75rem;color:var(--color-text-secondary);margin-top:var(--space-xl);padding:var(--space-sm) var(--space-md);background:linear-gradient(135deg,#4ade8014,#4ade8005);border-radius:100px;border:1px solid rgba(74,222,128,.15);letter-spacing:.02em}.status-dot{width:8px;height:8px;border-radius:50%;background:#4ade80;position:relative}.status-dot:after{content:"";position:absolute;inset:-3px;border-radius:50%;border:1px solid rgba(74,222,128,.4);animation:statusPulse 2s ease-in-out infinite}@keyframes statusPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.6);opacity:0}}.quick-links{display:flex;gap:var(--space-lg);margin-top:var(--space-lg);flex-wrap:wrap}.quick-link{font-family:var(--font-mono);font-size:.8125rem;color:var(--color-text-secondary);text-decoration:none;display:inline-flex;align-items:center;gap:var(--space-sm);transition:color var(--transition-fast);position:relative;padding-bottom:2px}.quick-link:after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--color-text);transition:width .3s ease}.quick-link:hover{color:var(--color-text)}.quick-link:hover:after{width:100%}.prose{line-height:1.8}.prose h2{margin-top:var(--space-2xl);margin-bottom:var(--space-md)}.prose h3{margin-top:var(--space-xl)}.prose ul,.prose ol{margin-bottom:var(--space-lg);padding-left:var(--space-xl)}.prose li{margin-bottom:var(--space-sm)}.prose blockquote{border-left:2px solid var(--color-accent);padding-left:var(--space-lg);margin:var(--space-xl) 0;font-style:italic;color:var(--color-text-secondary)}.prose code{font-family:IBM Plex Mono,monospace;font-size:.9em;background:var(--color-bg-subtle);padding:2px 6px;border-radius:3px}.prose pre{background:var(--color-text);color:var(--color-bg);padding:var(--space-lg);border-radius:8px;overflow-x:auto;margin:var(--space-xl) 0}.prose pre code{background:none;padding:0}.prose table{width:100%;border-collapse:collapse;margin:var(--space-xl) 0;font-size:.9rem}.prose th,.prose td{padding:var(--space-sm) var(--space-md);text-align:left;border-bottom:1px solid var(--color-border)}.prose th{font-weight:500;color:var(--color-text);background:var(--color-bg-subtle);font-size:.8rem;text-transform:uppercase;letter-spacing:.03em}.prose td{color:var(--color-text-secondary)}.prose tr:hover td{background:var(--color-bg-subtle)}.prose td strong{color:var(--color-text)}@media(max-width:640px){.prose table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.prose th,.prose td{padding:var(--space-xs) var(--space-sm);font-size:.8rem}}.prose img{max-width:100%;height:auto;margin:var(--space-xl) 0;border-radius:4px}@media(max-width:640px){:root{--space-3xl: 3rem;--space-4xl: 4rem;--space-5xl: 5rem}html{font-size:16px}.container{padding:0 var(--space-lg)}h1{font-size:2.5rem}.intro-title{font-size:2.25rem}.section{margin-bottom:var(--space-3xl)}.nav-brand{font-size:.8125rem;white-space:nowrap}.nav-links{gap:var(--space-sm)}.nav-link{font-size:.75rem}.now-grid{grid-template-columns:1fr}footer .container{flex-direction:column;gap:var(--space-md);text-align:center}.quick-links{flex-direction:column;gap:var(--space-md)}}::selection{background:var(--color-accent);color:#fff}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@view-transition{navigation:auto}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}main{animation:fadeInUp .5s ease-out}.section{animation:fadeInUp .5s ease-out backwards}.section:nth-child(1){animation-delay:.1s}.section:nth-child(2){animation-delay:.2s}.section:nth-child(3){animation-delay:.3s}.section:nth-child(4){animation-delay:.4s}.nav-link{position:relative}.nav-link:after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--color-text);transition:width .3s ease}.nav-link:hover:after,.nav-link.active:after{width:100%}.card{transition:background .2s ease,border-color .2s ease}.card:hover{background:var(--color-bg-subtle);border-color:var(--color-text)}.now-card{transition:background .2s ease,border-color .2s ease}.now-card:hover{background:var(--color-bg-subtle);border-color:var(--color-text)}.timeline-title{transition:color .2s ease}.timeline-item:hover .timeline-title{color:var(--color-accent)}.publication-link{transition:color .15s ease}.publication-link:hover{color:var(--color-accent-hover)}.footer-link{transition:color .15s ease}.footer-link:hover{color:var(--color-text)}.intro-title{animation:titleReveal .8s ease-out}@keyframes titleReveal{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.timeline:before{content:"";position:absolute;left:2.5px;top:0;bottom:0;width:1px;background:linear-gradient(to bottom,var(--color-accent),var(--color-border) 20%,var(--color-border) 80%,transparent);transform:scaleY(0);transform-origin:top;animation:timelineReveal 1s ease-out .5s forwards}@keyframes timelineReveal{to{transform:scaleY(1)}}.footer-text{position:relative}.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}.reveal.revealed{opacity:1;transform:translateY(0)}::selection{background:var(--color-accent);color:#fff;text-shadow:none}::-moz-selection{background:var(--color-accent);color:#fff;text-shadow:none}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-accent)}*{scrollbar-width:thin;scrollbar-color:var(--color-border) var(--color-bg)}:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px;border-radius:2px}@media print{*{animation:none!important;transition:none!important}}html{transition:background-color .3s ease}body,nav,.card,.now-card{transition:background-color .3s ease,color .3s ease,border-color .3s ease}[data-theme=dark] .card:hover,[data-theme=dark] .now-card:hover{background:#1a1a1a}[data-theme=dark] .prose pre{background:#0f0e0e}[data-theme=dark] .prose code{background:var(--color-bg-subtle)}[data-theme=dark] ::selection{background:var(--color-accent);color:var(--color-bg)}[data-theme=dark] ::-webkit-scrollbar-track{background:var(--color-bg)}[data-theme=dark] ::-webkit-scrollbar-thumb{background:var(--color-border)}.theme-toggle{background:none;border:none;padding:var(--space-xs);cursor:pointer;color:var(--color-text-secondary);transition:color var(--transition-fast),transform var(--transition-fast);display:flex;align-items:center;justify-content:center;border-radius:4px;margin-left:var(--space-md)}.theme-toggle:hover{color:var(--color-text);transform:rotate(15deg)}.theme-toggle svg{width:18px;height:18px}.theme-toggle .sun-icon{display:none}.theme-toggle .moon-icon,[data-theme=dark] .theme-toggle .sun-icon{display:block}[data-theme=dark] .theme-toggle .moon-icon{display:none}[data-theme=dark] .spotify-wrapper{background:#121212}@media(max-width:480px){.nav-brand{font-size:.75rem}.nav-link:before{display:none}.nav-link{font-size:.6875rem}.nav-links{gap:var(--space-sm)}.theme-toggle{margin-left:var(--space-xs)}}.skip-link{position:fixed;top:-40px;left:0;background:var(--color-accent);color:#fff;padding:var(--space-sm) var(--space-md);z-index:1000;text-decoration:none;font-size:.875rem;transition:top .2s ease}.skip-link:focus{top:0}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.tag{border:1px solid transparent;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.tag:hover{border-color:#5a5a5a4d}[data-theme=dark] .tag:hover{border-color:#9696964d}.timeline-item:hover .timeline-date{color:var(--color-accent)}.timeline-date{transition:color .2s ease}.work-venue{font-family:var(--font-mono);background:none;padding:0;border-radius:0;margin-left:0}a[href^=http]:not([href*="johannesroth.com"]):after{content:" ↗";font-size:.75em;color:var(--color-accent);opacity:.6;transition:opacity .2s ease}a[href^=http]:not([href*="johannesroth.com"]):hover:after{opacity:1}a.nav-link[href^=http]:after,a.nav-brand[href^=http]:after,a.footer-link[href^=http]:after,a.quick-link[href^=http]:after,a.pub-link[href^=http]:after,a.tool-row[href^=http]:after,a.download-cv:after{content:none}.prose>p:first-of-type{position:relative;padding-left:1rem}.prose>p:first-of-type:before{content:"";position:absolute;left:0;top:.5em;bottom:.5em;width:2px;background:linear-gradient(to bottom,var(--color-accent),transparent);border-radius:1px}.page-description{position:relative}.page-description:first-letter{color:var(--color-accent);font-weight:500}.post-tag{position:relative}.prose th{border-bottom:2px solid var(--color-accent);border-bottom-color:#5a5a5a4d}[data-theme=dark] .prose th{border-bottom-color:#9696964d}.prose blockquote{background:#5a5a5a08;padding:var(--space-md) var(--space-lg);border-radius:0 4px 4px 0}[data-theme=dark] .prose blockquote{background:#9696960a}.prose pre{border-top:2px solid var(--color-accent)}hr,.divider{border:none;height:1px;background:linear-gradient(to right,transparent,var(--color-accent),transparent);opacity:.3;margin:var(--space-2xl) 0}.prose ul li::marker{color:var(--color-accent)}.prose ol li::marker{color:var(--color-accent);font-weight:500}:root,[data-theme=dark]{--color-midnight-canvas: #000000;--color-frost-white: #ffffff;--color-deep-shadow: #181818;--color-whisper-gray: #6d6d6d;--color-misty-gray: #636363;--gradient-deep-ocean: linear-gradient(90deg, rgb(160, 224, 171), rgb(255, 172, 46) 50%, rgb(165, 45, 37));--color-bg: var(--color-midnight-canvas);--color-bg-subtle: rgba(255, 255, 255, .055);--color-text: var(--color-frost-white);--color-text-secondary: rgba(255, 255, 255, .68);--color-text-tertiary: var(--color-whisper-gray);--color-accent: var(--color-frost-white);--color-accent-hover: var(--color-frost-white);--color-border: rgba(255, 255, 255, .3);--color-border-subtle: rgba(255, 255, 255, .14);--font-roobert: "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-raleway: "Raleway", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-sans: var(--font-roobert);--font-serif: var(--font-raleway);--font-mono: var(--font-roobert);--max-width: 1078px;--radius-cards: 10px;--radius-buttons: 75.024px}html{background:#000}body{font-family:var(--font-roobert);font-weight:400;line-height:1.25;color:var(--color-frost-white);background:linear-gradient(125deg,#a0e0ab30,#12181157 28%,#0000 54%),linear-gradient(24deg,#0000 35%,#ffac2e21 58%,#a52d252e),linear-gradient(180deg,#ffffff09,#0000 26%),#000;min-height:100vh;overflow-x:hidden;position:relative;isolation:isolate}body:before{display:none}body:after{display:none}h1,h2,h3,h4,h5,h6{font-family:var(--font-roobert);font-weight:400;letter-spacing:normal;color:var(--color-frost-white)}p,.intro-bio,.timeline-description,.tool-desc,.item-description,.post-excerpt,.page-description,.now-card-content,.publication-authors{color:#ffffffad}a{color:var(--color-frost-white);text-decoration-color:#ffffff4d}a:hover{text-decoration-color:var(--color-frost-white)}strong{color:var(--color-frost-white);font-weight:600}.container{max-width:var(--max-width)}main{padding-top:64px}nav{top:12px;height:auto;margin:0 12px;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-buttons);background:#00000052;backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px)}nav .container{min-height:56px;padding:0 8px 0 24px}.nav-brand,.nav-link,.footer-link,.download-cv,.nav-cv{font-family:var(--font-roobert);font-weight:400;letter-spacing:normal}.nav-brand{color:var(--color-frost-white)}.nav-links{gap:28px}.nav-link{color:#ffffffb8}.nav-link:before{content:none}.nav-link:hover{color:var(--color-frost-white)}.nav-cv,.download-cv,.not-found-link,.archive-toggle,.timeline-toggle-cta,.pub-toggle-cta,.pub-writeup summary{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:11px 28px;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-buttons)!important;color:var(--color-frost-white);background:#0000;text-decoration:none;transition:border-color .2s ease,background-color .2s ease,color .2s ease}.nav-cv{min-height:40px;padding:10px 24px}.download-cv:hover,.nav-cv:hover,.not-found-link:hover,.archive-toggle:hover,.timeline-toggle-cta:hover,.pub-toggle-cta:hover,.pub-writeup summary:hover{background:#63636373;border-color:#ffffffd1}.theme-toggle{display:none}.intro{position:relative;min-height:calc(100vh - 148px);display:grid;align-content:center;gap:28px;margin-bottom:152px!important;padding:64px 76px;border-radius:10px;background:linear-gradient(94deg,#a0e0ab2e,#ffac2e1f 45%,#a52d2533),#ffffff06}.intro:before{display:none}.scroll-cue{position:absolute;left:50%;bottom:18px;z-index:3;display:flex;justify-content:center;width:24px;height:38px;padding-top:8px;border:1px solid rgba(255,255,255,.24);border-radius:999px;color:#ffffff80;text-decoration:none;opacity:.62;transform:translate(-50%);transition:opacity .2s ease,border-color .2s ease,color .2s ease}.scroll-cue:before{content:"";width:4px;height:4px;border-radius:999px;background:currentColor;animation:scroll-cue-drift 1.8s ease-in-out infinite}.scroll-cue:hover,.scroll-cue:focus-visible{border-color:#ffffff7a;color:#ffffffd1;opacity:.9}@keyframes scroll-cue-drift{0%,to{transform:translateY(0);opacity:.35}48%{transform:translateY(13px);opacity:.9}}@media(prefers-reduced-motion:reduce){.scroll-cue:before{animation:none}}.intro-eyebrow{width:fit-content;margin:0;padding:8px 12px;border-top:1px solid rgba(255,255,255,.3);border-radius:var(--radius-buttons);color:#ffffffc7;font-size:12px;line-height:1.58}.intro .intro-name-row{display:grid!important;grid-template-columns:minmax(0,1fr) minmax(220px,320px);gap:48px!important;align-items:end!important;margin-bottom:28px!important}.intro .intro-title{grid-column:1;grid-row:1;margin:0!important;font-size:clamp(70px,8vw,108px)!important;line-height:.76!important;font-weight:400!important;letter-spacing:normal!important}.intro .intro-photo{grid-column:2;grid-row:1 / span 3;width:100%!important;height:auto!important;aspect-ratio:4 / 5;border-radius:10px!important;border:1px solid rgba(255,255,255,.18);background:#ffffff0a;box-shadow:none!important}.intro .intro-photo img{width:100%;height:100%;object-fit:cover;filter:none!important}.ascii-accent{display:none!important}.intro-bio{max-width:680px;font-size:18px!important;line-height:1.36!important}.status{justify-self:start!important;width:fit-content!important;border:1px solid rgba(255,255,255,.22)!important;border-radius:var(--radius-buttons)!important;background:#0000002e!important;color:#ffffffc7!important}.intro .download-cv{justify-self:start!important;width:fit-content!important}.intro-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:var(--space-xl)}.intro-actions .status,.intro-actions .download-cv{margin-top:0!important}.status-dot{background:#a0e0ab!important}.status-dot:after{border-color:#a0e0ab75!important}.section{margin-bottom:152px}.section-title,.page-title{font-family:var(--font-roobert)!important;font-size:clamp(39px,6vw,78px)!important;line-height:1.1!important;font-weight:300!important;letter-spacing:normal!important;text-transform:none!important;color:var(--color-frost-white)!important;border-bottom:0!important;padding-bottom:0!important}.page-header{margin-bottom:64px}.card,.now-card,.featured-item,.timeline-item,.publication,.post-item,.tool-row,.pub-link,.pub-writeup-content{border-radius:10px!important;border:1px solid rgba(255,255,255,.14)!important;background:#00000029!important;box-shadow:none!important;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}.timeline-item{padding:34px!important}.timeline-item:before{background:var(--color-frost-white)!important;border-color:#000!important;box-shadow:0 0 0 1px #ffffff73!important}.timeline-item:after,.timeline:before{background:#ffffff24!important}.timeline-title,.pub-title,.tool-name,.item-name,.paper-title,.post-title,.now-card-title,.publication-title{color:var(--color-frost-white)!important;font-weight:400!important;letter-spacing:normal!important}.timeline-date,.timeline-tech,.pub-year,.pub-meta,.tool-label,.tool-tech,.post-date,.item-meta,.featured-meta,.paper-venue,.paper-authors,.footer-text,.now-updated,.publication-venue{color:#ffffff7a!important;letter-spacing:normal!important}.pub-link,.tool-row,.post-item,.featured-item,.paper-entry{text-decoration:none!important}.pub-type,.tag,.post-tag,.item-badge,.draft-badge{border-radius:var(--radius-buttons)!important;background:#6363636b!important;color:var(--color-frost-white)!important;border:1px solid rgba(255,255,255,.18)}.tool-anim{filter:invert(1);opacity:.38}footer{border-top-color:#ffffff24}.footer-link{color:#ffffff94}.footer-link:hover{color:var(--color-frost-white)}.prose{color:#ffffffb8}.prose code,.prose pre,.prose blockquote,.prose th{border-radius:10px;background:#ffffff0f;color:var(--color-frost-white);border-color:#ffffff24}.prose img{border-radius:10px;filter:saturate(.82)}.reveal,.reveal.revealed{opacity:1!important;transform:none!important}main,.section,.intro-title,.intro,.timeline,.timeline:before{animation:none!important;opacity:1!important;transform:none!important}::selection{background:#ffac2ee6;color:#000}@media(max-width:760px){nav{margin:0 8px;border-radius:28px}nav .container{display:grid;grid-template-columns:1fr auto;padding:14px 16px;gap:14px}.nav-links{grid-column:1 / -1;width:100%;justify-content:flex-start;flex-wrap:wrap;gap:12px}.nav-link{font-size:13px}.nav-cv{display:none}.intro{min-height:auto;width:calc(100vw - 48px);padding-top:48px;padding-right:24px;padding-left:24px;max-width:calc(100vw - 48px);margin-bottom:96px!important;overflow:hidden}.intro .intro-name-row{grid-template-columns:1fr;gap:28px!important}.intro .intro-photo,.intro .intro-title{grid-column:1}.intro .intro-photo{grid-row:2;max-width:100%}.intro .intro-title{font-size:clamp(48px,15vw,62px)!important;line-height:.9!important;max-width:100%}.section{margin-bottom:96px}}body{background:radial-gradient(1200px 760px at 12% 8%,#a0e0ab2e,#0000 58%),radial-gradient(1040px 860px at 86% 20%,#a52d2538,#0000 62%),radial-gradient(900px 620px at 44% 82%,#ffac2e1f,#0000 64%),#000}body:before{content:"";display:block;position:fixed;inset:0;z-index:-1;pointer-events:none;background:linear-gradient(115deg,#ffffff0e,#fff0 30%),linear-gradient(180deg,#0000,#000000b8 68%,#000)}main{padding-bottom:24px}.intro{margin-bottom:128px!important;background:linear-gradient(100deg,#a0e0ab3b,#ffac2e1c 45%,#a52d2540),#ffffff05;overflow:hidden}.intro:after{content:"";position:absolute;inset:auto -8% -22% 24%;height:44%;background:var(--gradient-deep-ocean);filter:blur(68px);opacity:.14;pointer-events:none}.intro .intro-photo{background:#ffffff09}.intro .intro-photo img{object-position:center top;transform:scale(1.24);transform-origin:center 24%}.section{position:relative;scroll-margin-top:120px;margin-bottom:128px}.section:before{content:"";position:absolute;inset:-44px -42px auto;height:clamp(250px,32vw,420px);border-radius:10px;background:linear-gradient(100deg,#a0e0ab1c,#ffac2e0e 46%,#a52d2524),#ffffff03;opacity:.72;z-index:-1;mask-image:linear-gradient(to bottom,#000 0%,rgba(0,0,0,.84) 42%,transparent 100%)}.section:nth-of-type(2n):before{background:linear-gradient(78deg,#a52d251f,#00000008 42%,#a0e0ab17),#ffffff03}.section-title,.page-title{margin-bottom:48px!important;font-size:clamp(54px,8.5vw,94px)!important;line-height:.92!important}.timeline,.pub-list,.tools-list{border-top:1px solid rgba(255,255,255,.24)}.timeline{display:block}.timeline:before{content:none!important}.timeline-item,.timeline-hidden .timeline-item{display:grid;grid-template-columns:138px minmax(0,1fr);gap:28px;padding:28px 0!important;border:0!important;border-bottom:1px solid rgba(255,255,255,.16)!important;border-radius:0!important;background:transparent!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important}.timeline-item:before,.timeline-item:after{content:none!important}.timeline-date{grid-column:1;grid-row:1 / span 4;margin:0!important;padding-top:7px;font-size:11px!important;line-height:1.58!important}.timeline-title,.timeline-org,.timeline-description,.timeline-tech{grid-column:2}.timeline-title{font-size:clamp(24px,3vw,29px)!important;line-height:1.21!important;margin-bottom:8px!important}.timeline-org,.timeline-description{max-width:780px;font-size:16px!important;line-height:1.36!important}.timeline-tech{margin-top:18px!important;font-size:11px!important}.timeline-toggle,.pub-toggle{border-bottom:1px solid rgba(255,255,255,.16)}.timeline-toggle-cta,.pub-toggle-cta{width:100%;min-height:auto;padding:20px 0!important;border:0!important;border-radius:0!important;background:transparent!important}.timeline-toggle-line,.pub-toggle-line{background:#ffffff24!important}.timeline-toggle-text,.pub-toggle-text{color:#ffffff85!important}.timeline-toggle-cta:hover .timeline-toggle-text,.pub-toggle-cta:hover .pub-toggle-text{color:var(--color-frost-white)!important}.pub-list{display:block}.pub,.tool-entry{border:0!important;border-bottom:1px solid rgba(255,255,255,.16)!important}.pub-link,.pub-link:hover,.pub-link:focus,.tool-row,.tool-row:hover,.tool-row:focus{border:0!important;border-radius:0!important;background:transparent!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important}.pub-link{grid-template-columns:64px 1fr 18px!important;gap:28px!important;padding:26px 0!important}.pub-year{font-size:11px!important;line-height:1.58!important}.pub-title{font-size:clamp(18px,2.4vw,22px)!important;line-height:1.25!important;margin-bottom:8px!important}.pub-meta{font-size:11px!important;line-height:1.58!important}.pub-arrow{color:#ffffff75!important}.pub-writeup{margin:-6px 0 22px 92px!important}.pub-writeup summary{min-height:auto!important;width:fit-content;padding:0!important;border:0!important;border-radius:0!important;background:transparent!important;color:#ffffff80!important;font-size:12px!important;line-height:1.58!important}.pub-writeup summary:before{content:"+ notes"}.pub-writeup[open] summary:before{content:"- close notes"}.pub-writeup-content{max-width:760px!important;margin:18px 0 8px!important;padding:22px 0 0!important;border:0!important;border-top:1px solid rgba(255,255,255,.14)!important;border-radius:0!important;background:transparent!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;font-size:15px!important;line-height:1.52!important}.tools-heading{margin-top:96px!important}.tool-row{grid-template-columns:92px minmax(0,1fr) minmax(140px,auto)!important;gap:28px!important;align-items:baseline!important;padding:24px 0!important}.tool-label-col{gap:0!important}.tool-anim{display:none!important}.tool-label,.tool-tech{font-size:11px!important;line-height:1.58!important}.tool-name{font-family:var(--font-roobert)!important;font-size:clamp(18px,2.4vw,22px)!important;line-height:1.25!important;margin-bottom:7px!important}.tool-desc{max-width:650px;font-size:16px!important;line-height:1.36!important}.recognition-block{margin-top:48px!important;padding-top:28px!important;border-top-color:#ffffff3d!important;gap:16px!important}.recognition-line{font-size:16px!important;line-height:1.36!important}.recognition-award{font-weight:400!important}#contact{padding:clamp(36px,7vw,76px);border-radius:10px;background:linear-gradient(98deg,#a0e0ab14,#ffac2e09 48%,#a52d2517),#ffffff03}#contact .section-title{margin-bottom:32px!important}#contact p{max-width:760px;font-size:18px;line-height:1.36}a[href^=http]:not([href*="johannesroth.com"]):after{content:none!important}footer{margin-top:80px!important;padding:28px 0!important;border-top-color:#ffffff29!important}@media(max-width:760px){.section{margin-bottom:96px;scroll-margin-top:150px}.section:before{inset-inline:-18px}.section-title,.page-title{font-size:clamp(48px,15vw,68px)!important;margin-bottom:32px!important}.timeline-item,.timeline-hidden .timeline-item,.pub-link,.tool-row{grid-template-columns:1fr!important;gap:8px!important}.pub-writeup{margin-left:0!important}.tool-tech{white-space:normal!important}#contact{padding:32px 24px}.intro .intro-photo img{transform:scale(1.16)}}.intro{min-height:calc(100vh - 116px)!important;display:grid!important;align-content:stretch!important;padding:clamp(52px,6vw,76px) clamp(44px,6.4vw,86px)!important}.intro-copy{display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,.64fr);grid-template-rows:auto auto auto auto auto 1fr;column-gap:clamp(42px,6vw,86px);row-gap:0;align-items:center;min-height:100%}.intro .intro-eyebrow,.intro .intro-name-row,.intro .intro-bio,.intro .intro-actions,.intro .status,.intro .download-cv{grid-column:1}.intro .intro-eyebrow{align-self:end;margin-bottom:34px}.intro .intro-name-row{display:block!important;margin-bottom:clamp(46px,9vh,92px)!important}.intro .intro-title{max-width:7.4em}.intro .intro-photo{grid-column:2;grid-row:1 / -1;align-self:stretch;justify-self:end;position:relative;display:flex;align-items:flex-start;justify-content:center;width:100%!important;min-height:620px;aspect-ratio:auto;overflow:hidden;border:0!important;border-radius:0!important;background:transparent!important;box-shadow:none!important}.intro .intro-photo:before{content:"";position:absolute;right:-10%;top:26%;width:92%;height:64%;border-radius:999px;background:var(--gradient-deep-ocean);filter:blur(74px);opacity:.16;transform:rotate(-14deg)}.intro .intro-photo img{position:relative;z-index:1;width:auto;max-width:min(34vw,440px);height:min(calc(100% - 24px),calc(100vh - 168px));min-height:560px;max-height:none;object-fit:contain;object-position:center top;filter:drop-shadow(0 34px 58px rgba(0,0,0,.34))!important;transform:translateY(8px)!important}.recognition-block{display:grid!important;grid-template-columns:92px minmax(0,1fr);gap:28px!important;margin-top:64px!important;padding-top:0!important;border-top:0!important}.recognition-kicker{margin:0;padding-top:24px;color:#ffffff7a;font-size:11px;line-height:1.58;text-transform:uppercase}.recognition-grid{border-top:1px solid rgba(255,255,255,.24)}.recognition-line,.recognition-line:hover{display:grid!important;grid-template-columns:86px minmax(180px,.42fr) minmax(0,1fr);gap:24px;align-items:baseline;padding:20px 0;border-bottom:1px solid rgba(255,255,255,.16);color:inherit;text-decoration:none}.recognition-line--featured .recognition-award{font-size:22px;line-height:1.25}.recognition-year{color:#ffffff7a!important;font-size:11px!important;line-height:1.58!important}.recognition-note{color:#ffffffa8!important}@media(max-width:760px){.intro{width:100%!important;max-width:100%!important;min-height:auto!important;display:grid!important;padding:34px 24px 42px!important}.intro-copy{display:contents;min-height:0}.intro .intro-eyebrow,.intro .intro-name-row,.intro .intro-photo,.intro .intro-bio,.intro .intro-actions,.intro .status,.intro .download-cv{grid-column:1}.intro .intro-eyebrow{order:1;margin-bottom:28px}.intro .intro-name-row{order:2;margin-bottom:22px!important}.intro .intro-photo{order:3;grid-row:auto;width:100%!important;height:clamp(196px,58vw,260px)!important;min-height:0;margin:4px 0 30px;align-items:flex-start;justify-content:center;overflow:hidden;border-radius:10px!important}.intro .intro-photo:before{inset:30% 4% -30%;width:auto;height:auto;filter:blur(52px);opacity:.14}.intro .intro-photo img{height:clamp(460px,128vw,580px);max-height:none;max-width:none;width:auto;object-position:center top;transform:translateY(-3%) scale(1.03)!important}.intro .intro-bio{order:4}.intro .intro-actions{order:5;display:flex;align-items:center;gap:12px;flex-wrap:wrap}.intro .status,.intro .download-cv{margin-top:0!important}.recognition-block{grid-template-columns:1fr;gap:12px!important;margin-top:44px!important}.recognition-kicker{padding-top:0}.recognition-line,.recognition-line:hover{grid-template-columns:1fr!important;gap:6px;padding:18px 0}}@media(min-width:761px){.intro{grid-template-columns:minmax(0,1fr) minmax(360px,.74fr);column-gap:clamp(28px,4.8vw,76px);align-items:stretch!important;overflow:hidden!important;padding-bottom:0!important}.intro-copy{display:block;position:relative;z-index:2;align-self:center;max-width:min(100%,690px);min-height:auto;padding-bottom:clamp(52px,6vw,86px)}.intro .intro-eyebrow,.intro .intro-name-row,.intro .intro-bio,.intro .status,.intro .download-cv{position:relative;z-index:2}.intro .intro-name-row{margin-bottom:clamp(44px,8vh,82px)!important}.intro .intro-photo{grid-column:2;position:relative;z-index:1;align-self:stretch;justify-self:end;width:min(100%,560px)!important;min-height:0;display:flex;align-items:flex-end;justify-content:flex-end;overflow:hidden;pointer-events:none;background:transparent!important;border:0!important;box-shadow:none!important}.intro .intro-photo:before{display:none}.intro .intro-photo img{width:auto;height:100%;min-height:0;max-width:none;max-height:none;object-fit:contain;object-position:center bottom;transform:none!important;filter:none!important}}@media(max-width:760px){.intro .intro-photo{position:relative;height:clamp(216px,58vw,258px)!important;justify-content:center;overflow:hidden;background:transparent!important;border:0!important;box-shadow:none!important}.intro .intro-photo img{height:clamp(520px,142vw,620px);width:auto;max-width:none;transform:translateY(-4%) scale(1.02)!important}}@media(min-width:761px){.intro{height:min(760px,calc(100svh - 132px));min-height:0!important;max-height:820px}}@media(min-width:761px)and (max-height:920px){main{padding-top:52px}.intro{height:calc(100svh - 116px);margin-bottom:112px!important;padding-top:clamp(32px,4.6svh,48px)!important;padding-left:clamp(42px,5.4vw,70px)!important;padding-right:clamp(42px,5.4vw,70px)!important}.intro-copy{align-self:center;padding-bottom:clamp(30px,4.2svh,48px)}.intro-actions{margin-top:clamp(18px,3.2svh,28px)}.intro .intro-eyebrow{margin-bottom:clamp(22px,3.2svh,30px)}.intro .intro-title{font-size:clamp(62px,7.2vw,94px)!important;line-height:.78!important}.intro .intro-name-row{margin-bottom:clamp(28px,5.2svh,48px)!important}.intro-bio{max-width:610px;font-size:16px!important;line-height:1.28!important}.status{min-height:34px;padding:7px 16px!important;font-size:12px!important}.intro .download-cv{min-height:38px;padding:9px 24px;font-size:13px}.intro .intro-photo{width:min(100%,520px)!important}.intro .intro-photo img{height:100%}}@media(min-width:761px)and (max-height:780px){.intro{height:calc(100svh - 102px);padding-top:28px!important}.intro .intro-title{font-size:clamp(58px,6.8vw,86px)!important}.intro .intro-name-row{margin-bottom:24px!important}.intro-bio{font-size:15px!important;line-height:1.26!important}.intro .intro-photo img{height:100%}}@media(min-width:1600px){.container{max-width:min(1280px,calc(100vw - 120px))}main{padding-top:44px}.intro{grid-template-columns:minmax(0,1.08fr) minmax(390px,.78fr);column-gap:clamp(56px,5vw,84px);height:min(760px,calc(100svh - 116px));padding-top:44px!important;padding-left:clamp(64px,5.6vw,92px)!important;padding-right:clamp(64px,5.6vw,92px)!important}.intro-copy{align-self:start;max-width:720px;padding-bottom:42px}.intro .intro-eyebrow{margin-bottom:30px}.intro .intro-title{font-size:clamp(84px,5.7vw,98px)!important;line-height:.8!important}.intro .intro-name-row{margin-bottom:52px!important}.intro-bio{max-width:660px;font-size:17px!important;line-height:1.3!important}.intro .intro-photo{width:min(100%,540px)!important}}.intro .intro-title{font-size:clamp(58px,6.6vw,88px)!important;line-height:.82!important}.section-title,.page-title{font-size:clamp(42px,5.8vw,74px)!important;line-height:1!important}@media(min-width:761px)and (max-height:920px){.intro .intro-title{font-size:clamp(54px,6vw,78px)!important}}@media(min-width:761px)and (max-height:780px){.intro .intro-title{font-size:clamp(50px,5.6vw,72px)!important}}@media(min-width:1600px){.intro .intro-title{font-size:clamp(70px,4.8vw,82px)!important}.section-title,.page-title{font-size:clamp(56px,5.2vw,78px)!important}}@media(max-width:760px){.intro .intro-title{font-size:clamp(42px,12vw,54px)!important;line-height:.94!important}.section-title,.page-title{font-size:clamp(38px,12vw,56px)!important}}@media(max-width:760px){.container{padding-inline:clamp(16px,5vw,24px)}.intro{width:100%!important;max-width:100%!important;min-width:0!important;padding:34px clamp(18px,6vw,24px) 42px!important;overflow:hidden!important}.intro-copy,.intro .intro-name-row,.intro .intro-bio,.intro .intro-actions{width:100%;max-width:100%;min-width:0}.intro .intro-name-row{display:block!important;margin-bottom:22px!important}.intro .intro-title{max-width:6.2em;font-size:clamp(40px,11vw,48px)!important;line-height:.98!important;overflow-wrap:normal}.intro .intro-bio{font-size:clamp(15px,4vw,16px)!important;line-height:1.42!important}.intro .intro-photo{width:100%!important;max-width:100%!important}.intro .intro-actions{align-items:stretch}.intro .status,.intro .download-cv{max-width:100%}}html[data-theme=dark]{color-scheme:dark}html[data-theme=light]{color-scheme:light;background:#f7f9f7}.nav-actions{display:inline-flex;align-items:center;gap:10px}.theme-toggle{display:inline-flex!important;align-items:center;justify-content:center;width:40px;height:40px;margin-left:0!important;padding:0;border:1px solid var(--color-border);border-radius:var(--radius-buttons);color:var(--color-text-secondary);background:#0000;cursor:pointer;transition:border-color .2s ease,background-color .2s ease,color .2s ease}.theme-toggle:hover{color:var(--color-text);border-color:var(--color-text);background:var(--color-bg-subtle);transform:none}.theme-toggle svg{width:17px;height:17px}@media(max-width:760px){.nav-actions{justify-self:end}}[data-theme=light]{--color-midnight-canvas: #f7f9f7;--color-frost-white: #10140f;--color-deep-shadow: #ffffff;--color-whisper-gray: rgba(16, 20, 15, .5);--color-misty-gray: rgba(16, 20, 15, .62);--gradient-deep-ocean: linear-gradient(90deg, rgb(86, 146, 101), rgb(218, 155, 50) 50%, rgb(178, 70, 58));--color-bg: #f7f9f7;--color-bg-subtle: rgba(16, 20, 15, .06);--color-text: #10140f;--color-text-secondary: rgba(16, 20, 15, .68);--color-text-tertiary: rgba(16, 20, 15, .5);--color-accent: #1f3f2a;--color-accent-hover: #10140f;--color-border: rgba(16, 20, 15, .28);--color-border-subtle: rgba(16, 20, 15, .13);--orb-color: 45, 66, 52}[data-theme=light] body{color:var(--color-text);background:radial-gradient(1180px 760px at 10% 6%,#5692653d,#f7f9f700 60%),radial-gradient(980px 820px at 88% 18%,#b2463a29,#f7f9f700 62%),radial-gradient(820px 560px at 42% 82%,#da9b3224,#f7f9f700 66%),#f7f9f7}[data-theme=light] body:before{background:linear-gradient(115deg,#ffffffb8,#fff0 30%),linear-gradient(180deg,#f7f9f700,#f7f9f7c2 68%,#f7f9f7)}[data-theme=light] h1,[data-theme=light] h2,[data-theme=light] h3,[data-theme=light] h4,[data-theme=light] h5,[data-theme=light] h6,[data-theme=light] .nav-brand,[data-theme=light] .section-title,[data-theme=light] .page-title,[data-theme=light] .timeline-title,[data-theme=light] .pub-title,[data-theme=light] .tool-name,[data-theme=light] .item-name,[data-theme=light] .paper-title,[data-theme=light] .post-title,[data-theme=light] .now-card-title,[data-theme=light] .publication-title,[data-theme=light] strong{color:var(--color-text)!important}[data-theme=light] p,[data-theme=light] .intro-bio,[data-theme=light] .timeline-description,[data-theme=light] .timeline-org,[data-theme=light] .tool-desc,[data-theme=light] .item-description,[data-theme=light] .post-excerpt,[data-theme=light] .page-description,[data-theme=light] .now-card-content,[data-theme=light] .publication-authors,[data-theme=light] .recognition-note,[data-theme=light] .prose{color:var(--color-text-secondary)!important}[data-theme=light] .timeline-date,[data-theme=light] .timeline-tech,[data-theme=light] .pub-year,[data-theme=light] .pub-meta,[data-theme=light] .tool-label,[data-theme=light] .tool-tech,[data-theme=light] .post-date,[data-theme=light] .item-meta,[data-theme=light] .featured-meta,[data-theme=light] .paper-venue,[data-theme=light] .paper-authors,[data-theme=light] .footer-text,[data-theme=light] .now-updated,[data-theme=light] .publication-venue,[data-theme=light] .recognition-kicker,[data-theme=light] .recognition-year{color:var(--color-text-tertiary)!important}[data-theme=light] a{color:var(--color-text);text-decoration-color:#10140f47}[data-theme=light] a:hover{text-decoration-color:var(--color-text)}[data-theme=light] nav{border-color:#10140f1f;background:#ffffff8f;box-shadow:0 18px 48px #10140f14}[data-theme=light] .nav-link{color:#10140f9e}[data-theme=light] .nav-link:hover{color:var(--color-text)}[data-theme=light] .nav-cv,[data-theme=light] .download-cv,[data-theme=light] .not-found-link,[data-theme=light] .archive-toggle,[data-theme=light] .timeline-toggle-cta,[data-theme=light] .pub-toggle-cta,[data-theme=light] .pub-writeup summary{border-color:#10140f40!important;color:var(--color-text)!important;background:#ffffff3d!important}[data-theme=light] .download-cv:hover,[data-theme=light] .nav-cv:hover,[data-theme=light] .not-found-link:hover,[data-theme=light] .archive-toggle:hover,[data-theme=light] .timeline-toggle-cta:hover,[data-theme=light] .pub-toggle-cta:hover,[data-theme=light] .pub-writeup summary:hover{background:#10140f12!important;border-color:#10140f85!important}[data-theme=light] .theme-toggle{border-color:#10140f38;color:#10140fa8;background:#ffffff47}[data-theme=light] .theme-toggle:hover{border-color:#10140f8a;color:var(--color-text);background:#10140f12}[data-theme=light] .intro{background:linear-gradient(98deg,#56926533,#da9b321a 48%,#b2463a24),#ffffff70!important;box-shadow:inset 0 1px #ffffff94}[data-theme=light] #contact{background:linear-gradient(98deg,#56926513,#da9b3209 48%,#b2463a0e),#ffffff42!important;box-shadow:none}[data-theme=light] .intro-eyebrow{border-top-color:#10140f42;color:#10140fad;background:#fff3}[data-theme=light] .intro:after{opacity:.2}[data-theme=light] .intro .intro-photo:before{opacity:.18}[data-theme=light] .scroll-cue{border-color:#10140f2e;color:#10140f70}[data-theme=light] .scroll-cue:hover,[data-theme=light] .scroll-cue:focus-visible{border-color:#10140f5c;color:#10140fad}[data-theme=light] .status{border-color:#56926557!important;background:#ffffff57!important;color:var(--color-text-secondary)!important}[data-theme=light] .section:before{background:linear-gradient(100deg,#56926521,#da9b3212 46%,#b2463a1a),#ffffff57!important;opacity:.88}[data-theme=light] .section:nth-of-type(2n):before{background:linear-gradient(78deg,#b2463a1a,#ffffff38 42%,#5692651f),#ffffff47!important}[data-theme=light] .timeline,[data-theme=light] .pub-list,[data-theme=light] .tools-list,[data-theme=light] .recognition-grid{border-top-color:#10140f3d!important}[data-theme=light] .timeline-item,[data-theme=light] .timeline-hidden .timeline-item,[data-theme=light] .timeline-toggle,[data-theme=light] .pub-toggle,[data-theme=light] .pub,[data-theme=light] .tool-entry,[data-theme=light] .recognition-line,[data-theme=light] .recognition-line:hover{border-bottom-color:#10140f26!important}[data-theme=light] .card,[data-theme=light] .now-card,[data-theme=light] .featured-item{border-color:#10140f21!important;background:#fff6!important}[data-theme=light] .pub-link,[data-theme=light] .pub-link:hover,[data-theme=light] .pub-link:focus,[data-theme=light] .tool-row,[data-theme=light] .tool-row:hover,[data-theme=light] .tool-row:focus,[data-theme=light] .post-item{background:transparent!important}[data-theme=light] .timeline-toggle-line,[data-theme=light] .pub-toggle-line{background:#10140f24!important}[data-theme=light] .timeline-toggle-text,[data-theme=light] .pub-toggle-text,[data-theme=light] .pub-arrow,[data-theme=light] .pub-writeup summary{color:#10140f80!important}[data-theme=light] .timeline-toggle-cta:hover .timeline-toggle-text,[data-theme=light] .pub-toggle-cta:hover .pub-toggle-text{color:var(--color-text)!important}[data-theme=light] .pub-writeup-content{border-top-color:#10140f24!important;color:var(--color-text-secondary)!important}[data-theme=light] .pub-type,[data-theme=light] .tag,[data-theme=light] .post-tag,[data-theme=light] .item-badge,[data-theme=light] .draft-badge{border-color:#10140f1f!important;background:#10140f12!important;color:var(--color-text)!important}[data-theme=light] .recognition-line,[data-theme=light] .recognition-line:hover{color:var(--color-text)}[data-theme=light] footer{border-top-color:#10140f29!important}[data-theme=light] .footer-link{color:#10140f94}[data-theme=light] .footer-link:hover{color:var(--color-text)}[data-theme=light] .prose code,[data-theme=light] .prose blockquote,[data-theme=light] .prose th{background:#ffffff7a;color:var(--color-text);border-color:#10140f24}[data-theme=light] .prose pre{background:#10140f;color:#f7f9f7;border-color:#5692656b}[data-theme=light] .prose pre code{background:none;color:inherit}[data-theme=light] .prose img{filter:saturate(.98)}[data-theme=light] .spotify-wrapper{background:#ffffff70}[data-theme=light] ::selection{background:#56926542;color:var(--color-text)}[data-theme=light] *{scrollbar-color:rgba(16,20,15,.28) #f7f9f7}[data-theme=light] ::-webkit-scrollbar-track{background:#f7f9f7}[data-theme=light] ::-webkit-scrollbar-thumb{background:#10140f3d}.nav-menu-toggle{display:none;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:1px solid var(--color-border);border-radius:var(--radius-buttons);color:var(--color-text-secondary);background:#0000;cursor:pointer;transition:border-color .2s ease,background-color .2s ease,color .2s ease}.nav-menu-toggle:hover{color:var(--color-text);border-color:var(--color-text);background:var(--color-bg-subtle)}.nav-menu-lines,.nav-menu-lines:before,.nav-menu-lines:after{display:block;width:15px;height:1.5px;border-radius:999px;background:currentColor;transition:transform .2s ease,opacity .2s ease}.nav-menu-lines{position:relative}.nav-menu-lines:before,.nav-menu-lines:after{content:"";position:absolute;left:0}.nav-menu-lines:before{transform:translateY(-5px)}.nav-menu-lines:after{transform:translateY(5px)}nav[data-menu-open=true] .nav-menu-lines{background:transparent}nav[data-menu-open=true] .nav-menu-lines:before{transform:rotate(45deg)}nav[data-menu-open=true] .nav-menu-lines:after{transform:rotate(-45deg)}@media(max-width:760px){main{padding-top:26px!important}nav{margin:8px 10px 0!important;border-radius:var(--radius-buttons)!important}nav[data-menu-open=true]{border-radius:28px!important}nav .container{display:grid!important;grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"brand actions" "links links";align-items:center;min-height:60px;padding:8px 10px 8px 22px!important;gap:0 10px!important}.nav-brand{grid-area:brand;min-width:0;font-size:15px!important}.nav-actions{grid-area:actions;justify-self:end;gap:8px}.theme-toggle,.nav-menu-toggle{width:38px;height:38px;flex:0 0 38px}.nav-menu-toggle{display:inline-flex}.nav-cv{display:none!important}.nav-links{grid-area:links;display:none!important;width:100%;margin-top:10px;padding-top:10px;border-top:1px solid var(--color-border-subtle);flex-direction:column;align-items:flex-start;gap:4px!important}nav[data-menu-open=true] .nav-links{display:flex!important}.nav-link{padding:5px 0;font-size:14px!important;line-height:1.4}.section{scroll-margin-top:96px!important}.scroll-cue{display:none}.section:before{content:""!important;display:block!important;inset:-20px -14px auto!important;height:clamp(160px,42vw,250px)!important;border-radius:18px!important;background:linear-gradient(104deg,#5692651f,#da9b320f 48%,#b2463a1a),#fff3!important;opacity:.76!important;mask-image:linear-gradient(to bottom,#000 0%,rgba(0,0,0,.68) 54%,transparent 100%)!important;-webkit-mask-image:linear-gradient(to bottom,#000 0%,rgba(0,0,0,.68) 54%,transparent 100%)!important}.section:nth-of-type(2n):before{background:linear-gradient(82deg,#b2463a17,#ffffff2e 44%,#5692651c),#ffffff29!important}#contact:before{content:none!important;display:none!important}.intro{padding-top:30px!important;margin-bottom:76px!important}.intro .intro-eyebrow{display:none!important}.intro .intro-name-row{margin-bottom:8px!important}.intro .intro-photo{margin-top:0!important;margin-bottom:14px!important}.intro .intro-photo img{transform:translateY(1%) scale(1.02)!important}.intro .intro-bio{margin:0!important}.intro .intro-bio+.intro-bio{margin-top:14px!important}.intro .intro-actions{margin-top:18px!important;gap:10px}.intro .status{padding:9px 14px!important}}@media(max-width:480px){.section:before{inset:-20px calc(-1*clamp(16px,5vw,24px)) auto calc(-1*clamp(16px,5vw,24px))!important;border-radius:0 0 18px 18px!important}}@media(min-width:451px)and (max-width:760px){.intro .intro-photo{height:clamp(250px,56vw,360px)!important}.intro .intro-photo img{height:clamp(450px,92vw,570px)!important;transform:translate(2%,1%) scale(1)!important}}@media(min-width:761px)and (max-width:1599px){.intro{grid-template-columns:minmax(0,1fr) minmax(clamp(300px,34vw,500px),.72fr);column-gap:clamp(24px,4vw,58px);min-height:clamp(640px,calc(100svh - 112px),760px)!important;height:auto!important;overflow:visible!important;padding-left:clamp(34px,5vw,70px)!important;padding-right:clamp(34px,5vw,70px)!important}.intro-copy{min-width:0;max-width:min(100%,650px);padding-bottom:clamp(30px,4.5vw,64px)}.intro .intro-title{max-width:100%;font-size:clamp(50px,5.4vw,78px)!important;line-height:.88!important;overflow-wrap:normal}.intro .intro-name-row{margin-bottom:clamp(28px,4.6vw,52px)!important}.intro-bio{max-width:min(100%,600px);font-size:clamp(15px,1.2vw,17px)!important;line-height:1.34!important}.intro .intro-photo{width:min(100%,500px)!important}.intro .intro-photo img{transform:translate(2%)!important}}.timeline-title{margin-bottom:0!important}.timeline-org{display:block;max-width:min(100%,780px);margin:-1px 0 8px!important;font-size:12px!important;line-height:1.45!important;color:var(--color-text-tertiary)!important;text-transform:uppercase;letter-spacing:.04em!important}.timeline-org:before{content:none}.timeline-description{max-width:780px;margin:0!important;font-size:16px!important;line-height:1.36!important}.timeline-tech{margin-top:12px!important}@media(max-width:760px){.timeline-title{font-size:clamp(23px,6.2vw,30px)!important;line-height:1.14!important;margin-bottom:0!important}.timeline-org{margin:-1px 0 8px!important;font-size:11px!important;line-height:1.4!important}.timeline-description{font-size:clamp(15px,4vw,16px)!important;line-height:1.42!important}.timeline-tech{margin-top:10px!important}}@media(min-width:761px)and (max-width:1050px){.intro{grid-template-columns:minmax(0,1fr) minmax(270px,.62fr);column-gap:clamp(18px,3vw,32px);padding-left:clamp(28px,4vw,46px)!important;padding-right:clamp(28px,4vw,46px)!important}.intro .intro-title{font-size:clamp(46px,6vw,62px)!important;line-height:.92!important}.intro .intro-name-row{margin-bottom:clamp(22px,3.5vw,34px)!important}.intro-bio{max-width:100%;font-size:15px!important;line-height:1.34!important}.intro .intro-photo{width:min(100%,420px)!important}}@media(min-width:1280px)and (max-width:1599px){.container{max-width:min(1240px,calc(100vw - 88px))}.intro{grid-template-columns:minmax(0,1.06fr) minmax(360px,.74fr);column-gap:clamp(44px,4vw,68px);height:min(760px,calc(100svh - 116px))!important;min-height:0!important;overflow:hidden!important;padding-left:clamp(54px,5vw,84px)!important;padding-right:clamp(54px,5vw,84px)!important}.intro-copy{align-self:center;max-width:690px;padding-bottom:clamp(42px,5vw,76px)}.intro .intro-title{max-width:7.4em;font-size:clamp(64px,5.2vw,82px)!important;line-height:.84!important}.intro .intro-name-row{margin-bottom:clamp(42px,5.4vw,68px)!important}.intro-bio{max-width:640px;font-size:16px!important;line-height:1.32!important}.intro .intro-photo{width:min(100%,520px)!important}.intro .intro-photo img{transform:translate(2%)!important}}@media(min-width:1280px)and (max-width:1599px)and (max-height:849px){.intro{overflow:visible!important}.intro .intro-photo{width:min(100%,500px)!important;overflow:visible}.intro .intro-photo img{width:auto!important;height:100%!important;min-height:0;max-width:none!important;object-fit:contain!important;object-position:center bottom!important;transform:translate(2%)!important}}@media(min-width:761px)and (max-height:849px){main{padding-top:clamp(32px,5svh,42px)!important}}
