html,body,#root{min-height:100%;margin:0}html,body{overflow-x:hidden}.cv-header__top{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.tour-launcher{flex-shrink:0;background:var(--bg-card);color:var(--fg);border:1px solid var(--border-strong);border-radius:999px;padding:.4rem .9rem;font-family:var(--mono);font-size:.8rem;letter-spacing:.04em;cursor:pointer;transition:border-color .15s ease,color .15s ease}.tour-launcher:hover{border-color:var(--accent);color:var(--accent)}.tour-tooltip{background:var(--bg-card, #121418);color:var(--fg, #e7e5df);padding:1rem 1.1rem;width:min(32rem,calc(100vw - 2rem));max-width:none;font-family:var(--sans);border:1px solid var(--border-strong);border-radius:10px;box-shadow:0 10px 30px #00000059}.tour-tooltip__title{margin:0 0 .4rem;font-family:var(--serif);color:var(--accent);font-size:1.05rem;letter-spacing:-.01em}.tour-tooltip__content{font-family:var(--sans);font-size:.9rem;line-height:1.4}.tour-tooltip__footer{display:flex;align-items:center;flex-wrap:nowrap;gap:.5rem;margin-top:.9rem}.tour-tooltip__progress{font-family:var(--mono);font-size:.75rem;opacity:.6;white-space:nowrap;flex-shrink:0}.tour-tooltip__actions{margin-left:auto;display:flex;gap:.4rem}.tour-tooltip__skip,.tour-tooltip__back,.tour-tooltip__primary{font-family:var(--mono);font-size:.8rem;padding:.35rem .75rem;border-radius:999px;border:1px solid var(--border-strong);background:transparent;color:var(--fg);cursor:pointer}.tour-tooltip__back,.tour-tooltip__primary:not(:disabled){display:inline-flex;align-items:center;justify-content:center}.tour-tooltip__back svg,.tour-tooltip__primary svg{display:block}.tour-tooltip__mute{display:inline-flex;align-items:center;justify-content:center;width:1.9rem;height:1.9rem;padding:0;border-radius:999px;border:1px solid var(--border-strong);background:transparent;color:var(--fg);cursor:pointer;transition:border-color .15s ease,color .15s ease}.tour-tooltip__mute:hover{border-color:var(--accent);color:var(--accent)}@media(min-width:769px){.tour-tooltip__content{display:none}body.tour-modal-open .tour-tooltip__content{display:block}}.tour-tooltip__primary{background:var(--accent);color:#121418;border-color:var(--accent);letter-spacing:.02em}.tour-tooltip__skip{opacity:.7}.tour-tooltip__primary:disabled,.tour-tooltip__back:disabled{opacity:.4;cursor:not-allowed}body.tour-modal-open .reactour__mask{opacity:0!important;pointer-events:none!important;transition:opacity .2s ease}body.tour-modal-open .reactour__popover{z-index:200}.project-card.tour-click{animation:tour-card-press 1s cubic-bezier(.25,.1,.25,1) both;z-index:1}@keyframes tour-highlight-pulse{0%,to{filter:drop-shadow(0 0 6px var(--accent, #f5b56b)) drop-shadow(0 0 12px var(--accent, #f5b56b))}50%{filter:drop-shadow(0 0 12px var(--accent, #f5b56b)) drop-shadow(0 0 24px var(--accent, #f5b56b))}}@keyframes tour-card-press{0%{transform:scale(1);box-shadow:0 0 0 0 transparent}20%{transform:scale(.94) translateY(2px);box-shadow:0 0 0 3px var(--accent);border-color:var(--accent)}60%{transform:scale(.94) translateY(2px);box-shadow:0 0 0 3px var(--accent);border-color:var(--accent)}to{transform:scale(1);box-shadow:0 0 0 0 transparent}}:root{--bg: #0b0c0e;--bg-elev: #111317;--bg-card: #121418;--border: #1f2228;--border-strong: #2a2e36;--fg: #e7e5df;--fg-2: #b4b2ac;--muted: #7a7971;--accent: #f5b56b;--accent-2: #9af5c8;--link-underline: rgba(245, 181, 107, .4);--serif: "Instrument Serif", "Iowan Old Style", Georgia, serif;--sans: "Bricolage Grotesque", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;background:var(--bg);color:var(--fg);font-family:var(--sans);font-size:16px;line-height:1.6;font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;letter-spacing:-.005em;font-feature-settings:"ss01","ss02","liga","calt"}body>*:before,.cv:before{pointer-events:none}html:after{content:"";position:fixed;inset:0;z-index:2;pointer-events:none;opacity:.06;mix-blend-mode:overlay;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.9  0 0 0 0 0.9  0 0 0 0 0.9  0 0 0 0.5 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>")}body:before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.025) 1px,transparent 0);background-size:28px 28px;mask-image:radial-gradient(ellipse at 50% 0%,black 20%,transparent 75%);-webkit-mask-image:radial-gradient(ellipse at 50% 0%,black 20%,transparent 75%)}body:after{content:"";position:fixed;top:-20vh;right:-10vw;width:60vw;height:60vw;z-index:0;pointer-events:none;background:radial-gradient(closest-side,rgba(245,181,107,.09),transparent 70%);filter:blur(40px)}a{color:var(--fg);text-decoration:none;border-bottom:1px solid var(--link-underline);transition:color .16s ease,border-color .16s ease}a:hover{color:var(--accent);border-bottom-color:var(--accent)}code,.mono{font-family:var(--mono);font-size:.88em}code{background:var(--bg-elev);border:1px solid var(--border);padding:1px 6px;border-radius:4px;color:var(--fg-2)}::selection{background:#f5b56b40;color:var(--fg)}.cv{max-width:1200px;margin:0 auto;padding:clamp(3rem,8vw,6rem) clamp(1.25rem,5vw,3.5rem) 5rem;position:relative;z-index:1}.cv-header{display:flex;flex-direction:column;gap:.85rem;margin-bottom:2.5rem}.cv-header>*{animation:rise .7s cubic-bezier(.2,.7,.2,1) both}.cv-header__eyebrow{animation-delay:0ms}.cv-header h1{animation-delay:80ms}.cv-header .cv-label{animation-delay:.18s}.cv-header .cv-headline{animation-delay:.26s}.cv-header .cv-availability{animation-delay:.34s}.cv-header .cv-summary{animation-delay:.42s}.cv-header .cv-cta-row{animation-delay:.5s}.cv-header .cv-contact{animation-delay:.58s}.cv-header__eyebrow{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:-.25rem}.cv-eyebrow{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}.cv-header h1{margin:0;font-family:var(--serif);font-weight:400;font-size:clamp(2.8rem,7vw,4.6rem);line-height:.96;letter-spacing:-.03em;color:var(--fg);font-feature-settings:"ss01","liga","dlig";text-wrap:balance}.cv-header h1 em{font-style:italic;color:var(--accent);font-weight:400}.cv-label{margin:.1rem 0 0;font-family:var(--mono);font-size:12.5px;font-weight:500;color:var(--fg-2);letter-spacing:.04em}.cv-availability{margin:0;display:inline-flex;align-items:center;gap:.55rem;padding:5px 12px 5px 10px;width:fit-content;font-family:var(--mono);font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-2);background:#9af5c80f;border:1px solid rgba(154,245,200,.22);border-radius:999px}.cv-availability-dot{width:7px;height:7px;border-radius:50%;background:var(--accent-2);box-shadow:0 0 0 3px #9af5c829;animation:pulse 2.6s ease-in-out infinite;flex-shrink:0}@keyframes pulse{0%,to{box-shadow:0 0 0 3px #6ee39a2e}50%{box-shadow:0 0 0 6px #6ee39a0a}}.cv-headline{margin:.5rem 0 0;font-size:1.05rem;line-height:1.55;color:var(--fg);max-width:58ch;text-wrap:pretty;font-style:italic}.cv-summary{margin:.75rem 0 0;font-size:1.12rem;line-height:1.6;color:var(--fg-2);max-width:58ch;text-wrap:pretty;hanging-punctuation:first last}.cv-cta-row{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.25rem}.cv-cta{display:inline-flex;align-items:center;gap:.5rem;padding:11px 18px;border-radius:999px;font-family:var(--sans);font-size:.92rem;font-weight:600;letter-spacing:-.005em;text-decoration:none;border:1px solid transparent;cursor:pointer;transition:transform .18s cubic-bezier(.2,.7,.2,1),background .18s ease,color .18s ease,border-color .18s ease,box-shadow .22s ease}.cv-cta-arrow{font-family:var(--mono);font-weight:400;transition:transform .22s cubic-bezier(.2,.7,.2,1)}.cv-cta:hover .cv-cta-arrow{transform:translate(3px)}.cv-cta--ghost:hover .cv-cta-arrow{transform:translateY(2px)}.cv-cta--primary{background:var(--accent);color:#181a15;border-color:var(--accent);box-shadow:0 8px 26px -12px #f5b56b8c}.cv-cta--primary:hover{transform:translateY(-1px);box-shadow:0 14px 36px -12px #f5b56ba6}.cv-cta--ghost{background:transparent;color:var(--fg);border-color:var(--border-strong)}.cv-cta--ghost:hover{transform:translateY(-1px);border-color:var(--accent);color:var(--accent)}.cv-cta-linkedin{display:inline-flex;align-items:center;gap:.5rem;margin-top:1.5rem;padding:.6rem 1.4rem;font-family:var(--mono);font-size:13px;letter-spacing:.04em;color:var(--bg);background:var(--accent);border:1px solid var(--accent);border-radius:4px;text-decoration:none;transition:background .18s ease,color .18s ease,transform .12s ease}.cv-cta-linkedin:hover{background:transparent;color:var(--accent);transform:translateY(-1px)}.cv-cta-linkedin__arrow{transition:transform .18s ease}.cv-cta-linkedin:hover .cv-cta-linkedin__arrow{transform:translate(3px)}.cv-contact{list-style:none;padding:0;margin:1.5rem 0 0;display:flex;flex-wrap:wrap;align-items:center;gap:.2rem .85rem;font-family:var(--mono);font-size:12px;letter-spacing:.02em;color:var(--muted)}.cv-contact li{display:inline-flex;align-items:center;position:relative}.cv-contact li+li:before{content:"·";margin-right:.85rem;color:var(--border-strong)}.cv-contact a{border-bottom:1px dotted var(--border-strong);padding:2px 0;color:var(--fg-2);background:transparent;transition:color .16s ease,border-color .16s ease}.cv-contact a:hover{color:var(--accent);border-bottom-color:var(--accent);background:transparent;transform:none}.cv-contact-icon-btn{all:unset;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;color:var(--fg-2);transition:color .18s ease,background .18s ease}.cv-contact-icon-btn:hover{color:var(--fg);background:var(--bg-2)}.email-modal{position:relative;background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:2rem 2.5rem;max-width:380px;width:90vw;text-align:center;animation:rise .3s cubic-bezier(.2,.7,.2,1) both}.email-modal h2{margin:0 0 .25rem;font-size:1.15rem}.email-modal__hint{font-size:.8rem;color:var(--muted);font-style:italic;margin:0 0 1.5rem}.email-modal__actions{display:flex;flex-direction:column;gap:.5rem}.email-modal__btn{all:unset;cursor:pointer;display:block;padding:.55rem 1rem;border:1px solid var(--border);border-radius:8px;font-size:.85rem;text-align:center;color:var(--fg);transition:background .15s ease,border-color .15s ease}.email-modal__btn:hover{background:var(--bg-2);border-color:var(--border-strong)}.email-modal__btn--primary{background:var(--fg);color:var(--bg);border-color:var(--fg)}.email-modal__btn--primary:hover{opacity:.85;background:var(--fg)}.cv-contact-place{color:var(--muted)}.cv-section{margin-top:clamp(3rem,7vw,4.5rem);animation:rise .8s cubic-bezier(.2,.7,.2,1) both}.cv-section:nth-of-type(2){animation-delay:60ms}.cv-section:nth-of-type(3){animation-delay:.12s}.cv-section:nth-of-type(4){animation-delay:.18s}.cv-section:nth-of-type(5){animation-delay:.24s}.cv-section-title{font-family:var(--mono);font-weight:500;font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin:0 0 1.5rem;display:flex;align-items:center;gap:.75rem}.cv-section-title-text{color:var(--fg-2)}.cv-section-title:after{content:"";flex:1;height:1px;background:linear-gradient(to right,var(--border-strong),transparent)}.cv-work{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2rem}.cv-work-item{position:relative;padding-left:1.5rem;border-left:1px solid var(--border);transition:border-color .2s ease}.cv-work-item:before{content:"";position:absolute;left:-4px;top:.6rem;width:7px;height:7px;border-radius:50%;background:var(--bg);border:1.5px solid var(--border-strong);transition:border-color .2s ease,background .2s ease}.cv-work-item:hover{border-left-color:var(--border-strong)}.cv-work-item:hover:before{border-color:var(--accent);background:var(--accent)}.cv-dates{display:inline-block;font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;color:var(--muted);margin-bottom:.4rem;text-transform:uppercase}.cv-work-head{display:flex;flex-wrap:wrap;align-items:baseline;gap:.25rem .5rem;margin-bottom:.4rem}.cv-work-head strong{font-family:var(--sans);font-weight:600;font-size:1.1rem;color:var(--fg);letter-spacing:-.01em}.cv-at{font-family:var(--sans);font-weight:400;color:var(--muted);font-size:1rem}.cv-at:before{content:"· ";color:var(--border-strong)}.cv-work-item p{margin:.35rem 0 0;color:var(--fg-2);max-width:60ch}.cv-highlights{margin:.7rem 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.3rem;max-width:60ch}.cv-highlights li{position:relative;padding-left:1.1rem;color:var(--fg-2);font-size:.95rem}.cv-highlights li:before{content:"•";position:absolute;left:0;top:0;color:var(--border-strong)}.cv-education{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1rem}.cv-education li{display:flex;flex-wrap:wrap;align-items:baseline;gap:.25rem .75rem}.cv-education li strong{font-weight:600;color:var(--fg)}.cv-education li>span:not(.cv-dates){color:var(--fg-2)}.cv-education .cv-dates{margin-left:auto;margin-bottom:0}.cv-skills{display:flex;flex-direction:column;gap:1rem}.cv-skill-group{display:grid;grid-template-columns:120px 1fr;gap:1.25rem;align-items:start}.cv-skill-name{font-family:var(--mono);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding-top:.25rem}.cv-chips{display:flex;flex-wrap:wrap;gap:.35rem .4rem}.cv-skills-toggle{grid-column:1 / -1;justify-self:start;font-family:var(--mono);font-size:11.5px;letter-spacing:.08em;color:var(--muted);background:transparent;border:1px dashed var(--muted);border-radius:999px;padding:3px 10px;cursor:pointer;opacity:.75;transition:opacity .12s ease,color .12s ease,border-color .12s ease}.cv-skills-toggle:hover{opacity:1;color:var(--fg, #e7e5df);border-color:currentColor}.cv-skill-extras .cv-chips{grid-column:1 / -1;margin-top:.4rem}.cv-chip{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--mono);font-size:11.5px;padding:4px 10px;background:var(--bg-elev);color:var(--fg-2);border:1px solid var(--border);border-radius:999px;transition:background .16s ease,color .16s ease,border-color .16s ease,transform .16s ease}.cv-chip.has-icon{padding-left:7px}.cv-chip:hover{color:var(--fg);background:var(--bg-card);border-color:var(--border-strong);transform:translateY(-1px)}.cv-chip-icon{width:13px;height:13px;display:block;flex-shrink:0;filter:saturate(.85) brightness(1.05)}.cv-empty{color:var(--fg-2);padding:1rem 1.2rem;background:var(--bg-elev);border:1px solid var(--border);border-left:2px solid var(--accent);border-radius:6px;font-size:.95rem}.cv-interests{display:flex;flex-wrap:wrap;gap:.35rem .4rem}.project-search{position:relative;margin-bottom:1rem}.search-related-heading{margin:1.25rem 0 .5rem;padding-top:.75rem;border-top:1px dashed var(--border, rgba(128, 128, 128, .3));font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted, rgba(128, 128, 128, .85))}.search-related-grid{opacity:.88}.project-search-field{display:flex;align-items:center;gap:.6rem;padding:0 .9rem;height:42px;background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;transition:border-color .16s ease,background .16s ease,box-shadow .16s ease}.project-search-field:focus-within{border-color:var(--border-strong);background:var(--bg-card);box-shadow:0 0 0 3px #f5b56b14}.project-search-field.is-open{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.project-search-icon{color:var(--muted);flex-shrink:0}.project-search-field:focus-within .project-search-icon{color:var(--accent)}.project-search-field input{flex:1;min-width:0;background:transparent;border:none;outline:none;color:var(--fg);font-family:var(--sans);font-size:.95rem;letter-spacing:-.005em}.project-search-field input::placeholder{color:var(--muted)}.project-search-field input::-webkit-search-cancel-button{display:none}.project-search-clear{background:transparent;border:none;color:var(--muted);cursor:pointer;font-size:18px;line-height:1;padding:4px 6px;border-radius:4px;transition:color .16s ease,background .16s ease}.project-search-clear:hover{color:var(--fg);background:var(--border)}.project-search-count{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);white-space:nowrap;padding-left:.5rem;border-left:1px solid var(--border);cursor:help}.project-search-spinner{width:.72rem;height:.72rem;border-radius:50%;border:2px solid rgba(245,181,107,.2);border-top-color:#f5b56bf2;animation:project-search-spin .8s linear infinite;flex-shrink:0}@keyframes project-search-spin{to{transform:rotate(360deg)}}.project-search-hint{margin:6px 2px 0;font-size:11px;line-height:1.4;color:var(--muted);font-style:italic}.project-search-suggest{position:absolute;top:calc(100% - 1px);left:0;right:0;z-index:50;list-style:none;padding:6px;margin:0;background:var(--bg-card);border:1px solid var(--border-strong);border-top:1px solid var(--border);border-radius:0 0 10px 10px;box-shadow:0 14px 40px #00000073;max-height:320px;overflow-y:auto;animation:dropdown .16s ease both}@keyframes dropdown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.project-search-suggest-item{display:grid;grid-template-columns:22px 1fr auto;align-items:center;gap:.6rem;padding:7px 10px;border-radius:6px;cursor:pointer;font-size:.92rem;color:var(--fg-2);transition:background .12s ease,color .12s ease}.project-search-suggest-item.is-active{background:var(--bg-elev);color:var(--fg)}.project-search-suggest-kind{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:6px;background:var(--bg-elev);border:1px solid var(--border);font-family:var(--mono);font-size:11px;color:var(--muted)}.project-search-suggest-item.is-active .project-search-suggest-kind{border-color:var(--border-strong)}.project-search-suggest-kind img{width:12px;height:12px;display:block}.project-search-suggest-kind[data-kind=project]{color:var(--accent)}.project-search-suggest-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-search-suggest-label mark{background:transparent;color:var(--accent);font-weight:600}.project-search-suggest-meta{font-family:var(--mono);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted)}@media(max-width:520px){.project-search-count{display:none}}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem}.project-sort{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.85rem;color:var(--text-muted, #888)}.project-sort select{background:var(--bg-card);color:inherit;border:1px solid var(--border);border-radius:4px;padding:.2rem .4rem;font:inherit}.projects-stats-banner{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem;margin-bottom:.5rem;font-size:.88rem;color:var(--fg-2, #aaa)}.projects-stats-sep{opacity:.5}.projects-stats-btn{margin-left:auto;flex-shrink:0;padding:6px 12px;font-size:.8rem}.projects-disclaimer{margin-bottom:.75rem}.projects-disclaimer p{margin:0;color:var(--muted);font-size:.88rem;font-style:italic}.stats-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.5rem}.stats-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;padding:1rem;text-align:center}.stats-card-value{font-family:var(--serif);font-size:clamp(1.5rem,3vw,2rem);color:var(--accent);line-height:1.2}.stats-card-value--small{font-size:clamp(.9rem,2vw,1.1rem);font-family:var(--mono)}.stats-card-label{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.15em;color:var(--muted);margin-top:.3rem}@media(max-width:640px){.projects-disclaimer{flex-direction:column;align-items:flex-start}.stats-summary{grid-template-columns:1fr}}.project-card{position:relative;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:1.1rem 1.15rem 1rem;display:flex;flex-direction:column;gap:.6rem;transition:border-color .2s ease,transform .2s ease,background .2s ease;overflow:hidden}.project-card:before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:linear-gradient(140deg,rgba(245,181,107,.35),transparent 45%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .22s ease;pointer-events:none}.project-card:hover{border-color:var(--border-strong);transform:translateY(-2px)}.project-card:hover:before{opacity:1}.project-head{display:flex;align-items:flex-start;gap:.5rem}.project-head h3{margin:0;font-family:var(--sans);font-weight:600;font-size:.98rem;line-height:1.3;letter-spacing:-.01em;flex:1;min-width:0}.project-head h3 a{color:var(--fg);border-bottom:none;display:inline-flex;align-items:center;gap:.35rem}.project-head h3 a:after{content:"↗";font-family:var(--mono);font-weight:400;color:var(--muted);font-size:.85em;transition:color .18s ease,transform .18s ease}.project-head h3 a:hover{color:var(--accent)}.project-head h3 a:hover:after{color:var(--accent);transform:translate(2px,-2px)}.project-desc{margin:0;color:var(--fg-2);font-size:.88rem;line-height:1.5}.project-chips{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.1rem}.project-chips .cv-chip{font-size:10.5px;padding:2px 8px;background:transparent}.project-meta{margin-top:auto;padding-top:.8rem;border-top:1px dashed var(--border);display:flex;justify-content:space-between;gap:.5rem;font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--muted);text-transform:uppercase}.project-badge{font-family:var(--mono);font-weight:500;font-size:9.5px;text-transform:uppercase;letter-spacing:.14em;padding:3px 8px;border-radius:4px;background:var(--bg-elev);color:var(--fg-2);border:1px solid var(--border);white-space:nowrap}.badge-web{color:#8ec5ff;border-color:#8ec5ff40;background:#8ec5ff0f}.badge-cli{color:var(--accent);border-color:#f5b56b40;background:#f5b56b0f}.badge-library{color:#c9a6ff;border-color:#c9a6ff40;background:#c9a6ff0f}.badge-mobile{color:#9af5c8;border-color:#9af5c840;background:#9af5c80f}.badge-contract{color:#ff9e9e;border-color:#ff9e9e40;background:#ff9e9e0f}.badge-data{color:#7fd3ff;border-color:#7fd3ff40;background:#7fd3ff0f}.badge-role{letter-spacing:.18em}.badge-frontend{color:#8ec5ff;border-color:#8ec5ff59;background:#8ec5ff14}.badge-backend{color:#f5b56b;border-color:#f5b56b59;background:#f5b56b14}.badge-fullstack{color:#c9a6ff;border-color:#c9a6ff59;background:#c9a6ff14}.badge-other{color:var(--fg-2);border-color:var(--border-strong);background:var(--bg-elev)}.project-head-badges{display:inline-flex;flex-wrap:wrap;gap:.25rem}.project-card{cursor:pointer}.project-card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.project-chip-more{font-size:10px;padding:2px 8px;color:var(--muted);background:transparent}.project-modal-backdrop{position:fixed;inset:0;z-index:100;background:#050608b3;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:flex-start;justify-content:center;padding:clamp(1rem,5vw,3rem) 1rem;overflow-y:auto;animation:modal-fade .18s ease both}@keyframes modal-fade{0%{opacity:0}to{opacity:1}}.project-modal{position:relative;width:min(860px,100%);background:var(--bg-card);border:1px solid var(--border-strong);border-radius:14px;box-shadow:0 30px 80px #00000080;animation:modal-rise .32s cubic-bezier(.2,.8,.2,1) both}@keyframes modal-rise{0%{opacity:0;transform:translateY(24px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.project-modal-close{position:absolute;top:.8rem;right:.9rem;width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:var(--bg-elev);color:var(--fg-2);font-size:20px;line-height:1;cursor:pointer;transition:color .16s ease,border-color .16s ease,background .16s ease}.project-modal-close:hover{color:var(--fg);background:var(--bg-card);border-color:var(--border-strong)}.project-modal-head{padding:1.5rem 1.75rem 1rem;border-bottom:1px solid var(--border)}.project-modal-titles{display:flex;flex-wrap:wrap;align-items:baseline;gap:.75rem}.project-modal-head h2{margin:0;font-family:var(--serif);font-weight:400;font-size:clamp(1.5rem,3vw,2rem);letter-spacing:-.015em;line-height:1.15}.project-modal-head h2 a{color:var(--fg);border-bottom:none}.project-modal-head h2 a:after{content:" ↗";color:var(--muted);font-size:.65em;font-family:var(--mono)}.project-modal-head h2 a:hover{color:var(--accent)}.project-modal-head h2 a:hover:after{color:var(--accent)}.project-modal-badges{display:inline-flex;flex-wrap:wrap;gap:.3rem}.project-modal-meta{margin-top:.75rem;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);display:flex;flex-wrap:wrap;gap:.25rem .9rem}.project-modal-body{padding:1.25rem 1.75rem 1.75rem;max-height:calc(90vh - 6rem);overflow-y:auto;display:flex;flex-direction:column;gap:1.5rem}.project-modal-lead{margin:0;color:var(--fg);font-size:1rem;line-height:1.6;max-width:68ch}.project-modal-section h3{margin:0 0 .7rem;font-family:var(--mono);font-weight:500;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}.project-modal-section p{margin:0 0 .5rem;color:var(--fg-2);max-width:68ch;line-height:1.6}.project-modal-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1rem}.project-modal-features li{padding:.85rem 1rem;background:var(--bg-elev);border:1px solid var(--border);border-radius:8px}.project-modal-features strong{display:block;color:var(--fg);font-size:.95rem;margin-bottom:.3rem}.project-modal-features p{margin:0 0 .4rem;font-size:.9rem}.project-modal-impl{color:var(--muted)!important;font-size:.85rem!important}.project-modal-entrypoints{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.35rem}.project-modal-entrypoints code{font-size:10.5px;padding:2px 6px}.project-modal-changes{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.project-modal-changes li{padding-left:1rem;position:relative;color:var(--fg-2);font-size:.92rem;line-height:1.5}.project-modal-changes li:before{content:"";position:absolute;left:0;top:.6em;width:6px;height:1px;background:var(--border-strong)}.project-modal-changes strong{color:var(--fg);font-weight:600}.cloc-table{display:flex;flex-direction:column;gap:2px;font-family:var(--mono);font-size:12px}.cloc-head{display:grid;grid-template-columns:1fr 60px 2fr;gap:.8rem;padding:0 .6rem .3rem;color:var(--muted);font-size:10px;letter-spacing:.15em;text-transform:uppercase;border-bottom:1px solid var(--border)}.cloc-row{display:grid;grid-template-columns:1fr 60px 2fr;gap:.8rem;align-items:center;padding:.45rem .6rem;border-radius:4px}.cloc-row:hover{background:var(--bg-elev)}.cloc-lang{color:var(--fg)}.cloc-files{color:var(--fg-2)}.cloc-bar-cell{display:flex;align-items:center;gap:.6rem;min-width:0}.cloc-bar{flex:1;height:6px;background:var(--bg-elev);border-radius:3px;overflow:hidden}.cloc-bar-fill{display:block;height:100%;background:linear-gradient(to right,var(--accent),rgba(245,181,107,.4));border-radius:3px}.cloc-code{color:var(--fg-2);white-space:nowrap;min-width:70px;text-align:right}.cloc-total{margin-top:.3rem;border-top:1px solid var(--border);padding-top:.6rem;font-weight:600}.cloc-total .cloc-lang,.cloc-total .cloc-files,.cloc-total .cloc-code{color:var(--fg)}@media(max-width:540px){.project-modal-head{padding:1.1rem 1.1rem .8rem}.project-modal-body{padding:1rem 1.1rem 1.4rem}.cloc-head,.cloc-row{grid-template-columns:1fr 40px 1.4fr;gap:.5rem}}@keyframes rise{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}@media(max-width:640px){.cv-skill-group{grid-template-columns:1fr;gap:.4rem}.cv-education .cv-dates{margin-left:0}.cv-cta{padding:10px 15px;font-size:.88rem}.cv{padding-bottom:7rem}}.skip-link{position:fixed;top:-100px;left:16px;z-index:200;padding:10px 16px;border-radius:8px;background:var(--accent);color:#111;font-family:var(--sans);font-weight:600;font-size:.9rem;text-decoration:none;border:1px solid var(--accent);transition:top .18s ease}.skip-link:focus,.skip-link:focus-visible{top:16px;outline:none;box-shadow:0 0 0 3px #f5b56b59}.project-search-kbd{display:inline-flex;align-items:center;gap:2px;padding:3px 7px;border-radius:6px;border:1px solid var(--border-strong);background:var(--bg-elev);color:var(--muted);font-family:var(--mono);font-size:10.5px;letter-spacing:.05em;-webkit-user-select:none;user-select:none;transition:opacity .16s ease}.project-search-field:focus-within .project-search-kbd,.project-search-field:has(input[value]:not([value=""])) .project-search-kbd{opacity:0;pointer-events:none}.project-search-empty{padding:14px 12px;color:var(--muted);font-size:.9rem;text-align:center}.project-search-empty-chips{display:inline-flex;gap:6px;margin-left:6px}.project-search-empty-chip{background:transparent;border:1px dashed var(--border-strong);color:var(--fg-2);border-radius:999px;padding:2px 10px;font-family:var(--mono);font-size:11px;cursor:pointer;transition:color .14s ease,border-color .14s ease}.project-search-empty-chip:hover{color:var(--accent);border-color:var(--accent)}.filter-bar{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem .5rem;margin:0 0 .85rem;font-family:var(--mono);font-size:11.5px;color:var(--muted);letter-spacing:.04em}.filter-bar-label{text-transform:uppercase;letter-spacing:.18em;font-size:10.5px}.filter-bar-pill{display:inline-flex;align-items:center;gap:6px;padding:3px 4px 3px 10px;border-radius:999px;background:#f5b56b1a;color:var(--accent);border:1px solid rgba(245,181,107,.28)}.filter-bar-pill-x{appearance:none;border:0;background:transparent;color:inherit;cursor:pointer;font-size:14px;line-height:1;padding:2px 6px;border-radius:999px;transition:background .14s ease}.filter-bar-pill-x:hover{background:#f5b56b33}.filter-bar-clear{appearance:none;background:transparent;border:0;color:var(--fg-2);font:inherit;text-transform:uppercase;letter-spacing:.14em;cursor:pointer;padding:2px 8px;border-bottom:1px dashed var(--border-strong);transition:color .14s ease,border-color .14s ease}.filter-bar-clear:hover{color:var(--accent);border-bottom-color:var(--accent)}.cv-chip.is-clickable{cursor:pointer;appearance:none;font:inherit}.cv-chip.is-active{color:var(--accent);border-color:#f5b56b73;background:#f5b56b1a}.cv-section{content-visibility:auto;contain-intrinsic-size:1px 800px}@supports (animation-timeline: view()){@media(prefers-reduced-motion:no-preference){.project-card{animation:card-rise linear both;animation-timeline:view();animation-range:entry 0% cover 18%}}}@keyframes card-rise{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.lang-switcher{display:inline-flex;gap:2px;padding:3px;margin:0 auto 16px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:999px;font-family:JetBrains Mono,ui-monospace,monospace;font-size:12px;box-shadow:0 2px 8px #0003}.lang-switcher-wrap{display:flex;justify-content:center;width:100%;position:relative;z-index:10}.lang-switcher-btn{appearance:none;border:0;background:transparent;padding:4px 8px;border-radius:999px;cursor:pointer;color:var(--fg-2);font:inherit;letter-spacing:.04em;display:inline-flex;align-items:center;justify-content:center;line-height:1;opacity:.55;transition:background .15s ease,color .15s ease,opacity .15s ease,transform .15s ease}.lang-switcher-btn .lang-flag{font-size:16px;line-height:1}.lang-switcher-btn:hover{opacity:1;transform:translateY(-1px)}.lang-switcher-btn.is-active{opacity:1;background:#ffffff1f}.lang-banner{position:fixed;bottom:16px;left:50%;display:flex;align-items:center;gap:14px;padding:10px 16px;background:#111317eb;color:#fff;border:1px solid rgba(231,229,223,.1);border-radius:999px;box-shadow:0 14px 36px -10px #0009;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);z-index:49;font-family:Bricolage Grotesque,system-ui,sans-serif;font-size:14px;max-width:calc(100% - 32px);animation:lang-banner-in .32s cubic-bezier(.2,.7,.2,1) both}@keyframes lang-banner-in{0%{opacity:0;transform:translate(-50%,16px)}to{opacity:1;transform:translate(-50%)}}.lang-banner-prompt{font-weight:500}.lang-banner-actions{display:inline-flex;gap:6px}.lang-banner-btn{appearance:none;border:1px solid rgba(255,255,255,.2);background:transparent;color:inherit;font:inherit;padding:5px 12px;border-radius:999px;cursor:pointer;transition:background .15s ease}.lang-banner-btn:hover{background:#ffffff1f}.lang-banner-yes{background:#fff;color:#111;border-color:#fff}.lang-banner-yes:hover{background:#f0f0f0}@media(max-width:480px){.lang-banner{flex-direction:column;align-items:stretch;text-align:center}.lang-banner-actions{justify-content:center}}.nav-header{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:center;gap:16px;padding:10px 14px;margin:0 -14px 24px;background:#0b0c0eb8;backdrop-filter:saturate(160%) blur(12px);-webkit-backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid rgba(231,229,223,.06)}.nav-header-links{list-style:none;margin:0;padding:0;display:inline-flex;flex-wrap:wrap;gap:2px}.nav-header-links a{position:relative;display:inline-flex;align-items:center;gap:6px;padding:6px 12px 6px 10px;border-radius:999px;color:var(--muted, #7a7971);font-family:JetBrains Mono,ui-monospace,monospace;font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;text-decoration:none;border:1px solid transparent;transition:color .16s ease,border-color .16s ease,background .16s ease}.nav-header-dot{width:5px;height:5px;border-radius:50%;background:transparent;border:1px solid var(--border-strong, #2a2e36);transition:background .16s ease,border-color .16s ease,box-shadow .2s ease;flex-shrink:0}.nav-header-links a:hover{color:var(--fg, #e7e5df)}.nav-header-links a:hover .nav-header-dot{border-color:var(--fg-2, #b4b2ac)}.nav-header-links a.is-active{color:var(--fg, #e7e5df)}.nav-header-links a.is-active .nav-header-dot{background:var(--accent-2, #9af5c8);border-color:var(--accent-2, #9af5c8);box-shadow:0 0 0 3px #9af5c82e}.nav-header-actions{display:inline-flex;align-items:center;gap:10px}.top-header__left{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.top-header__view-toggle{appearance:none;background:transparent;color:var(--fg, #e7e5df);border:1px solid var(--border-strong, #2a2e36);border-radius:999px;padding:6px 14px;font-family:JetBrains Mono,ui-monospace,monospace;font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;cursor:pointer;transition:color .16s ease,border-color .16s ease,background .16s ease}.top-header__view-toggle:hover{color:var(--accent, #9af5c8);border-color:var(--accent, #9af5c8)}.top-header__view-toggle.is-active{color:var(--accent-2, #9af5c8);border-color:var(--accent-2, #9af5c8);background:#9af5c814}.nav-header-actions .lang-switcher{margin:0}.sound-toggle{position:fixed;top:1rem;right:9.5rem;z-index:50;width:2.25rem;height:2.25rem;display:inline-flex;align-items:center;justify-content:center;background:var(--bg-card);color:var(--fg);border:1px solid var(--border-strong);border-radius:999px;cursor:pointer;transition:border-color .15s ease,color .15s ease}.sound-toggle:hover{border-color:var(--accent);color:var(--accent)}.sound-toggle[aria-pressed=true]{color:var(--accent);border-color:var(--accent)}.nav-header-actions .sound-toggle{position:static;width:2rem;height:2rem}.section-nav{position:fixed;left:50%;bottom:20px;transform:translate(-50%);z-index:40;padding:6px 10px;border:1px solid rgba(231,229,223,.08);border-radius:999px;background:#0b0c0eb8;backdrop-filter:saturate(160%) blur(14px);-webkit-backdrop-filter:saturate(160%) blur(14px);box-shadow:0 12px 30px -12px #0009;max-width:calc(100vw - 24px)}.section-nav .nav-header-links{flex-wrap:wrap;justify-content:center}@media(max-width:560px){.nav-header{flex-direction:column;align-items:stretch;gap:4px;padding:6px 10px;margin:0 0 8px}.nav-header-links a{padding:4px 8px;font-size:10px;letter-spacing:.12em}.nav-header-links,.nav-header-actions{justify-content:center}.section-nav{display:none}.top-header__left{justify-content:center;gap:4px}.top-header__view-toggle{padding:4px 10px;font-size:10px;letter-spacing:.12em}}
