:root{--sans-serif-font: "Inter Safe", "Inter Fallback", Helvetica, Arial, sans-serif;--serif-font: "Source Serif Safe", "Serif Fallback", "Georgia", serif;--code-font: "Cascadia Code Safe", monospace;font-optical-sizing:none;letter-spacing:-.011em}@font-face{font-family:"Inter Safe";src:local("Inter"),url("fonts/Inter4.woff2") format("woff2");font-display:optional}@font-face{font-family:"Source Serif Safe";src:local("Source Serif"),url("fonts/SourceSerif4Variable-Roman.ttf.woff2") format("woff2");font-display:optional}@font-face{font-family:"Cascadia Code Safe";src:local("Cascadia Code"),url("fonts/CascadiaCode-SemiLight.woff2") format("woff2");font-display:optional}@font-face{font-family:"Inter Fallback";src:local("Arial"),local("Helvetica Neue"),local("Helvetica");ascent-override:90.49%;descent-override:22.56%;line-gap-override:0%;size-adjust:107.06%}@font-face{font-family:"Serif Fallback";src:local("Georgia"),local("Times New Roman");ascent-override:89.5%;descent-override:24.2%;line-gap-override:0%;size-adjust:104.5%}html{scroll-behavior:smooth;scroll-padding-top:2rem;-webkit-text-size-adjust:100%;text-size-adjust:100%}body{line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}h1,h2,h3,h4,h5,h6,.section-title,.front-section-title{text-wrap:balance}p{line-height:1.6;text-wrap:pretty}main ul li,main ol li{line-height:1.5}main ul li+li,main ol li+li{margin-top:.5em}@media (pointer: coarse){.post-item,.blog-post-card,.blog-featured,.h-timeline-item,.item-card,.project-grid-card,.section-more a,.nav-links,.navbar>.nav-navs .nav-links{min-height:28px;padding-top:.25rem;padding-bottom:.25rem;font-size:1.2rem}.filter-controls .taxonomy-item a{min-height:20px}}a:hover{background-color:rgba(0,0,0,0) !important;color:var(--primary-color) !important}a:hover::before{display:none !important}a.external:hover::after{background-color:var(--primary-color) !important}a:focus-visible,button:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px;border-radius:.25rem}.cards .card{display:flex;flex-direction:column;border-radius:.5rem;overflow:hidden;background:var(--bg-2);border:1px solid color-mix(in srgb, var(--primary-color) 8%, rgba(0,0,0,0));box-shadow:0 2px 8px rgba(0,0,0,.04);transition:box-shadow .3s cubic-bezier(.25, 1, .5, 1),border-color .3s ease,transform .3s cubic-bezier(.25, 1, .5, 1)}.cards .card:hover{background-color:var(--bg-2) !important;border-color:color-mix(in srgb, var(--primary-color) 30%, rgba(0,0,0,0));box-shadow:0 8px 24px color-mix(in srgb, var(--primary-color) 12%, rgba(0,0,0,.08));transform:translateY(-3px)}.cards .card:hover .card-title{color:var(--primary-color) !important}.cards .card:hover .card-description{color:var(--text-color-high-contrast) !important}.cards .card:hover .card-tag{background:color-mix(in srgb, var(--primary-color) 25%, rgba(0,0,0,0))}.cards .card:hover .card-image,.cards .card:hover .card-image-placeholder{transform:scale(1.04)}.cards .card .card-info{position:relative;z-index:1;background:var(--bg-2);padding:.75rem 1rem 1rem !important;text-align:center !important}.cards .card .card-image{margin:0 !important;width:100% !important;height:auto !important;aspect-ratio:16/9;object-fit:cover;display:block;transition:transform .5s cubic-bezier(.25, 1, .5, 1)}.cards .card .card-image-placeholder{width:100%;height:0;padding-bottom:56.25%;background:color-mix(in srgb, var(--primary-color) 8%, rgba(0,0,0,0));position:relative;transition:transform .5s cubic-bezier(.25, 1, .5, 1);transform-origin:center}.cards .card .card-image-placeholder::after{content:"";position:absolute;inset:0;background-image:url("/img/placeholder-project.svg");background-repeat:no-repeat;background-position:center;background-size:60%;opacity:.6}.cards .card .card-title{font-size:1.05rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-color-high-contrast) !important;transition:color .2s ease}.cards .card .card-description{font-size:.85rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;color:var(--meta-color) !important;transition:color .2s ease}.cards .card .card-tags{display:flex;gap:.35rem;flex-wrap:wrap;justify-content:center;margin-top:.6rem}.cards .card .card-tag{font-size:.58rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--primary-color);background:color-mix(in srgb, var(--primary-color) 12%, rgba(0,0,0,0));padding:.15rem .4rem;border-radius:.25rem;line-height:1.2;text-decoration:none;transition:background .2s ease,color .2s ease}.cards .card .card-tag:hover,.cards .card .card-tag:focus-visible{background:color-mix(in srgb, var(--primary-color) 25%, rgba(0,0,0,0))}.filter-controls .taxonomy-item a:hover{background:color-mix(in srgb, var(--primary-color) 25%, rgba(0,0,0,0)) !important}.project-grid-card:hover{color:#fff !important}.navbar .nav-navs{margin-left:auto}.navbar .nav-links{font-size:1.05em;font-weight:600}.nav-actions{display:flex;align-items:center;gap:.25rem;margin-left:.15rem}.nav-actions::before{content:"";display:block;width:1px;height:1.15em;background:color-mix(in srgb, var(--primary-color) 15%, rgba(0,0,0,0));margin-right:.4rem}.nav-actions .search-icon{margin-inline:0 !important}.nav-actions .theme-switcher{margin-inline-start:0 !important}.nav-hamburger{display:none;flex-direction:column;align-items:center;justify-content:center;gap:4px;width:2.25rem;height:2.25rem;padding:0;margin-left:.15rem;background:none;border:none;cursor:pointer;-webkit-tap-highlight-color:rgba(0,0,0,0);border-radius:.375rem;transition:background .2s ease}.nav-hamburger:hover,.nav-hamburger:focus-visible{background:color-mix(in srgb, var(--primary-color) 8%, rgba(0,0,0,0))}.nav-hamburger span{display:block;width:1.1rem;height:1.5px;background:var(--text-color);border-radius:2px;transition:transform .3s cubic-bezier(.4, 0, .2, 1),opacity .2s ease,width .25s ease;transform-origin:center}.navbar.nav-open .nav-hamburger span:nth-child(1){transform:translateY(5.5px) rotate(45deg)}.navbar.nav-open .nav-hamburger span:nth-child(2){opacity:0;width:0}.navbar.nav-open .nav-hamburger span:nth-child(3){transform:translateY(-5.5px) rotate(-45deg)}#banner-home-img{border-radius:.5rem !important;box-shadow:0 4px 24px color-mix(in srgb, var(--primary-color) 12%, rgba(0,0,0,.12));border:3px solid color-mix(in srgb, var(--primary-color) 20%, rgba(0,0,0,0)) !important}#banner-container-home{display:flex !important;align-items:flex-start !important;gap:0 !important}#home-banner-text{flex:1;min-width:0}#image-container-home{align-self:flex-start !important;overflow:visible !important;max-width:25% !important;flex-shrink:0 !important;padding-inline-start:1.25rem !important;margin:0 !important;margin-top:.5rem !important}#banner-home-subtitle p{text-align:justify;line-height:1.6;font-size:1rem}.front-page-sections{margin-top:2rem}.front-section{margin-bottom:2.5rem}.front-section-title{font-size:1.15rem;font-weight:600;margin-bottom:.85rem;padding-bottom:.3rem;border-bottom:2px solid color-mix(in srgb, var(--primary-color) 18%, rgba(0,0,0,0));color:var(--text-color);letter-spacing:.03em}.posts-first .section-title{font-size:1.15rem !important;font-weight:600;letter-spacing:.03em}.page-title-row{display:flex;align-items:center;gap:1rem;border-bottom:var(--divider-color) solid .5px;padding-bottom:8px}.page-title-row .section-title{flex:1;min-width:0;border-bottom:none;padding-bottom:0}.cv-button{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;flex-shrink:0;padding:.5rem .85rem;border-radius:.375rem;background:var(--primary-color);color:var(--hover-color) !important;text-decoration:none;font-weight:600;font-size:.85rem;letter-spacing:.02em;white-space:nowrap;transition:transform .2s cubic-bezier(.25, 1, .5, 1),box-shadow .2s ease,opacity .2s ease}.cv-button svg{flex-shrink:0;opacity:.9}.cv-button:hover{background:var(--primary-color) !important;color:var(--hover-color) !important;opacity:.95;transform:translateY(-2px);box-shadow:0 4px 14px color-mix(in srgb, var(--primary-color) 35%, rgba(0,0,0,0))}.cv-button:active{transform:translateY(0);box-shadow:0 1px 4px color-mix(in srgb, var(--primary-color) 20%, rgba(0,0,0,0))}.journey-map{display:flex;align-items:center;justify-content:center;gap:0;padding:1.5rem 0;overflow-x:auto;scrollbar-width:thin;scrollbar-color:color-mix(in srgb, var(--primary-color) 20%, rgba(0,0,0,0)) rgba(0,0,0,0)}.journey-step{display:flex;flex-direction:column;align-items:center;text-align:center;min-width:6rem;max-width:10rem;padding:.75rem .5rem;border-radius:.375rem;background:color-mix(in srgb, var(--primary-color) 5%, rgba(0,0,0,0));border:1px solid color-mix(in srgb, var(--primary-color) 12%, rgba(0,0,0,0));cursor:default;transition:transform .3s cubic-bezier(.25, 1, .5, 1),box-shadow .3s ease,border-color .3s ease}.journey-step:hover{transform:translateY(-3px);box-shadow:0 6px 16px color-mix(in srgb, var(--primary-color) 10%, rgba(0,0,0,.06));border-color:color-mix(in srgb, var(--primary-color) 30%, rgba(0,0,0,0))}.journey-step:hover .journey-info strong{color:var(--primary-color)}.journey-step:hover .journey-info span{color:var(--text-color-high-contrast)}.journey-icon{font-size:1.85rem;margin-bottom:.5rem;line-height:1}.journey-info{display:flex;flex-direction:column;gap:.15rem}.journey-info strong{font-size:.85rem;color:var(--text-color);transition:color .2s ease}.journey-info span{font-size:.75rem;color:var(--meta-color);line-height:1.25;transition:color .2s ease}.journey-connector{width:1.75rem;height:2px;background:var(--primary-color);flex-shrink:0}.journey-continuation{width:2.75rem;height:2px;flex-shrink:0;background:linear-gradient(90deg, var(--primary-color), rgba(0,0,0,0))}.section-more{text-align:right;margin-top:.5rem;font-size:.85rem;font-weight:500}.section-more a{text-decoration:none;color:color-mix(in srgb, var(--primary-color) 70%, rgba(0,0,0,0));transition:color .2s ease;display:inline-block;padding:.3rem 0}.section-more a:hover{color:var(--primary-color)}.item-cards,.post-list{display:flex;flex-direction:column;gap:.625rem}.post-list{gap:.25rem}.item-card{display:flex;gap:1.25rem;padding:.85rem;border-radius:.375rem;border:1px solid color-mix(in srgb, var(--primary-color) 10%, rgba(0,0,0,0));background:color-mix(in srgb, var(--primary-color) 3%, rgba(0,0,0,0));transition:background .25s ease,border-color .25s ease,transform .25s cubic-bezier(.25, 1, .5, 1)}.item-card:hover{background:color-mix(in srgb, var(--primary-color) 6%, rgba(0,0,0,0));border-color:color-mix(in srgb, var(--primary-color) 30%, rgba(0,0,0,0));transform:translateY(-2px)}.item-card:hover .item-card-title{color:var(--primary-color)}.item-card:hover .item-card-description{color:var(--text-color-high-contrast)}.item-card:hover .item-card-tag{background:color-mix(in srgb, var(--primary-color) 25%, rgba(0,0,0,0))}.post-item{display:block;padding:.75rem .85rem;border-radius:.25rem;border-left:3px solid color-mix(in srgb, var(--primary-color) 25%, rgba(0,0,0,0));text-decoration:none;color:inherit;background:rgba(0,0,0,0);transition:border-color .25s ease,background .25s ease,transform .25s ease}.post-item:hover,.post-item:focus-visible{border-left-color:var(--primary-color);background:color-mix(in srgb, var(--primary-color) 4%, rgba(0,0,0,0));transform:translateX(2px)}.post-item:hover .post-item-title,.post-item:focus-visible .post-item-title{color:var(--primary-color)}.post-item:hover .post-item-description,.post-item:focus-visible .post-item-description{color:var(--text-color-high-contrast)}.post-item:hover .post-item-tag,.post-item:focus-visible .post-item-tag{background:color-mix(in srgb, var(--primary-color) 25%, rgba(0,0,0,0))}.item-card-image{flex-shrink:0;width:140px;aspect-ratio:16/9;overflow:hidden;object-fit:cover;border-radius:.25rem;background:color-mix(in srgb, var(--primary-color) 6%, rgba(0,0,0,0))}.item-card-image img{width:100%;height:100%;object-fit:cover}.item-card-body,.post-item-body{flex:1;min-width:0}.item-card-meta,.post-item-meta{display:flex;align-items:center;gap:.5rem;margin-bottom:.3rem;flex-wrap:wrap}.item-card-date,.post-item-date{font-size:.75rem;color:var(--meta-color);font-family:var(--font-monospace, monospace);opacity:.65;transition:color .2s ease,opacity .2s ease}.item-card-tag,.post-item-tag{font-size:.65rem;font-weight:600;color:var(--primary-color);letter-spacing:.05em;background:color-mix(in srgb, var(--primary-color) 12%, rgba(0,0,0,0));padding:.2rem .5rem;border-radius:.25rem;line-height:1;text-decoration:none;transition:background .2s ease,color .2s ease,transform .2s ease;flex-shrink:0}.item-card-tag:hover,.item-card-tag:focus-visible,.post-item-tag:hover,.post-item-tag:focus-visible{background:color-mix(in srgb, var(--primary-color) 25%, rgba(0,0,0,0))}.item-card-title,.post-item-title{font-size:1.05rem;margin:.15rem 0;font-weight:600;line-height:1.3;color:var(--text-color);transition:color .2s ease}.item-card-title a,.post-item-title a{text-decoration:none;color:inherit}.item-card-description,.post-item-description{font-size:.88rem;margin:.2rem 0 0;line-height:1.5;color:var(--meta-color);transition:color .2s ease;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.article-hero-image{margin:1.5rem 0;text-align:center}.article-hero-image img{max-width:100%;height:auto;max-height:480px;object-fit:contain;border-radius:.375rem;display:block;margin:0 auto;box-shadow:0 4px 24px color-mix(in srgb, var(--primary-color) 8%, rgba(0,0,0,.08))}.blog-featured{display:flex;flex-direction:column;border-radius:.5rem;overflow:hidden;border:1px solid color-mix(in srgb, var(--primary-color) 12%, rgba(0,0,0,0));background:var(--bg-2);text-decoration:none;color:inherit;cursor:pointer;transition:border-color .3s ease,box-shadow .3s ease,transform .3s cubic-bezier(.25, 1, .5, 1);margin-top:2.5rem;margin-bottom:2rem}.blog-featured:hover,.blog-featured:focus-visible{border-color:color-mix(in srgb, var(--primary-color) 35%, rgba(0,0,0,0));box-shadow:0 8px 24px color-mix(in srgb, var(--primary-color) 12%, rgba(0,0,0,.08));transform:translateY(-3px)}.blog-featured:hover .blog-featured-title,.blog-featured:hover .blog-post-readmore,.blog-featured:focus-visible .blog-featured-title,.blog-featured:focus-visible .blog-post-readmore{color:var(--primary-color)}.blog-featured:hover .blog-featured-description,.blog-featured:focus-visible .blog-featured-description{color:var(--text-color-high-contrast)}.blog-featured:hover .blog-featured-image img:not(.blog-featured-placeholder),.blog-featured:focus-visible .blog-featured-image img:not(.blog-featured-placeholder){transform:scale(1.03)}.blog-featured-image{width:100%;height:0;padding-bottom:42%;position:relative;overflow:hidden;background:color-mix(in srgb, var(--primary-color) 6%, rgba(0,0,0,0))}.blog-featured-image img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.25, 1, .5, 1)}.blog-featured-image .blog-featured-placeholder{object-fit:contain;padding:2rem;opacity:.4}.blog-featured-body{padding:1.5rem;display:flex;flex-direction:column;gap:.35rem}.blog-featured-title{font-size:1.35rem;font-weight:600;line-height:1.3;margin:.15rem 0;color:var(--text-color-high-contrast);transition:color .2s ease}.blog-featured-description{font-size:.95rem;line-height:1.5;margin:.2rem 0 0;color:var(--meta-color);transition:color .2s ease;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.blog-post-list{display:flex;flex-direction:column;gap:0}.blog-post-card{display:flex;position:relative;padding:1.25rem 1rem 1.25rem 1.5rem;border-bottom:1px solid color-mix(in srgb, var(--primary-color) 6%, rgba(0,0,0,0));text-decoration:none;color:inherit;cursor:pointer;overflow:hidden;transition:background .25s ease}.blog-post-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--primary-color);transform:scaleY(0);transform-origin:bottom;transition:transform .25s cubic-bezier(.25, 1, .5, 1);border-radius:0 .25rem .25rem 0}.blog-post-card:first-child{border-top:1px solid color-mix(in srgb, var(--primary-color) 6%, rgba(0,0,0,0))}.blog-post-card:hover,.blog-post-card:focus-visible{background:color-mix(in srgb, var(--primary-color) 3%, rgba(0,0,0,0))}.blog-post-card:hover::before,.blog-post-card:focus-visible::before{transform:scaleY(1)}.blog-post-card:hover .blog-post-title,.blog-post-card:hover .blog-post-readmore,.blog-post-card:focus-visible .blog-post-title,.blog-post-card:focus-visible .blog-post-readmore{color:var(--primary-color);opacity:1}.blog-post-card:hover .blog-post-description,.blog-post-card:focus-visible .blog-post-description{color:var(--text-color-high-contrast)}.blog-post-card:hover .blog-post-tag,.blog-post-card:focus-visible .blog-post-tag{background:color-mix(in srgb, var(--primary-color) 25%, rgba(0,0,0,0))}.blog-post-body{flex:1;min-width:0;display:flex;flex-direction:column}.blog-post-meta{display:flex;align-items:center;gap:.5rem;margin-bottom:.3rem;flex-wrap:wrap}.blog-post-date{font-size:.75rem;color:var(--meta-color);font-family:var(--font-monospace, monospace);opacity:.65;transition:color .2s ease,opacity .2s ease}.blog-post-tag{font-size:.65rem;font-weight:600;color:var(--primary-color);letter-spacing:.05em;background:color-mix(in srgb, var(--primary-color) 12%, rgba(0,0,0,0));padding:.2rem .5rem;border-radius:.25rem;line-height:1;text-decoration:none;transition:background .2s ease,color .2s ease,transform .2s ease;flex-shrink:0}.blog-post-tag:hover,.blog-post-tag:focus-visible{background:color-mix(in srgb, var(--primary-color) 25%, rgba(0,0,0,0))}.blog-post-reading-time{font-size:.75rem;color:var(--meta-color);opacity:.7;font-style:italic}.blog-post-title{font-size:1.15rem;margin:.15rem 0;font-weight:600;line-height:1.3;color:var(--text-color-high-contrast);transition:color .2s ease}.blog-post-description{font-size:.9rem;margin:.2rem 0 0;line-height:1.5;color:var(--meta-color);transition:color .2s ease;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.h-timeline{display:flex;gap:.5rem;justify-content:center;overflow-x:auto;padding:1rem 0;position:relative;scrollbar-width:thin;scrollbar-color:color-mix(in srgb, var(--primary-color) 20%, rgba(0,0,0,0)) rgba(0,0,0,0)}.h-timeline::before{content:"";position:absolute;top:calc(1.65rem - 1px);left:0;right:0;height:2px;background:linear-gradient(90deg, color-mix(in srgb, var(--primary-color) 50%, rgba(0,0,0,0)) 0%, color-mix(in srgb, var(--primary-color) 35%, rgba(0,0,0,0)) 30%, color-mix(in srgb, var(--primary-color) 12%, rgba(0,0,0,0)) 85%, rgba(0,0,0,0) 100%);z-index:0;border-radius:.25rem}.h-timeline-item{display:flex;flex-direction:column;align-items:center;text-align:center;min-width:7.5rem;max-width:9rem;padding:.35rem .5rem .5rem;text-decoration:none;color:inherit;position:relative;z-index:1;flex-shrink:0;border-radius:.25rem;transition:opacity .25s ease,transform .25s cubic-bezier(.25, 1, .5, 1)}.h-timeline-item:nth-child(1){opacity:1}.h-timeline-item:nth-child(2){opacity:.92}.h-timeline-item:nth-child(3){opacity:.85}.h-timeline-item:nth-child(4){opacity:.78}.h-timeline-item:nth-child(5){opacity:.7}.h-timeline-item:nth-child(n+6){opacity:.65}.h-timeline-item:hover,.h-timeline-item:focus-visible{opacity:1;transform:translateY(-3px)}.h-timeline-item:hover .h-timeline-dot,.h-timeline-item:focus-visible .h-timeline-dot{transform:scale(1.3);box-shadow:0 0 0 4px color-mix(in srgb, var(--primary-color) 25%, rgba(0,0,0,0)),0 0 12px color-mix(in srgb, var(--primary-color) 30%, rgba(0,0,0,0))}.h-timeline-item:hover .h-timeline-title,.h-timeline-item:focus-visible .h-timeline-title{color:var(--primary-color)}.h-timeline-item:hover .h-timeline-tag,.h-timeline-item:focus-visible .h-timeline-tag{background:color-mix(in srgb, var(--primary-color) 25%, rgba(0,0,0,0))}.h-timeline-dot{width:.6rem;height:.6rem;border-radius:50%;background:var(--primary-color);margin-bottom:.5rem;transition:transform .3s cubic-bezier(.25, 1, .5, 1),box-shadow .3s ease;box-shadow:0 0 0 3px color-mix(in srgb, var(--primary-color) 12%, rgba(0,0,0,0));flex-shrink:0}.h-timeline-tag{font-size:.6rem;font-weight:600;color:var(--primary-color);letter-spacing:.04em;background:color-mix(in srgb, var(--primary-color) 12%, rgba(0,0,0,0));padding:.1rem .4rem;border-radius:.25rem;line-height:1;text-decoration:none;transition:background .2s ease,color .2s ease,transform .2s ease;margin-bottom:.3rem;white-space:nowrap}.h-timeline-tag:hover,.h-timeline-tag:focus-visible{background:color-mix(in srgb, var(--primary-color) 25%, rgba(0,0,0,0))}.h-timeline-title{font-size:.85rem;font-weight:600;line-height:1.3;color:var(--text-color);transition:color .2s ease;margin-bottom:0}.h-timeline-date{font-size:.75rem;color:var(--meta-color);font-family:var(--font-monospace, monospace);opacity:.5;transition:color .2s ease,opacity .2s ease;margin-top:.2rem}.h-timeline-item:nth-child(n+6){display:none}@media (max-width: 1100px){.h-timeline-item:nth-child(n+5){display:none}}.project-grid{display:grid;grid-template-columns:repeat(3, 1fr);gap:1rem}.project-grid-card{position:relative;display:block;border-radius:.375rem;overflow:hidden;aspect-ratio:4/3;text-decoration:none;transition:box-shadow .3s cubic-bezier(.25, 1, .5, 1),transform .3s cubic-bezier(.25, 1, .5, 1)}.project-grid-card:hover,.project-grid-card:focus-visible{box-shadow:0 8px 24px color-mix(in srgb, var(--primary-color) 15%, rgba(0,0,0,.25));transform:translateY(-3px)}.project-grid-card:hover .project-grid-img img,.project-grid-card:focus-visible .project-grid-img img{transform:scale(1.06)}.project-grid-card:hover .project-grid-title,.project-grid-card:focus-visible .project-grid-title{color:var(--primary-color) !important}.project-grid-card:hover .project-grid-tag,.project-grid-card:focus-visible .project-grid-tag{background:color-mix(in srgb, var(--primary-color) 25%, rgba(0,0,0,0))}.project-grid-img{position:absolute;inset:0}.project-grid-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.25, 1, .5, 1)}.project-grid-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;text-align:center;padding:.85rem;background:linear-gradient(to top, rgba(0,0,0,.9) 0%, rgba(0,0,0,0) 50%, rgba(0,0,0,0) 100%);transition:background .3s ease}.project-grid-title{font-size:clamp(.75rem,2.8cqi,.95rem);font-weight:600;line-height:1.3;margin:0 0 .35rem;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.9);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .2s ease}.project-grid-tags{display:flex;gap:.35rem;flex-wrap:wrap;justify-content:center}.project-grid-tag{font-size:.58rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--primary-color);background:color-mix(in srgb, var(--primary-color) 15%, rgba(0,0,0,0));backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:.15rem .4rem;border-radius:.25rem;line-height:1.5;flex-shrink:0;text-decoration:none;transition:background .2s ease,color .2s ease}.wasm-container{margin:1.5rem auto;border:none;border-radius:.375rem;overflow:hidden;position:relative;box-shadow:0 4px 16px rgba(0,0,0,.05)}.wasm-container.wasm-loaded{border-radius:0;outline:none;box-shadow:none}.wasm-container .wasm-iframe{margin:0;max-width:100%;height:100%;background:var(--background-color);border:none}.wasm-container .wasm-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:color-mix(in srgb, var(--primary-color) 4%, var(--background-color));border:1px solid color-mix(in srgb, var(--primary-color) 15%, rgba(0,0,0,0));border-radius:.375rem;cursor:pointer;transition:border-color .3s ease,box-shadow .3s ease}.wasm-container .wasm-overlay:hover{border-color:color-mix(in srgb, var(--primary-color) 35%, rgba(0,0,0,0));box-shadow:0 8px 24px color-mix(in srgb, var(--primary-color) 10%, rgba(0,0,0,.12))}.wasm-container .wasm-overlay:hover .wasm-play-icon{transform:scale(1.1);box-shadow:0 4px 20px color-mix(in srgb, var(--primary-color) 40%, rgba(0,0,0,0))}.wasm-container .wasm-overlay:hover .wasm-btn{color:var(--primary-color)}.wasm-container .wasm-play-icon{width:4rem;height:4rem;border-radius:50%;background:color-mix(in srgb, var(--primary-color) 12%, rgba(0,0,0,0));border:2px solid color-mix(in srgb, var(--primary-color) 30%, rgba(0,0,0,0));display:flex;align-items:center;justify-content:center;transition:transform .3s cubic-bezier(.25, 1, .5, 1),box-shadow .3s ease}.wasm-container .wasm-play-icon svg{width:1.5rem;height:1.5rem;fill:var(--primary-color);margin-left:.2rem}.wasm-container .wasm-btn{font-size:.95rem;font-weight:600;color:color-mix(in srgb, var(--primary-color) 70%, rgba(0,0,0,0));letter-spacing:.03em;transition:color .2s ease}.timeline{position:relative;padding-left:2rem;margin:2rem 0}.timeline::before{content:"";position:absolute;left:.5rem;top:0;bottom:0;width:2px;border-radius:2px;background:linear-gradient(180deg, var(--primary-color), color-mix(in srgb, var(--primary-color) 15%, rgba(0,0,0,0)))}.timeline-item{position:relative;padding-bottom:1.5rem;padding-left:1rem}.timeline-item:last-child{padding-bottom:0}.timeline-item:hover .timeline-marker,.timeline-item:focus-within .timeline-marker{transform:scale(1.3);box-shadow:0 0 0 4px color-mix(in srgb, var(--primary-color) 25%, rgba(0,0,0,0)),0 0 12px color-mix(in srgb, var(--primary-color) 30%, rgba(0,0,0,0))}.timeline-marker{position:absolute;left:calc(-1.8rem + 1px);top:1.4rem;width:.6rem;height:.6rem;border-radius:50%;background:var(--primary-color);box-shadow:0 0 0 3px color-mix(in srgb, var(--primary-color) 15%, rgba(0,0,0,0));transition:transform .3s cubic-bezier(.25, 1, .5, 1),box-shadow .3s ease}a.timeline-content,div.timeline-content{display:block;padding:.85rem 1.1rem;border-radius:.375rem;background:rgba(0,0,0,0);border:1px solid color-mix(in srgb, var(--primary-color) 8%, rgba(0,0,0,0));position:relative;overflow:hidden;text-decoration:none;color:inherit;transition:background .3s ease,border-color .3s ease}a.timeline-content::before,div.timeline-content::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--primary-color);transform:scaleY(0);transform-origin:bottom;transition:transform .3s cubic-bezier(.25, 1, .5, 1);border-radius:.375rem}a.timeline-content:hover,a.timeline-content:focus-visible,div.timeline-content:hover,div.timeline-content:focus-visible{background:color-mix(in srgb, var(--primary-color) 4%, rgba(0,0,0,0));border-color:color-mix(in srgb, var(--primary-color) 30%, rgba(0,0,0,0))}a.timeline-content:hover::before,a.timeline-content:focus-visible::before,div.timeline-content:hover::before,div.timeline-content:focus-visible::before{transform:scaleY(1)}a.timeline-content:hover .timeline-title,a.timeline-content:focus-visible .timeline-title,div.timeline-content:hover .timeline-title,div.timeline-content:focus-visible .timeline-title{color:var(--primary-color)}a.timeline-content:hover .timeline-description,a.timeline-content:focus-visible .timeline-description,div.timeline-content:hover .timeline-description,div.timeline-content:focus-visible .timeline-description{color:var(--text-color-high-contrast)}a.timeline-content:hover .timeline-highlights,a.timeline-content:focus-visible .timeline-highlights,div.timeline-content:hover .timeline-highlights,div.timeline-content:focus-visible .timeline-highlights{background:color-mix(in srgb, var(--primary-color) 25%, rgba(0,0,0,0))}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.3rem;flex-wrap:wrap;gap:.35rem}.timeline-date{font-size:.75rem;color:var(--meta-color);font-family:var(--font-monospace, monospace);opacity:.65;transition:color .2s ease,opacity .2s ease}.timeline-highlights{font-size:.65rem;font-weight:600;color:var(--primary-color);letter-spacing:.05em;background:color-mix(in srgb, var(--primary-color) 12%, rgba(0,0,0,0));padding:.2rem .5rem;border-radius:.25rem;line-height:1;text-decoration:none;transition:background .2s ease,color .2s ease,transform .2s ease}.timeline-highlights:hover,.timeline-highlights:focus-visible{background:color-mix(in srgb, var(--primary-color) 25%, rgba(0,0,0,0))}.timeline-title{font-size:1.1rem;margin:.25rem 0;font-weight:600;color:var(--text-color);transition:color .2s ease}.timeline-description{font-size:.92rem;margin:.3rem 0 0;line-height:1.5;color:var(--meta-color);transition:color .2s ease}#publications{margin-top:2rem}.publications{margin:.5rem 0}.publication-year{font-size:1.4rem;font-weight:600;margin:2rem 0 1rem;padding-bottom:.35rem;border-bottom:2px solid color-mix(in srgb, var(--primary-color) 40%, rgba(0,0,0,0));display:inline-block;opacity:.9}.publication-year:first-child{margin-top:.5rem}.publication-entry{display:flex;gap:1.25rem;padding:1rem;margin-bottom:.75rem;border-radius:.375rem;border:1px solid color-mix(in srgb, var(--primary-color) 5%, rgba(0,0,0,0));transition:background .3s ease,border-color .3s ease,transform .3s cubic-bezier(.25, 1, .5, 1)}.publication-entry:hover{background:color-mix(in srgb, var(--primary-color) 4%, rgba(0,0,0,0));border-color:color-mix(in srgb, var(--primary-color) 20%, rgba(0,0,0,0));transform:translateY(-2px)}.publication-entry:hover .publication-title a{color:var(--primary-color)}.publication-entry:hover .publication-authors,.publication-entry:hover .publication-venue{color:var(--text-color-high-contrast)}.publication-thumbnail{flex-shrink:0;width:180px;aspect-ratio:16/9;object-fit:cover;border-radius:.25rem;background:color-mix(in srgb, var(--primary-color) 6%, rgba(0,0,0,0))}.publication-info{flex:1;min-width:0}.publication-title{font-size:1.15rem;font-weight:600;margin:0 0 .35rem;line-height:1.3;color:var(--text-color)}.publication-title a{text-decoration:none;color:inherit;transition:color .2s ease}.publication-authors{font-size:.9rem;line-height:1.4;color:var(--meta-color);margin:0 0 .35em;transition:color .2s ease}.publication-authors .author-self{font-weight:600}.publication-venue{font-size:.9rem;line-height:1.4;font-style:italic;color:var(--meta-color);margin:0 0 .5rem;transition:color .2s ease}.publication-links{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.publication-link-icon{width:1em;height:1em;fill:currentColor;flex-shrink:0}.publication-link{display:inline-flex;align-items:center;gap:.35em;font-size:.8rem;padding:.4rem .6rem;border-radius:.25rem;text-decoration:none;font-weight:600;background:color-mix(in srgb, var(--primary-color) 10%, rgba(0,0,0,0));color:var(--primary-color) !important;border:1px solid color-mix(in srgb, var(--primary-color) 20%, rgba(0,0,0,0));transition:background .2s ease,border-color .2s ease}.publication-link:hover{background:color-mix(in srgb, var(--primary-color) 25%, rgba(0,0,0,0));border-color:color-mix(in srgb, var(--primary-color) 40%, rgba(0,0,0,0))}.publication-copy-bib{margin-left:auto;background:rgba(0,0,0,0);border:1px dashed color-mix(in srgb, var(--primary-color) 35%, rgba(0,0,0,0));color:color-mix(in srgb, var(--primary-color) 80%, rgba(0,0,0,0)) !important}.publication-copy-bib:hover{border-style:solid}.publication-copy-bib.copied{background:color-mix(in srgb, var(--primary-color) 20%, rgba(0,0,0,0));border-style:solid;border-color:color-mix(in srgb, var(--primary-color) 50%, rgba(0,0,0,0));color:var(--primary-color) !important}.teaching-course{margin:1rem 0 2rem}.teaching-course-header{margin-bottom:1.25rem}.teaching-course-info h2{margin-bottom:.5rem}.teaching-course-meta{display:flex;flex-wrap:wrap;gap:.5rem 1.25rem;font-size:.9rem;color:var(--meta-color)}.teaching-course-meta a{text-decoration:none;color:var(--primary-color)}.teaching-course-meta a:hover{text-decoration:underline}.teaching-meta-item{white-space:nowrap}.teaching-course-image{width:100%;max-height:400px;object-fit:cover;border-radius:.375rem;margin:1.25rem 0;border:1px solid color-mix(in srgb, var(--primary-color) 12%, rgba(0,0,0,0));box-shadow:0 4px 20px color-mix(in srgb, var(--primary-color) 8%, rgba(0,0,0,.05))}.teaching-topics{display:grid;grid-template-columns:repeat(auto-fit, minmax(11rem, 1fr));gap:.75rem;margin:1rem 0 1.5rem}.teaching-topic{padding:.65rem 1rem;border-radius:.375rem;font-size:.9rem;font-weight:600;background:color-mix(in srgb, var(--primary-color) 5%, rgba(0,0,0,0));border:1px solid color-mix(in srgb, var(--primary-color) 12%, rgba(0,0,0,0));text-align:center;transition:transform .3s cubic-bezier(.25, 1, .5, 1),border-color .3s ease}.teaching-topic:hover{transform:translateY(-2px);border-color:color-mix(in srgb, var(--primary-color) 30%, rgba(0,0,0,0))}.teaching-title-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.teaching-title-row h2{margin:0}@media (max-width: 960px){.page-header{font-size:2.25em;margin-block:2.5rem .75rem}#banner-container-home{flex-direction:column-reverse !important;align-items:center !important;gap:1rem !important}#image-container-home{max-width:none !important;width:100% !important;padding-inline-start:0 !important;margin-top:0 !important;text-align:center !important}#image-container-home img{width:80% !important;max-width:280px !important;margin:0 auto !important;display:block !important}#home-banner-text,.nav-title{text-align:center}#banner-home-subtitle p{text-align:left !important}.navbar{flex-direction:row !important;flex-wrap:nowrap !important;justify-content:center !important;align-items:center !important;position:relative}.nav-actions{position:absolute;right:0;top:50%;transform:translateY(-50%);margin:0}.nav-actions .search-icon,.nav-actions .theme-switcher,.nav-actions .theme-resetter{display:none !important}.nav-actions::before{display:none}.nav-hamburger{display:flex}.navbar>.nav-navs{position:absolute;top:calc(100% + .05rem);right:0;z-index:100;min-width:10.5rem;margin:0 !important;padding:0;background:color-mix(in srgb, var(--background-color) 92%, rgba(0,0,0,0));backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-radius:.5rem;border:1px solid color-mix(in srgb, var(--primary-color) 12%, rgba(0,0,0,0));box-shadow:0 12px 40px rgba(0,0,0,.12),0 2px 10px rgba(0,0,0,.05);opacity:0;visibility:hidden;transform:translateY(-8px);transform-origin:top center;transition:opacity .25s cubic-bezier(.4, 0, .2, 1),transform .25s cubic-bezier(.4, 0, .2, 1),visibility .25s;pointer-events:none;display:block !important}.navbar>.nav-navs ul{display:flex !important;flex-direction:column !important;align-items:stretch !important;gap:0 !important;padding:.35rem 0;margin:0;list-style:none}.navbar>.nav-navs .nav-links{display:flex;align-items:center;padding:.35rem 1rem;line-height:1;border-radius:.375rem;font-size:1.05rem;font-weight:600;color:var(--text-color);transition:background .2s ease,color .2s ease}.navbar>.nav-navs .nav-links:hover{background:color-mix(in srgb, var(--primary-color) 12%, rgba(0,0,0,0));color:var(--primary-color)}.navbar>.nav-navs .nav-tools-row{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem .75rem .25rem;margin:0 .4rem .2rem;border-top:1px solid color-mix(in srgb, var(--primary-color) 10%, rgba(0,0,0,0))}.navbar>.nav-navs .nav-tools-row .search-icon,.navbar>.nav-navs .nav-tools-row .theme-switcher,.navbar>.nav-navs .nav-tools-row .theme-resetter{display:initial !important;margin:0 !important}.navbar.nav-open>.nav-navs{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}.front-page-sections{margin-top:1.5rem}.front-section-title{font-size:1.1rem}.front-section{margin-bottom:2rem}.journey-map{flex-direction:column;align-items:center;padding:1rem 0;gap:0}.journey-step{display:grid;grid-template-columns:2.75rem 1fr;align-items:center;text-align:left;width:80%;max-width:none;padding:.85rem 1rem;gap:1rem}.journey-step:hover{transform:translateX(2px)}.journey-icon{margin-bottom:0;text-align:center;width:100%;font-size:1.85rem}.journey-info{align-items:flex-start}.journey-connector{width:2px;height:1.5rem}.journey-continuation{width:2px;height:2.5rem;background:linear-gradient(180deg, var(--primary-color), rgba(0,0,0,0))}.timeline{padding-left:1.5rem}.timeline-marker{left:calc(-1.3rem + 1px)}.h-timeline{justify-content:center;padding:.75rem 0}.h-timeline-item{min-width:6.5rem;max-width:7.5rem;padding:.35rem .35rem .5rem}.h-timeline-item:nth-child(n+4){display:none}.project-grid{gap:.75rem}.project-grid-title{font-size:.85rem}.post-item-tag,.blog-post-tag,.card-tag,.project-grid-tag{font-size:.52rem;padding:.1rem .35rem}.blog-featured-body{padding:1.25rem 1.15rem 1.5rem}.blog-featured-title{font-size:1.2rem}.blog-featured-image{padding-bottom:50%}.teaching-title-row{flex-direction:column;align-items:flex-start;gap:.75rem}}@media (max-width: 600px){.page-header{font-size:1.75em;margin-block:2rem .5rem}#image-container-home img{max-width:220px !important}.item-card{flex-direction:column;gap:.75rem}.item-card-image{width:100%;height:auto;max-height:160px}.project-grid{grid-template-columns:1fr 1fr;gap:.65rem}.project-grid-card{aspect-ratio:3/2}.publication-entry{flex-direction:column;gap:.75rem}.publication-thumbnail{width:100%;height:auto;max-height:180px}.publication-links{gap:.4rem}.publication-link{font-size:.75rem;padding:.3rem .5rem}.publication-copy-bib{margin-left:0}.h-timeline-item{min-width:5.5rem;max-width:6.5rem;padding:.35rem .3rem .5rem}.h-timeline-item:nth-child(n+3){display:none}.h-timeline-title{font-size:.75rem}.h-timeline-tag{font-size:.55rem}.section-more{font-size:.8rem}.blog-featured-image{padding-bottom:56.25%}.blog-featured-description{-webkit-line-clamp:2}.blog-post-card{padding:1rem .85rem 1rem 1.15rem}.post-item{padding:.85rem}a.timeline-content,div.timeline-content{padding:.75rem .85rem}.timeline-title{font-size:1.05rem}.teaching-course-image{border-radius:0;margin-left:-16px;margin-right:-16px;width:calc(100% + 32px);max-width:none}.teaching-topics{grid-template-columns:1fr 1fr}}@media (max-width: 420px){#image-container-home img{max-width:180px !important}#banner-home-subtitle p{font-size:.95rem}.project-grid{grid-template-columns:1fr}.project-grid-card{aspect-ratio:16/9}.h-timeline{flex-direction:column;align-items:stretch;gap:0;padding:.35rem 0}.h-timeline::before{display:none}.h-timeline-item{flex-direction:row;text-align:left;min-width:auto;max-width:none;gap:.75rem;padding:.65rem .5rem;border-bottom:1px solid color-mix(in srgb, var(--primary-color) 8%, rgba(0,0,0,0))}.h-timeline-item:nth-child(n){display:flex !important;opacity:1}.h-timeline-dot{margin-bottom:0;width:.5rem;height:.5rem}.h-timeline-tag{margin-bottom:0}.h-timeline-title{font-size:.8rem;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.h-timeline-date{font-size:.7rem;margin-top:0}.blog-featured-title{font-size:1.15rem}.blog-featured-body{padding:1rem 1.15rem 1.25rem}.blog-featured{margin-top:1.75rem}.post-item-tag,.blog-post-tag,.card-tag,.project-grid-tag{font-size:.5rem;padding:.08rem .3rem}.blog-post-title{font-size:1.05rem}.blog-post-description{-webkit-line-clamp:1}.publication-title{font-size:1rem}.publication-authors,.publication-venue{font-size:.85rem}.teaching-topics{grid-template-columns:1fr}.journey-step{gap:.5rem;padding:.65rem .5rem}.journey-icon{font-size:1.6rem}.wasm-container{aspect-ratio:4/3 !important}.article-hero-image img{max-height:280px}}footer .social:hover>img{filter:brightness(0) saturate(100%) invert(38%) sepia(30%) saturate(1200%) hue-rotate(197deg) brightness(92%) contrast(88%) !important}[data-theme=dark] footer .social>img{filter:brightness(0) invert(1)}[data-theme=dark] footer .social:hover>img{filter:brightness(0) saturate(100%) invert(68%) sepia(18%) saturate(900%) hue-rotate(190deg) brightness(100%) contrast(88%) !important}@media (prefers-color-scheme: dark){:root:not([data-theme=light]) footer .social>img{filter:brightness(0) invert(1)}:root:not([data-theme=light]) footer .social:hover>img{filter:brightness(0) saturate(100%) invert(68%) sepia(18%) saturate(900%) hue-rotate(190deg) brightness(100%) contrast(88%) !important}}.search-icon.interactive-icon:hover path,.interactive-icon:hover path{fill:var(--primary-color) !important}.theme-switcher:hover{background:var(--primary-color) !important}.theme-resetter{display:none !important}#results-info{display:none !important}.home-title{font-weight:700 !important}.nav-links[href]:not(.no-active){transition:color .2s ease,opacity .2s ease}@supports (padding: env(safe-area-inset-left)){body{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}}