:root{--color-bg:#fff;--color-surface:#f8f9fa;--color-surface-alt:#f9fafb;--color-surface-variant:#e1e3e4;--color-surface-deep:#fff;--color-text:#171717;--color-text-muted:#444748;--color-outline:#747878;--color-outline-variant:#c4c7c7;--color-accent:#4d7c0f;--color-accent-ink:#3e6a00;--color-inverse:#fff;--color-navbar-bg:#ffffffe6;--font-serif:"Newsreader",ui-serif,Georgia,serif;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-tech:"Space Grotesk","Inter",sans-serif;--font-mono:ui-monospace,"SF Mono",Menlo,Consolas,monospace;--container-max:800px;--gutter:1.5rem;--section-gap:5rem;--radius:.25rem;--radius-lg:.5rem;font-family:var(--font-sans);--buncss-light:initial;--buncss-dark: ;color-scheme:light}:root[data-theme=dark]{--color-bg:#0f1113;--color-surface:#17191c;--color-surface-alt:#1b1e22;--color-surface-variant:#2a2d31;--color-surface-deep:#0a0b0d;--color-text:#e8eaed;--color-text-muted:#a7acb1;--color-outline:#6b7075;--color-outline-variant:#333740;--color-accent:#a3c86d;--color-accent-ink:#b6d982;--color-inverse:#0f1113;--color-navbar-bg:#0f1113d9;--buncss-light: ;--buncss-dark:initial;color-scheme:dark}*{box-sizing:border-box}html,body,#root{height:100%}body{background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-size:1rem;line-height:1.6}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}h1,h2,h3,h4{font-family:var(--font-serif);letter-spacing:-.02em;margin:0;font-weight:400;line-height:1.2}p{margin:0}.app{display:flex;background:var(--color-bg);flex-direction:column;min-height:100%}.main{max-width:var(--container-max);padding:8rem var(--gutter)0;flex:1;width:100%;margin:0 auto}.page{padding-bottom:var(--section-gap)}.page>h1{letter-spacing:-.02em;margin-bottom:1rem;font-size:2.5rem}.section{margin-bottom:var(--section-gap)}.section__label{font-family:var(--font-tech);letter-spacing:.05em;text-transform:uppercase;color:var(--color-outline);margin-bottom:2rem;font-size:.875rem;font-weight:500}.navbar{position:fixed;z-index:50;background:var(--color-navbar-bg);backdrop-filter:saturate(180%)blur(8px);-webkit-backdrop-filter:saturate(180%)blur(8px);border-bottom:1px solid var(--color-outline-variant);width:100%;top:0;left:0}.navbar__inner{display:flex;max-width:var(--container-max);padding:0 var(--gutter);justify-content:space-between;align-items: center;height:4rem;margin:0 auto}.navbar__brand{font-family:var(--font-serif);letter-spacing:-.02em;color:var(--color-text);font-size:1.35rem;font-weight:500;line-height:1}.navbar__links{display:none;align-items: center;gap:2rem}@media (min-width:768px){.navbar__links{display:flex}}.navbar__link{font-family:var(--font-serif);letter-spacing:.02em;text-transform:uppercase;color:var(--color-text-muted);border-bottom:1px solid #0000;padding:.25rem 0;transition:color .2s,border-color .2s;font-size:.8125rem;line-height:1}.navbar__link:hover{color:var(--color-text)}.navbar__link--active{color:var(--color-text);border-bottom-color:var(--color-text)}.navbar__actions{display:flex;align-items: center;gap:1rem}.navbar__icon{color:var(--color-text);display:inline-flex;align-items: center;font-size:1.125rem;line-height:1}.navbar__term{position:relative;display:inline-flex}.navbar__icon-btn{display:inline-flex;border-radius:var(--radius);color:var(--color-text);cursor:pointer;background:0 0;border:1px solid #0000;justify-content:center;align-items: center;width:2rem;height:2rem;padding:0;transition:border-color .15s,color .15s,background .15s}.navbar__icon-btn:hover,.navbar__icon-btn[aria-expanded=true]{border-color:var(--color-outline-variant);color:var(--color-accent)}.navbar__icon-btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.navbar__term-panel{position:absolute;background:var(--color-surface-deep);border:1px solid var(--color-outline-variant);border-radius:var(--radius);overflow:hidden;opacity:0;transform-origin:top right;pointer-events:none;width:19rem;transition:opacity .18s,transform .22s cubic-bezier(.22,.61,.36,1);top:calc(100% + .5rem);right:0;transform:translateY(-6px)scale(.96);box-shadow:0 12px 24px -14px #00000059}.navbar__term-panel.is-open{opacity:1;pointer-events:auto;transform:translateY(0)scale(1)}.status-panel{font-family:var(--font-mono);color:var(--color-text);padding:.9rem 1rem;font-size:.8125rem;line-height:1.55}.status-panel__prompt{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:.7rem;font-size:.75rem}.status-panel__user{color:#7fb77a}.status-panel__path{color:#6fa8dc}.status-panel__sep{color:var(--color-text-muted)}.status-panel__cmd{color:var(--color-text)}.status-panel__rows{display:flex;flex-direction:column;gap:.2rem;margin:0}.status-panel__row{display:grid;grid-template-columns:4.5rem 1fr;gap:.4rem}.status-panel__label{color:var(--color-text-muted);text-transform:lowercase;margin:0}.status-panel__value{color:var(--color-text);margin:0}.status-panel__sky{font-family:var(--font-mono);letter-spacing:0;white-space:pre;overflow:hidden;border:1px solid #1a1c20;border-radius:3px;margin:.75rem 0 0;padding:.5rem .6rem;font-size:.6875rem;line-height:1.1}.status-panel__sky--day{color:#d9e8f5;background:linear-gradient(#1a3a5c,#2d5c8a 60%,#6b8ba8)}.status-panel__sky--night{color:#9bb0d0;background:linear-gradient(#0a0e1a,#111830 70%,#1a2240)}.status-panel__sky-row{display:block;white-space:pre}.status-panel__sky-cell{white-space:pre}.status-panel__sky-cell--sun{color:#fcd34d;font-weight:700}.status-panel__sky-cell--sun-dim{color:#e6c177;opacity:.75;font-weight:700}.status-panel__sky-cell--moon{color:#e5e7eb}.status-panel__sky-cell--moon-dim{color:#c9ccd4;opacity:.7}.status-panel__sky-cell--star{color:#cbd5e1}.status-panel__sky-cell--cloud{color:#cdd7e1;opacity:.85}.status-panel__sky-cell--rain{color:#a5d8ff}.status-panel__sky-cell--snow{color:#f1f5f9;font-weight:600}.status-panel__sky-cell--fog{color:#8b96a6;opacity:.8}.status-panel__sky-cell--lightning{color:#fde68a;font-weight:700}.status-panel__sky--day .status-panel__sky-cell--cloud{color:#e8eff6;opacity:.9}.status-panel__sky--w-overcast.status-panel__sky--day{background:linear-gradient(#3a4a5c,#4b5b6e 60%,#6b7580)}.status-panel__sky--w-overcast.status-panel__sky--night{background:linear-gradient(#0b0f18,#181f2b 70%,#252c3a)}.status-panel__sky--w-fog.status-panel__sky--day{background:linear-gradient(#5c6672,#7a8490 60%,#a0a8b2)}.status-panel__sky--w-fog.status-panel__sky--night{background:linear-gradient(#14181f,#252a34 70%,#363b46)}.status-panel__sky--w-rain.status-panel__sky--day,.status-panel__sky--w-light-rain.status-panel__sky--day{background:linear-gradient(#2a3a4f,#3a4c63 60%,#586b80)}.status-panel__sky--w-rain.status-panel__sky--night,.status-panel__sky--w-light-rain.status-panel__sky--night{background:linear-gradient(#070b14,#0e1624 70%,#182133)}.status-panel__sky--w-snow.status-panel__sky--day{background:linear-gradient(#3b4a5e,#52657b 60%,#8597a8)}.status-panel__sky--w-snow.status-panel__sky--night{background:linear-gradient(#0c1220,#1a2233 70%,#2c374a)}.status-panel__sky--w-storm.status-panel__sky--day{background:linear-gradient(#1f2630,#2a3240 60%,#434c5a)}.status-panel__sky--w-storm.status-panel__sky--night{background:linear-gradient(#05070a,#0a0d14 70%,#13181f)}.status-panel__sky.is-flashing{color:#1f2937;transition:background 80ms;background:#e2e8f0!important}.status-panel__sky.is-flashing .status-panel__sky-cell--cloud,.status-panel__sky.is-flashing .status-panel__sky-cell--rain{color:#1f2937}.navbar__resume{padding:.35rem .85rem;font-size:.8125rem;line-height:1}.navbar__toggle{display:inline-flex;border:1px solid var(--color-outline-variant);border-radius:var(--radius);color:var(--color-text);cursor:pointer;background:0 0;justify-content:center;align-items: center;width:2.25rem;height:2.25rem;padding:0;transition:border-color .15s,color .15s}.navbar__toggle:hover{border-color:var(--color-accent);color:var(--color-accent)}.navbar__toggle:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@media (min-width:768px){.navbar__toggle{display:none}}@media (max-width:767px){.navbar__resume,.navbar__icon,.navbar__term{display:none}}.navbar__mobile{display:flex;padding:0 var(--gutter);background:var(--color-navbar-bg);backdrop-filter:saturate(180%)blur(8px);-webkit-backdrop-filter:saturate(180%)blur(8px);overflow:hidden;opacity:0;border-top:1px solid #0000;flex-direction:column;gap:.25rem;max-height:0;transition:max-height .26s,opacity .2s,padding .26s,border-color .26s}.navbar__mobile--open{opacity:1;padding:.5rem var(--gutter)1rem;border-top-color:var(--color-outline-variant);overflow-y:auto;max-height:calc(100vh - 4rem)}@media (min-width:768px){.navbar__mobile{display:none}}@media (prefers-reduced-motion:reduce){.navbar__mobile{transition:none}}.navbar__mobile-link{font-family:var(--font-serif);letter-spacing:-.01em;text-transform:uppercase;color:var(--color-text-muted);border-bottom:1px solid var(--color-outline-variant);padding:.75rem .25rem;transition:color .15s;font-size:1rem}.navbar__mobile-link:hover,.navbar__mobile-link--active{color:var(--color-text)}.navbar__mobile-resume{align-self: flex-start;margin-top:.75rem}.btn{display:inline-flex;font-family:var(--font-serif);letter-spacing:-.01em;text-transform:uppercase;cursor:pointer;border:1px solid #0000;border-radius:0;justify-content:center;align-items: center;padding:.5rem 1rem;transition:transform .12s,background .2s,color .2s;font-size:.875rem}.btn:active{transform:scale(.98)}.btn--primary{background:var(--color-text);color:var(--color-inverse);border-color:var(--color-text)}.btn--primary:hover{background:var(--color-inverse);color:var(--color-text);border-color:var(--color-text)}.btn--ghost{color:var(--color-text);border-color:var(--color-text);background:0 0}.btn--ghost:hover{background:var(--color-text);color:var(--color-inverse)}.btn--sm{padding:.375rem .75rem;font-size:.75rem}.hero{margin-bottom:2.5rem}.hero__title{letter-spacing:-.02em;margin-bottom:1.5rem;font-size:2.5rem;line-height:1.2}.hero__tagline{color:var(--color-text-muted);max-width:42rem;font-size:1.125rem;line-height:1.7}.hero__ctas{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem}.hero__rule{display:flex;align-items: center;gap:1rem;margin-top:2rem}.hero__rule-line{background:var(--color-outline-variant);opacity:.3;flex:1;height:1px}.hero__rule-tag{font-family:var(--font-mono);letter-spacing:.15em;text-transform:uppercase;color:var(--color-outline);font-size:.8125rem}.competencies{display:grid;grid-template-columns:1fr;gap:3rem}@media (min-width:768px){.competencies{grid-template-columns:repeat(3,1fr)}}.competency__head{display:flex;align-items: center;gap:.5rem;margin-bottom:1rem}.competency__icon{color:var(--color-accent);font-size:1.25rem}.competency__title{font-family:var(--font-serif);font-size:1.125rem;line-height:1.3}.competency__list{list-style:none;display:flex;color:var(--color-text-muted);flex-direction:column;gap:.5rem;margin:0;padding:0}.competency__item{display:flex;align-items: center;gap:.5rem}.competency__dot{background:var(--color-accent);border-radius:9999px;flex:none;width:4px;height:4px}.project-list{display:flex;flex-direction:column;gap:3rem}.project-card{border:1px solid #c4c7c74d;padding:2rem;transition:background .3s,color .3s,border-color .3s}.project-card:hover{background:var(--color-text);color:var(--color-inverse);border-color:var(--color-text)}.project-card:hover .project-card__title,.project-card:hover .project-card__desc{color:var(--color-inverse)}.project-card:hover .project-card__tag{background:var(--color-inverse);color:var(--color-text)}.project-card__row{display:flex;flex-direction:column;justify-content:space-between;align-items: flex-start;gap:1.5rem}@media (min-width:768px){.project-card__row{flex-direction:row}}.project-card__body{flex:1}.project-card__title{font-family:var(--font-serif);margin-bottom:.5rem;transition:color .3s;font-size:1.75rem;line-height:1.3}.project-card__title a{color:inherit}.project-card__title a:hover{color:var(--color-accent-ink)}.project-card__desc{color:var(--color-text-muted);margin-bottom:1.5rem;transition:color .3s;font-size:1rem;line-height:1.6}.project-card__tags{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;margin:0;padding:0}.project-card__tag{font-family:var(--font-mono);background:var(--color-surface-variant);color:var(--color-text);border-radius:var(--radius);padding:.25rem .5rem;transition:background .3s,color .3s;font-size:.8125rem;line-height:1.5}.project-card__media{overflow:hidden;background:#f3f4f5;flex:none;width:100%;height:8rem}@media (min-width:768px){.project-card__media{width:12rem}}.project-card__media img{object-fit:cover;filter:grayscale(100%);opacity:.6;width:100%;height:100%;transition:filter .5s,opacity .5s}.project-card:hover .project-card__media img{filter:grayscale(0);opacity:1}.project-card{cursor:pointer}.project-card:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.project-card--returning{animation:project-card-return .32s ease forwards}@keyframes project-card-return{0%{opacity:0}to{opacity:1}}.project-card--returning .project-card__title{opacity:0}.project-window-backdrop{position:fixed;z-index:100;backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px);background:#0a0c0e00;transition:background .32s,backdrop-filter .32s;inset:0}.project-window-backdrop--entering,.project-window-backdrop--open{backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);background:#0a0c0e73}.project-window-backdrop--closing{backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px);background:#0a0c0e00}.project-window{position:fixed;background:var(--color-bg);border:1px solid var(--color-outline-variant);border-radius:var(--radius-lg);overflow:hidden;display:flex;opacity:1;will-change:left,top,width,height,opacity;flex-direction:column;transition:left .36s cubic-bezier(.2,.8,.2,1),top .36s cubic-bezier(.2,.8,.2,1),width .36s cubic-bezier(.2,.8,.2,1),height .36s cubic-bezier(.2,.8,.2,1),opacity .4s;box-shadow:0 30px 60px -20px #00000059,0 10px 20px -10px #00000040}.project-window--closing{opacity:0}.project-window__chrome{display:flex;background:var(--color-surface);border-bottom:1px solid var(--color-outline-variant);flex:none;align-items: center;gap:.75rem;padding:.6rem .9rem}.project-window__title{text-align:center;font-family:var(--font-mono);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;transition:opacity .12s;font-size:.8125rem}.project-window--closing .project-window__title{opacity:0}.project-window__ghost-title{position:fixed;z-index:101;pointer-events:none;letter-spacing:-.02em;white-space:nowrap;opacity:0;will-change:left,top,font-size;transition:left .36s cubic-bezier(.2,.8,.2,1),top .36s cubic-bezier(.2,.8,.2,1),font-size .36s cubic-bezier(.2,.8,.2,1),color .36s;font-weight:400;line-height:1.3}.project-window__ghost-title--closing{opacity:1}.project-window__title-inner{display:inline-block}@media (prefers-reduced-motion:reduce){.project-window__ghost-title{display:none}.project-window--open .project-window__title,.project-window .project-window__title{opacity:1;transition:none}}.project-window__close{appearance:none;color:var(--color-text-muted);border-radius:var(--radius);cursor:pointer;display:inline-flex;background:0 0;border:none;justify-content:center;align-items: center;width:1.75rem;height:1.75rem;padding:0;transition:background .15s,color .15s;font-size:1.4rem;line-height:1}.project-window__close:hover{background:var(--color-surface-variant);color:var(--color-text);outline:none}.project-window__close:focus-visible{background:var(--color-surface-variant);color:var(--color-text);outline:none}.project-window__scroll{overflow-y:auto;opacity:0;flex:1;transition:opacity .22s .12s}.project-window--open .project-window__scroll{opacity:1}.project-window--closing .project-window__scroll{opacity:0;transition:opacity .16s}.project-window__hero{aspect-ratio:16/7;background:var(--color-surface-variant);overflow:hidden;width:100%}.project-window__hero img{object-fit:cover;width:100%;height:100%}.project-window__hero--placeholder{background:linear-gradient(135deg,var(--color-surface)0%,var(--color-surface-variant)100%)}.project-window__body{max-width:780px;margin:0 auto;padding:2rem clamp(1.25rem,4vw,2.5rem)}.project-window__tags{margin-bottom:1.5rem}.project-window__para{color:var(--color-text);margin:0 0 1rem;font-size:1.0625rem;line-height:1.7}.project-window__links{display:flex;flex-wrap:wrap;gap:1rem;margin:1.5rem 0 0}.project-window__link{font-family:var(--font-mono);color:var(--color-accent-ink);border-bottom:1px solid var(--color-accent-ink);padding-bottom:1px;font-size:.875rem}.project-window__related{border-top:1px solid var(--color-outline-variant);margin-top:3rem;padding-top:2rem}.project-window__related-label{font-family:var(--font-tech);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin:0 0 1rem;font-size:.75rem}.project-window__related-list{display:flex;flex-direction:column;gap:1.25rem}@media (prefers-reduced-motion:reduce){.project-window{transition:opacity .16s}.project-window-backdrop{transition:background .16s}}.timeline{position:relative;display:flex;border-left:1px solid #c4c7c74d;flex-direction:column;gap:4rem;padding-left:2rem}.timeline__item{position:relative}.timeline__dot{position:absolute;background:#a3a3a3;border-radius:9999px;width:8px;height:8px;top:.25rem;left:calc(-2rem - 5px)}.timeline__dot--current{background:var(--color-text)}.timeline__period{display:block;font-family:var(--font-mono);letter-spacing:.05em;text-transform:uppercase;color:var(--color-accent-ink);margin-bottom:.5rem;font-size:.8125rem}.timeline__role{font-family:var(--font-serif);margin-bottom:.5rem;font-size:1.25rem;line-height:1.3}.timeline__summary{color:var(--color-text-muted)}.skill-list{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;margin:0;padding:0}.about-page h1{margin-bottom:1.5rem;font-size:2.5rem}.about-intro{display:flex;flex-direction:column;gap:1rem;max-width:42rem;margin-bottom:4rem}.about-section{max-width:42rem}.about-section__title{font-family:var(--font-serif);color:var(--color-text);margin-bottom:1.25rem;font-size:1.625rem;line-height:1.3}.about-prose{display:flex;color:var(--color-text-muted);flex-direction:column;gap:1rem;font-size:1.0625rem;line-height:1.7}.about-list{list-style:none;display:flex;flex-direction:column;gap:.75rem;margin:0;padding:0}.about-list__item{display:flex;color:var(--color-text-muted);gap:.75rem;font-size:1rem;line-height:1.6}.about-list__marker{font-family:var(--font-mono);color:var(--color-accent);flex:none;padding-top:.125rem;font-size:.875rem}.about-stack{display:flex;flex-direction:column;gap:1.5rem}.about-stack__group{display:flex;flex-direction:column;gap:.5rem}.about-stack__title{font-family:var(--font-tech);letter-spacing:.08em;text-transform:uppercase;color:var(--color-outline);margin:0;font-size:.75rem;font-weight:500}.about-now{display:flex;flex-direction:column;gap:.875rem;margin:0;padding:0}.about-now__row{display:grid;grid-template-columns:7rem 1fr;border-bottom:1px solid var(--color-outline-variant);align-items:baseline;gap:1rem;padding-bottom:.875rem}.about-now__row:last-child{border-bottom:none;padding-bottom:0}.about-now__label{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--color-outline);margin:0;font-size:.75rem}.about-now__value{color:var(--color-text);margin:0;font-size:1rem;line-height:1.5}.about-quote{border-left:2px solid var(--color-accent);margin:0;padding:1rem 0 1rem 1.25rem}.about-quote__body{font-family:var(--font-serif);color:var(--color-text);margin:0 0 .5rem;font-size:1.25rem;font-style:italic;line-height:1.5}.about-quote__attr{font-family:var(--font-mono);color:var(--color-outline);font-size:.8125rem}.bookshelf{margin:0 calc(-1*var(--gutter));overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch}.bookshelf::-webkit-scrollbar{display:none}.bookshelf:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.bookshelf__list{list-style:none;padding:.5rem var(--gutter)1rem;display:flex;gap:1.5rem;margin:0}.bookshelf__item{scroll-snap-align:start;display:flex;flex-direction:column;flex:0 0 9.5rem;gap:.75rem}.bookshelf__cover{position:relative;aspect-ratio:2/3;background:var(--color-surface-variant);border-radius:var(--radius);overflow:hidden;display:flex;justify-content:center;align-items: center;box-shadow:0 6px 14px -8px #0000004d}.bookshelf__cover img{object-fit:cover;width:100%;height:100%}.bookshelf__cover-fallback{font-family:var(--font-serif);color:var(--color-text-muted);letter-spacing:.05em;font-size:1.5rem}.bookshelf__meta{display:flex;flex-direction:column;gap:.25rem}.bookshelf__title{font-family:var(--font-serif);color:var(--color-text);margin:0;font-size:.9375rem;line-height:1.3}.bookshelf__author{color:var(--color-text-muted);margin:0;font-size:.8125rem}.bookshelf__status{font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;border-radius:var(--radius);background:var(--color-surface-variant);color:var(--color-text-muted);align-self: flex-start;margin-top:.25rem;padding:.15rem .45rem;font-size:.6875rem}.bookshelf__status--reading{color:#14532d;background:#bbf7d0}.bookshelf__status--read{color:#f0fdf4;background:#14532d}.bookshelf__status--want{color:#713f12;background:#fef08a}.playlist{position:relative;margin:0 calc(-1*var(--gutter));overflow:hidden;cursor:grab;touch-action:pan-y;-webkit-mask-image:linear-gradient(90deg,#0000,#000 4rem calc(100% - 4rem),#0000);mask-image:linear-gradient(90deg,#0000,#000 4rem calc(100% - 4rem),#0000);padding:.5rem 0 1rem}.playlist.is-dragging{cursor:grabbing;user-select:none}.playlist.is-dragging *{pointer-events:none}.playlist:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.playlist__list{--playlist-item:9.5rem;--playlist-gap:1.25rem;list-style:none;display:flex;gap:var(--playlist-gap);will-change:transform;width:max-content;margin:0;padding:0;transition:filter .25s}.playlist__item{flex:0 0 var(--playlist-item);display:flex;flex-direction:column;gap:.6rem}.playlist__link{display:block;text-decoration:none;color:inherit}.playlist__art{position:relative;aspect-ratio:1;background:var(--color-surface-variant);border-radius:var(--radius);overflow:hidden;display:flex;justify-content:center;align-items: center;transition:transform .15s;box-shadow:0 6px 14px -8px #0000004d}.playlist__art:hover,.playlist__art:focus-within{transform:translateY(-2px)}.playlist__art img{object-fit:cover;width:100%;height:100%}.playlist__art-fallback{font-family:var(--font-mono);letter-spacing:.05em;color:var(--color-text-muted);font-size:1.5rem}.playlist__play{position:absolute;display:flex;color:var(--color-text);background:var(--color-surface);cursor:pointer;opacity:0;border:0;border-radius:999px;justify-content:center;align-items: center;width:1.75rem;height:1.75rem;padding:0;transition:opacity .15s,transform .15s;font-family:inherit;font-size:.75rem;line-height:1;inset:auto .5rem .5rem auto}.playlist__art:hover .playlist__play,.playlist__art.is-playing .playlist__play{opacity:1}.playlist__play:focus-visible{opacity:1}.playlist__play:hover{transform:scale(1.08)}.playlist__play .material-symbols-outlined{font-size:1rem}.playlist__art.is-playing{box-shadow:0 0 0 2px var(--color-accent),0 6px 14px -8px #0000004d}.playlist__meta{display:flex;flex-direction:column;gap:.15rem}.playlist__title{font-family:var(--font-serif);color:var(--color-text);display:inline-flex;flex-wrap:wrap;align-items: center;gap:.4rem;margin:0;font-size:.9375rem;line-height:1.3}.playlist__explicit{font-family:var(--font-mono);letter-spacing:.02em;background:var(--color-surface-variant);color:var(--color-text-muted);border:1px solid var(--color-outline-variant);text-transform:uppercase;border-radius:3px;padding:.15rem .3rem;font-size:.625rem;font-weight:600;line-height:1}.playlist__list.is-blurred{filter:blur(4px)}.playlist__cta{position:absolute;display:inline-flex;background:var(--color-surface);border:1px solid var(--color-outline-variant);font-family:var(--font-mono);letter-spacing:.02em;color:var(--color-text);pointer-events:none;animation:playlist-cta-fade .18s ease both;white-space:nowrap;z-index:1;border-radius:999px;align-items: center;gap:.75rem;padding:.55rem 1.1rem;font-size:.8125rem;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 8px 24px -12px #0000004d}.playlist__cta-icon,.playlist__cta .playlist__cta-icon.material-symbols-outlined{color:var(--color-accent);font-size:.875rem}.playlist__cta-arrow,.playlist__cta .playlist__cta-arrow.material-symbols-outlined{color:var(--color-text-muted);animation:playlist-cta-arrow 1.4s ease-in-out infinite;font-size:1rem}.playlist__cta-arrow:last-child{animation-delay:.7s}.playlist__cta-text{text-transform:lowercase}@keyframes playlist-cta-fade{0%{opacity:0;transform:translate(-50%,calc(4px - 50%))}to{opacity:1;transform:translate(-50%,-50%)}}@keyframes playlist-cta-arrow{0%,to{transform:translate(0);opacity:.55}50%{transform:translate(-3px);opacity:1}}.playlist__cta-arrow:last-child{animation-name:playlist-cta-arrow-right}@keyframes playlist-cta-arrow-right{0%,to{transform:translate(0);opacity:.55}50%{transform:translate(3px);opacity:1}}.playlist__artist{color:var(--color-text-muted);margin:0;font-size:.8125rem}.playlist__album{font-family:var(--font-mono);letter-spacing:.02em;color:var(--color-text-muted);opacity:.8;margin:0;font-size:.6875rem}@media (max-width:540px){.about-now__row{grid-template-columns:1fr;gap:.25rem}}.skill-list__item{font-family:var(--font-mono);background:var(--color-surface-alt);border:1px solid var(--color-outline-variant);border-radius:var(--radius-lg);color:var(--color-text);padding:.25rem .6rem;font-size:.8125rem}.contact-form{display:flex;flex-direction:column;gap:1.5rem;max-width:32rem;margin-top:2rem;margin-bottom:2rem}.contact-form__field{display:flex;flex-direction:column;gap:.375rem}.contact-form__field span{font-family:var(--font-tech);letter-spacing:.05em;text-transform:uppercase;color:var(--color-outline);font-size:.875rem}.contact-form__field input,.contact-form__field textarea{color:var(--color-text);border:none;border-bottom:1px solid var(--color-outline-variant);font:inherit;font-family:var(--font-sans);background:0 0;padding:.5rem 0}.contact-form__field input:focus,.contact-form__field textarea:focus{outline:none;border-bottom:2px solid var(--color-accent)}.contact-form__field textarea{resize:vertical;min-height:6rem}.contact-form__submit{font-family:var(--font-serif);letter-spacing:-.01em;text-transform:uppercase;background:var(--color-text);color:var(--color-inverse);border:1px solid var(--color-text);cursor:pointer;align-self: flex-start;padding:.5rem 1rem;transition:transform .12s,background .2s,color .2s,border-color .2s;font-size:.875rem}.contact-form__submit:hover{background:var(--color-inverse);color:var(--color-text);border-color:var(--color-text)}.contact-form__submit:active{transform:scale(.98)}.contact-form__submit:disabled{opacity:.6;cursor:progress;transform:none}.contact-form__success{color:var(--color-accent-ink);font-family:var(--font-mono)}.contact-form__error{color:#b3261e;font-family:var(--font-mono);font-size:.8125rem}.footer{border-top:1px solid var(--color-outline-variant);margin-top:var(--section-gap);background:var(--color-surface);width:100%}.footer__inner{max-width:var(--container-max);padding:3rem var(--gutter);display:flex;flex-direction:column;justify-content:space-between;align-items: center;gap:1rem;margin:0 auto}@media (min-width:768px){.footer__inner{flex-direction:row}}.footer__meta,.footer__socials a{font-family:var(--font-mono);letter-spacing:.15em;text-transform:uppercase;color:var(--color-text-muted);font-size:.625rem}.footer__socials{display:flex;gap:2rem}.footer__socials a{color:var(--color-outline);transition:color .2s}.footer__socials a:hover{color:var(--color-accent-ink)}.material-symbols-outlined{letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-feature-settings:"liga";-webkit-font-smoothing:antialiased;font-variation-settings:"FILL" 0,"wght" 300,"GRAD" 0,"opsz" 24;font-family:Material Symbols Outlined;font-size:1.25rem;font-style:normal;font-weight:400;line-height:1}.github-card{display:flex;border:1px solid var(--color-outline-variant);border-radius:var(--radius-lg);background:var(--color-surface);align-items: center;gap:1.5rem;padding:1.25rem}.github-card__avatar{overflow:hidden;border:1px solid var(--color-outline-variant);border-radius:9999px;flex:none;width:72px;height:72px}.github-card__avatar img{object-fit:cover;width:100%;height:100%}.github-card__chart{flex:1;min-width:0}.github-card__chart img{width:100%;height:auto}:root[data-theme=dark] .github-card__chart img{filter:invert(.92)hue-rotate(180deg)}@media (max-width:540px){.github-card{flex-direction:column;align-items:stretch}.github-card__avatar{align-self: center}}.linkedin-card{display:flex;border:1px solid var(--color-outline-variant);border-radius:var(--radius-lg);background:var(--color-surface);color:var(--color-text);align-items: center;gap:1rem;padding:.875rem 1.25rem;transition:border-color .2s,background .2s}.linkedin-card:hover{border-color:var(--color-accent);background:var(--color-surface-alt)}.linkedin-card__icon{display:inline-flex;color:#0a66c2;flex:none;justify-content:center;align-items: center;width:2rem;height:2rem}:root[data-theme=dark] .linkedin-card__icon{color:#4a9fe5}.linkedin-card__icon svg{width:100%;height:100%}.linkedin-card__body{display:flex;flex-direction:column;flex:1;gap:.125rem;min-width:0}.linkedin-card__label{font-family:var(--font-tech);letter-spacing:.12em;text-transform:uppercase;color:var(--color-outline);font-size:.6875rem}.linkedin-card__name{font-family:var(--font-serif);color:var(--color-text);font-size:1rem;line-height:1.2}.linkedin-card__cta{display:inline-flex;font-family:var(--font-mono);letter-spacing:.05em;color:var(--color-text-muted);align-items: center;gap:.25rem;transition:color .2s;font-size:.75rem}.linkedin-card:hover .linkedin-card__cta{color:var(--color-accent-ink)}.linkedin-card__cta .material-symbols-outlined{font-size:1rem}@media (max-width:540px){.linkedin-card:not(.linkedin-card--compact) .linkedin-card__cta{display:none}}.linkedin-card--compact{gap:.75rem;max-width:32rem;margin-bottom:2rem;padding:.625rem .875rem}.linkedin-card--compact .linkedin-card__icon{width:1.5rem;height:1.5rem}.linkedin-card--compact .linkedin-card__label{font-size:.625rem}.linkedin-card--compact .linkedin-card__name{font-size:.875rem}.linkedin-card--compact .linkedin-card__cta{font-size:.6875rem}.latest-post{border:1px solid var(--color-outline-variant);border-radius:var(--radius);background:var(--color-surface);padding:1.25rem 1.5rem}.latest-post__head{display:flex;justify-content:space-between;align-items: center;margin-bottom:.75rem}.latest-post__label{font-family:var(--font-tech);letter-spacing:.1em;text-transform:uppercase;color:var(--color-outline);font-size:.75rem}.latest-post__all{font-family:var(--font-mono);color:var(--color-text-muted);transition:color .2s;font-size:.75rem}.latest-post__all:hover{color:var(--color-accent-ink)}.latest-post__body{display:block;color:inherit}.latest-post__meta{display:flex;font-family:var(--font-mono);color:var(--color-outline);align-items: center;gap:.5rem;margin-bottom:.375rem;font-size:.75rem}.latest-post__title{font-family:var(--font-serif);color:var(--color-text);margin-bottom:.375rem;transition:color .2s;font-size:1.375rem;line-height:1.3}.latest-post__body:hover .latest-post__title{color:var(--color-accent-ink)}.latest-post__excerpt{color:var(--color-text-muted);margin-bottom:.75rem;font-size:.9375rem;line-height:1.55}.latest-post__cta{font-family:var(--font-mono);letter-spacing:.05em;color:var(--color-accent-ink);font-size:.75rem}.blog-list{display:flex;flex-direction:column;gap:2.5rem}.blog-card{border-bottom:1px solid var(--color-outline-variant);padding-bottom:2.5rem}.blog-list .blog-card:last-child{border-bottom:none;padding-bottom:0}.blog-card__meta{display:flex;font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--color-outline);align-items: center;gap:1rem;margin-bottom:.75rem;font-size:.75rem}.blog-card__title{font-family:var(--font-serif);margin-bottom:.5rem;font-size:1.75rem;line-height:1.25}.blog-card__title a{color:var(--color-text);transition:color .2s}.blog-card__title a:hover{color:var(--color-accent-ink)}.blog-card__excerpt{color:var(--color-text-muted);margin-bottom:1rem;line-height:1.6}.blog-card__tags{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;margin:0;padding:0}.blog-card__tag{font-family:var(--font-mono);color:var(--color-text-muted);background:var(--color-surface-alt);border:1px solid var(--color-outline-variant);border-radius:var(--radius);padding:.125rem .5rem;font-size:.75rem}.blog-post{max-width:42rem}.blog-post__back{display:inline-block;font-family:var(--font-mono);color:var(--color-text-muted);margin-bottom:2rem;transition:color .2s;font-size:.8125rem}.blog-post__back:hover{color:var(--color-accent-ink)}.blog-post__header{border-bottom:1px solid var(--color-outline-variant);margin-bottom:3rem;padding-bottom:2rem}.blog-post__meta{display:flex;font-family:var(--font-mono);color:var(--color-outline);align-items: center;gap:.75rem;margin-bottom:1rem;font-size:.8125rem}.blog-post__title{letter-spacing:-.02em;margin-bottom:1.25rem;font-size:2.5rem}.blog-post__tags{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;margin:0;padding:0}.blog-post__tag{font-family:var(--font-mono);color:var(--color-text-muted);background:var(--color-surface-alt);border:1px solid var(--color-outline-variant);border-radius:var(--radius);padding:.125rem .5rem;font-size:.75rem}.blog-post__nav{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--color-outline-variant);gap:1rem;margin-top:4rem;padding-top:2rem}.blog-post__nav-link{display:flex;border:1px solid var(--color-outline-variant);border-radius:var(--radius);flex-direction:column;gap:.25rem;padding:1rem;transition:border-color .2s,background .2s}.blog-post__nav-link:hover{border-color:var(--color-accent);background:var(--color-surface-alt)}.blog-post__nav-link--right{text-align:right}.blog-post__nav-label{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--color-outline);font-size:.6875rem}.blog-post__nav-title{font-family:var(--font-serif);color:var(--color-text);font-size:1rem}.prose{font-family:var(--font-serif);color:var(--color-text);font-size:1.125rem;line-height:1.75}.prose>*+*{margin-top:1.5rem}.prose h1,.prose h2,.prose h3,.prose h4{margin-top:2.5rem;margin-bottom:.75rem;line-height:1.3}.prose h1{font-size:2rem}.prose h2{font-size:1.625rem}.prose h3{font-size:1.25rem}.prose__link{color:var(--color-accent-ink);border-bottom:1px solid var(--color-outline-variant);transition:border-color .2s}.prose__link:hover{border-bottom-color:var(--color-accent)}.prose__code{font-family:var(--font-mono);background:var(--color-surface-variant);border-radius:var(--radius);padding:.125rem .375rem;font-size:.9em}.prose__list{color:var(--color-text);padding-left:1.5rem}.prose__list li+li{margin-top:.5rem}.prose__quote{border-left:2px solid var(--color-accent);color:var(--color-text-muted);margin:0;padding:.25rem 0 .25rem 1.25rem;font-style:italic}.prose__hr{border:none;border-top:1px solid var(--color-outline-variant);margin:3rem 0}.codeblock{border:1px solid var(--color-outline-variant);border-radius:var(--radius);overflow:hidden;background:var(--color-surface-alt);font-family:var(--font-mono);margin:1.5rem 0}.codeblock__head{display:flex;border-bottom:1px solid var(--color-outline-variant);background:var(--color-surface);justify-content:space-between;align-items: center;padding:.5rem .875rem}.codeblock__meta{display:flex;color:var(--color-text-muted);align-items: center;gap:.5rem;font-size:.75rem}.codeblock__title{font-family:var(--font-mono);color:var(--color-text);font-size:.75rem}.codeblock__lang{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--color-outline);font-size:.6875rem}.codeblock__copy{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);border:1px solid var(--color-outline-variant);border-radius:var(--radius);cursor:pointer;background:0 0;padding:.125rem .5rem;transition:color .2s,border-color .2s;font-size:.6875rem}.codeblock__copy:hover{color:var(--color-accent-ink);border-color:var(--color-accent)}.codeblock__body{overflow-x:auto;font-size:.875rem;line-height:1.6}.codeblock__body pre{margin:0;padding:1rem 1.125rem;background:0 0!important}.codeblock__body code{font-family:var(--font-mono)}.codeblock__body--fallback{color:var(--color-text);margin:0;padding:1rem 1.125rem}.codeblock__body .shiki,.codeblock__body .shiki span{color:var(--shiki-light)!important;background-color:var(--shiki-light-bg)!important;font-style:var(--shiki-light-font-style)!important;font-weight:var(--shiki-light-font-weight)!important;text-decoration:var(--shiki-light-text-decoration)!important}:root[data-theme=dark] .codeblock__body .shiki,:root[data-theme=dark] .codeblock__body .shiki span{color:var(--shiki-dark)!important;background-color:var(--shiki-dark-bg)!important;font-style:var(--shiki-dark-font-style)!important;font-weight:var(--shiki-dark-font-weight)!important;text-decoration:var(--shiki-dark-text-decoration)!important}.tooltip{position:relative;display:inline-block;outline:none}.tooltip__trigger{border-bottom:1px dashed var(--color-accent);cursor:help;color:var(--color-text);transition:color .2s}.tooltip:hover .tooltip__trigger{color:var(--color-accent-ink)}.tooltip:focus-visible .tooltip__trigger{color:var(--color-accent-ink)}.tooltip__popover{position:absolute;font-family:var(--font-sans);color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-outline-variant);border-radius:var(--radius);opacity:0;pointer-events:none;z-index:40;width:max-content;min-width:14rem;max-width:22rem;padding:.625rem .75rem;transition:opacity .15s,transform .15s;font-size:.8125rem;font-style:normal;line-height:1.5;bottom:calc(100% + .5rem);left:50%;transform:translate(-50%)translateY(4px);box-shadow:0 6px 20px #0000001f}.tooltip__popover:after{content:"";position:absolute;border:5px solid #0000;border-top-color:var(--color-outline-variant);top:100%;left:50%;transform:translate(-50%)}.tooltip:hover .tooltip__popover{opacity:1;pointer-events:auto;transform:translate(-50%)translateY(0)}.tooltip:focus-visible .tooltip__popover{opacity:1;pointer-events:auto;transform:translate(-50%)translateY(0)}@media (max-width:540px){.tooltip__popover{min-width:11rem;max-width:80vw}}.theme-toggle-wrap{position:fixed;display:flex;z-index:50;align-items: center;gap:.6rem;bottom:1.25rem;right:1.25rem}.theme-toggle{display:inline-flex;border:1px solid var(--color-outline-variant);background:var(--color-surface);color:var(--color-text);cursor:pointer;border-radius:9999px;justify-content:center;align-items: center;width:2.5rem;height:2.5rem;transition:background .15s,border-color .15s,transform .4s cubic-bezier(.22,.61,.36,1);box-shadow:0 2px 8px #00000014}.theme-toggle--expanded{transform:scale(1.35)}.theme-toggle:hover{border-color:var(--color-accent);color:var(--color-accent)}.theme-toggle:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.theme-toggle .material-symbols-outlined{font-size:1.25rem}.theme-toggle-hint{display:inline-flex;font-family:var(--font-serif);color:var(--color-text);white-space:nowrap;pointer-events:none;opacity:0;align-items: center;gap:.35rem;transition:opacity .4s;font-size:.9rem;font-style:italic;transform:translate(-.5rem,-.6rem)}.theme-toggle-hint.is-visible{opacity:1}.theme-toggle-hint__arrow{color:var(--color-text);display:block;flex-shrink:0}
