:root{--bg: #0c0b09;--bg-elevated: #141210;--bg-sidebar: #100f0d;--text: #efeae3;--text-muted: #9a9288;--accent: #d4a574;--accent-soft: rgba(212, 165, 116, .14);--border: rgba(239, 234, 227, .12);--radius: 14px;--side-width: 15.5rem;--side-collapsed: 4.25rem;--font-sans: "DM Sans", system-ui, sans-serif;--font-serif: "Instrument Serif", Georgia, serif}:root[data-theme=light]{--bg: #f6f2ed;--bg-elevated: #fffcf8;--bg-sidebar: #f1ece6;--text: #1b1712;--text-muted: #61584e;--accent: #8d5f2e;--accent-soft: rgba(141, 95, 46, .13);--border: rgba(28, 22, 14, .14)}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-height:100vh;font-family:var(--font-sans);font-optical-sizing:auto;background-color:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}#root{min-height:100vh}a{color:var(--accent);text-decoration:none;text-underline-offset:3px}a:hover{text-decoration:underline}.page{position:relative;overflow-x:hidden}.page:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(ellipse 120% 80% at 10% -20%,rgba(212,165,116,.09),transparent 50%),radial-gradient(ellipse 80% 60% at 95% 10%,rgba(120,140,180,.06),transparent 45%),repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(255,255,255,.012) 2px,rgba(255,255,255,.012) 4px);z-index:0}.main-panel{position:relative;z-index:1;min-height:100vh;margin-left:var(--side-collapsed);transition:margin-left .22s ease}@media (min-width: 841px) and (hover: hover){.page:has(.side-nav:hover) .main-panel{margin-left:var(--side-width)}}.wrap{position:relative;z-index:1;width:min(1120px,calc(100vw - var(--side-collapsed) - 6vw));margin:0 auto;padding:2.5rem 0 4rem;transition:width .22s ease}@media (min-width: 841px) and (hover: hover){.page:has(.side-nav:hover) .wrap{width:min(1120px,calc(100vw - var(--side-width) - 6vw))}}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.side-nav{position:fixed;top:0;left:0;z-index:40;display:flex;flex-direction:column;gap:2rem;width:var(--side-collapsed);height:100vh;padding:2rem .65rem 2rem .7rem;background:var(--bg-sidebar);border-right:1px solid var(--border);overflow-x:hidden;overflow-y:auto;transition:width .22s ease}@media (min-width: 841px) and (hover: hover){.side-nav:hover{width:var(--side-width);padding-left:.7rem;padding-right:1.15rem}}.side-nav__brand{display:flex;align-items:center;gap:.55rem;min-height:1.75rem;padding:.5rem .55rem;border-radius:10px;font-family:var(--font-serif);font-size:1.2rem;font-weight:400;letter-spacing:.02em;color:var(--text);line-height:1.2;text-decoration:none}.side-nav__brand:hover{color:var(--accent);background:#ffffff0d;text-decoration:none}.side-nav__brand-icon{display:flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;flex-shrink:0;color:var(--text-muted)}.side-nav__brand-icon img{width:100%;height:100%;display:block;object-fit:contain}.side-nav__brand-text{flex:1;min-width:0;white-space:nowrap;transition:opacity .15s ease,width .22s ease,margin .22s ease}@media (min-width: 841px) and (hover: hover){.side-nav:not(:hover) .side-nav__brand{justify-content:flex-start}.side-nav:not(:hover) .side-nav__brand-text{opacity:0;width:0;overflow:hidden;margin:0;pointer-events:none}}.side-nav__links ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.2rem}.side-nav__links{flex:1}.side-nav__link{display:flex;align-items:center;gap:.65rem;padding:.5rem .55rem;border-radius:10px;color:var(--text-muted);font-size:.9rem;font-weight:500;transition:background .12s ease,color .12s ease;text-decoration:none}.side-nav__link:hover{background:#ffffff0d;color:var(--text);text-decoration:none}.side-nav__link--active{background:var(--accent-soft);color:var(--accent)}.side-nav__link--active:hover{background:#d4a57438;color:var(--accent)}:root[data-theme=light] .side-nav__link:hover,:root[data-theme=light] .home-top-bar__link:hover,:root[data-theme=light] .nav-toggle:hover,:root[data-theme=light] .btn-ghost:hover,:root[data-theme=light] .pill{background:#0000000d}.side-nav__icon{display:flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;flex-shrink:0;opacity:.9}.side-nav__label{flex:1;min-width:0;transition:opacity .15s ease,width .22s ease,margin .22s ease;white-space:nowrap;overflow:hidden}.side-nav__bottom{margin-top:auto}.side-nav__theme-toggle{width:100%;display:flex;align-items:center;gap:.65rem;height:3rem;padding:.5rem .55rem;border:1px solid var(--border);border-radius:10px;background:transparent;color:var(--text-muted);font:inherit;font-size:.9rem;font-weight:500;text-align:left;cursor:pointer;overflow:hidden;transition:background .12s ease,color .12s ease}.side-nav__theme-toggle .side-nav__label{white-space:nowrap}.side-nav__theme-toggle:hover{background:#ffffff0d;color:var(--text)}:root[data-theme=light] .side-nav__theme-toggle:hover{background:#0000000d}@media (min-width: 841px) and (hover: hover){.side-nav:not(:hover) .side-nav__link{justify-content:flex-start;gap:0}.side-nav:not(:hover) .side-nav__label{opacity:0;width:0;overflow:hidden;margin:0;pointer-events:none;flex:0}.side-nav:not(:hover) .side-nav__theme-toggle{justify-content:flex-start;gap:0}}.nav-toggle{display:none;position:fixed;top:1rem;left:1rem;z-index:1000;width:2.75rem;height:2.75rem;padding:0;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:12px;background:color-mix(in srgb,var(--bg-elevated) 50%,transparent);backdrop-filter:blur(1px);-webkit-backdrop-filter:blur(1px);color:var(--text);cursor:pointer}.nav-toggle__bars{position:relative;width:1.1rem;height:2px;background:currentColor;border-radius:1px;transition:background-color .18s ease}.nav-toggle__bars:before,.nav-toggle__bars:after{content:"";position:absolute;left:0;width:100%;height:2px;background:currentColor;border-radius:1px}.nav-toggle__bars:before{top:-6px}.nav-toggle__bars:after{top:6px}.nav-toggle--open .nav-toggle__bars{background:transparent}.nav-toggle__bars:before,.nav-toggle__bars:after{transition:transform .18s ease,top .18s ease}.nav-toggle--open .nav-toggle__bars:before{top:0;transform:rotate(45deg)}.nav-toggle--open .nav-toggle__bars:after{top:0;transform:rotate(-45deg)}.nav-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;background:#00000073;opacity:0;pointer-events:none;transition:opacity .2s ease}.nav-backdrop--visible{opacity:1;pointer-events:auto}.home-top-bar{position:sticky;top:0;z-index:15;display:flex;justify-content:center;align-items:center;padding:.85rem max(1.25rem,4vw) .75rem;background:color-mix(in srgb,var(--bg) 88%,transparent);border-bottom:1px solid var(--border);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.home-top-bar__nav{width:100%}.home-top-bar__nav ul{list-style:none;margin:0;padding:0;display:flex;align-items:center;justify-content:center;gap:.35rem}.home-top-bar__link{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:10px;color:var(--text-muted);cursor:pointer;transition:background .12s ease,color .12s ease}.home-top-bar__link:hover{background:#ffffff0f;color:var(--text);text-decoration:none}@media (min-width: 841px) and (hover: hover){.home-top-bar{padding-left:max(1.25rem,calc(4vw - .5rem));padding-right:max(1.25rem,calc(4vw - .5rem))}}.section--page-start{padding-top:.5rem}.hero{padding:4rem 0 3.5rem}@media (max-width: 840px),(hover: none),(pointer: coarse){.main-panel{margin-left:0;padding-top:0}.wrap{width:min(1120px,92vw);padding-top:1.25rem}.nav-toggle{display:inline-flex;top:max(1rem,env(safe-area-inset-top,0px));left:max(1rem,env(safe-area-inset-left,0px));transition:left .2s ease,top .2s ease}.nav-toggle--open{left:calc(min(var(--side-width),88vw) - 3.25rem)}.nav-backdrop{display:block}.side-nav{width:min(var(--side-width),88vw);padding:4.75rem 1.15rem calc(2.75rem + env(safe-area-inset-bottom,0px)) 1.25rem;transform:translate(-100%);transition:transform .22s ease;box-shadow:12px 0 40px #00000059}.side-nav--open{transform:translate(0)}.side-nav:not(:hover) .side-nav__brand-text,.side-nav:not(:hover) .side-nav__label{opacity:1;width:auto;overflow:visible;margin:0;pointer-events:auto;flex:1}.side-nav:not(:hover) .side-nav__link{justify-content:flex-start;gap:.65rem}.side-nav:not(:hover) .side-nav__brand{justify-content:flex-start}.home-top-bar{margin-top:0;padding-top:.35rem;padding-left:max(1.25rem,4vw)}.hero{padding-top:2.25rem;padding-left:.25rem}}.hero h1{font-family:var(--font-serif);font-size:clamp(2.6rem,6vw,4rem);font-weight:400;line-height:1.08;margin:0 0 1rem;letter-spacing:-.02em}.hero-lede{font-size:1.15rem;color:var(--text-muted);max-width:36ch;margin:0 0 1.5rem}.hero-actions{display:flex;flex-wrap:wrap;gap:.75rem}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1rem;border-radius:999px;font-size:.875rem;font-weight:600;border:1px solid var(--border);background:transparent;color:var(--text);cursor:pointer;font-family:inherit;transition:background .15s ease,border-color .15s ease}.btn-primary{background:var(--accent-soft);border-color:#d4a57459;color:var(--accent)}.btn-primary:hover{background:#d4a57438;text-decoration:none}.btn-ghost:hover{background:#ffffff0a;text-decoration:none}.section{padding:3rem 0}.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.section-head--spaced{margin-top:1.25rem}.section-head h2{font-family:var(--font-serif);font-size:clamp(1.75rem,3vw,2.25rem);font-weight:400;margin:0}.section-meta{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.project-card{position:relative;display:flex;flex-direction:column;padding:1.35rem;border-radius:var(--radius);background:var(--bg-elevated);border:1px solid var(--border);transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.project-card__stretch{position:static}.project-card__stretch:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.project-footer a{position:relative;z-index:1}.project-card a:hover,a.project-card.project-card--link:hover{text-decoration:none}.project-card:hover{transform:translateY(-3px);border-color:#d4a57459;box-shadow:0 18px 40px #00000059}.project-card h3{margin:0 0 .35rem;font-size:1.05rem;font-weight:600}.project-card h3 a{color:var(--text)}.project-card h3 a:hover{color:var(--accent)}a.project-card.project-card--link{text-decoration:none;color:inherit}a.project-card.project-card--link:focus-visible{outline:2px solid var(--accent);outline-offset:2px}a.project-card.project-card--link h3{color:var(--text);transition:color .12s ease}a.project-card.project-card--link:hover h3{color:var(--accent)}.project-desc{flex:1;margin:0;font-size:.9rem;color:var(--text-muted);line-height:1.55}.project-footer{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border);font-size:.78rem;color:var(--text-muted)}.pill{display:inline-block;padding:.15rem .55rem;border-radius:999px;background:#ffffff0f;color:var(--text);font-size:.72rem}.error-box,.loading{padding:1.25rem;border-radius:var(--radius);border:1px dashed var(--border);color:var(--text-muted);font-size:.9rem}.error-box{border-color:#c8645073;color:#e8b4a8}.resume-layout{display:grid;gap:2rem}@media (min-width: 768px){.resume-layout{grid-template-columns:1fr 1fr;align-items:start}}.resume-block{padding:1.5rem;border-radius:var(--radius);background:var(--bg-elevated);border:1px solid var(--border)}.resume-block h3{font-family:var(--font-serif);font-size:1.35rem;font-weight:400;margin:0 0 1rem}.bio-links{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.bio-link{display:inline-flex;align-items:center;gap:.5rem;padding:.45rem .75rem;border-radius:999px;border:1px solid var(--border);background:#ffffff08;color:var(--text-muted);text-decoration:none;font-size:.88rem;font-weight:600;transition:background .12s ease,color .12s ease,border-color .12s ease}.bio-link:hover{background:#d4a5742e;border-color:#d4a57459;color:var(--text);text-decoration:none}.bio-link__icon{display:flex;align-items:center;justify-content:center;color:var(--accent);opacity:.95}.timeline{display:flex;flex-direction:column;gap:1.35rem}.timeline-item strong{display:block;font-weight:600;color:var(--text)}.timeline-item .company{color:var(--accent);font-size:.95rem}.timeline-item .period{font-size:.8rem;color:var(--text-muted);margin:.2rem 0 .35rem}.timeline-item p{margin:0;font-size:.9rem;color:var(--text-muted)}.timeline-item ul{margin:.5rem 0 0;padding-left:1.1rem;font-size:.88rem;color:var(--text-muted)}.skill-tags{display:flex;flex-wrap:wrap;gap:.45rem}.skill-tags span{padding:.35rem .65rem;border-radius:8px;background:var(--accent-soft);color:var(--accent);font-size:.8rem;font-weight:500}.pdf-frame{width:100%;min-height:480px;border:none;border-radius:var(--radius);background:#1a1816}.site-footer{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border);font-size:.85rem;color:var(--text-muted)}.friend-favicon{width:14px;height:14px;margin-left:.45rem;vertical-align:-2px;display:inline-block;border-radius:4px}.article-page{padding-bottom:2rem}.article-wrap{padding-top:.75rem}.article-page-root{position:relative}.article-hero{position:relative;height:270px;display:flex;justify-content:center;align-items:flex-start;z-index:1}.article-hero__bg{position:fixed;top:0;left:0;width:100%;height:270px;background-size:cover;background-position:center;z-index:0;pointer-events:none}.article-hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;background:transparent;pointer-events:none;opacity:0}.article-hero__inner{position:relative;z-index:2;width:100%;display:flex;flex-direction:column;align-items:center;padding-top:3.05rem}.article-hero__titleBox{background:#0009;border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:.75rem 1.35rem}.article-hero__title{margin:0;font-family:var(--font-serif);font-weight:400;font-size:clamp(2rem,4vw,3rem);color:#fff;letter-spacing:-.01em;text-shadow:0 10px 28px rgba(0,0,0,.55)}.article-hero__meta{margin-top:.55rem;font-size:.8rem;color:#ffffffd9;text-transform:uppercase;letter-spacing:.12em;text-align:center}:root[data-theme=light] .article-hero__titleBox{background:#ffffffb8;border-color:#0000001f}:root[data-theme=light] .article-hero__title{color:var(--text);text-shadow:none}:root[data-theme=light] .article-hero__meta{color:var(--text-muted)}:root[data-theme=light] .article-hero:after{background:transparent}.article-body{position:relative;z-index:1;margin-top:-72px;padding-top:3.75rem;padding-left:clamp(1rem,2.4vw,1.65rem);padding-right:clamp(1rem,2.4vw,1.65rem);padding-bottom:2rem;background:transparent}.article-header{margin-bottom:1.25rem}.article-title{font-family:var(--font-serif);font-size:clamp(2.1rem,4vw,2.75rem);font-weight:400;margin:0;letter-spacing:-.01em}.article-meta{margin-top:.65rem;font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em}.article-toc{margin:0 0 1.6rem;padding:0;border-radius:0;background:transparent;border:none}.article-toc__label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;margin-bottom:.5rem}.article-toc__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}.article-toc a:hover{text-decoration:underline}.article-content h2,.article-content h3{font-family:var(--font-serif);font-weight:400;margin:2rem 0 .9rem}.article-content{background:color-mix(in srgb,var(--bg-elevated) 95%,transparent);border:1px solid var(--border);border-radius:12px;padding:1.6rem 1.5rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.article-content section:first-of-type h2{margin-top:0}.article-content h2{font-size:1.7rem}.article-content h3{font-size:1.2rem;margin-top:1.6rem}.article-content p{margin:.9rem 0 0;color:var(--text-muted)}.article-inline-paragraph{margin:.35rem 0 0}.article-subsection p{margin-top:.35rem}.article-content ul{margin:.65rem 0 0;padding-left:1.2rem;color:var(--text-muted)}.article-content ul ul{margin:.35rem 0 0;padding-left:1.1rem}.article-content li{margin:.35rem 0;overflow-wrap:anywhere;word-break:break-word}.article-content a{overflow-wrap:anywhere;word-break:break-word}.article-link-group{margin-top:1.25rem}.article-link-group h3{margin-bottom:.6rem}.article-link-group ul{padding-left:1.15rem}.article-image{margin:1.6rem 0 1.2rem}.article-image img{width:100%;max-width:820px;height:auto;display:block;margin:0 auto;border-radius:var(--radius);border:1px solid var(--border)}.article-list-subheading{margin:1.25rem 0 1rem}.article-list-subheading h3{font-family:var(--font-serif);font-weight:400;font-size:clamp(1.45rem,2.5vw,1.85rem);margin:0;color:var(--text)}.article-collapsible-list{list-style:none;margin:.65rem 0 0;padding:0;display:flex;flex-direction:column;gap:.4rem}.article-collapsible-list>li{margin:0}.article-collapsible{border-radius:var(--radius);background:var(--bg-elevated);border:1px solid var(--border)}.article-collapsible[open]{border-color:#d4a57459}.article-collapsible summary{cursor:pointer;list-style:none;padding:.85rem 1rem;display:flex;align-items:center;gap:.75rem;color:var(--text);font-weight:600}.article-collapsible summary::-webkit-details-marker{display:none}.article-collapsible summary:before{content:"▾";color:var(--accent);transition:transform .18s ease}.article-collapsible[open] summary:before{transform:rotate(180deg)}.article-collapsible__body{padding:0 1rem .95rem}.article-collapsible__body p{margin:.55rem 0 0;color:var(--text-muted)}.steam-generated{margin:0 0 1.5rem;font-size:.82rem;color:var(--text-muted)}.steam-section{margin-bottom:2rem}.steam-section--after-featured{margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--border)}.steam-section__title{font-family:var(--font-serif);font-size:1.35rem;font-weight:400;margin:0 0 .35rem;color:var(--text)}.steam-section__lead{margin:0 0 1.25rem;max-width:40rem;font-size:.88rem;color:var(--text-muted);line-height:1.5}.steam-code{font-size:.85em;padding:.12rem .35rem;border-radius:6px;background:var(--bg-sidebar);border:1px solid var(--border);color:var(--text)}.steam-game-stack{display:grid;grid-template-columns:1fr;gap:2rem}.steam-game__last-played{margin:0;font-size:.82rem;color:var(--text-muted)}.steam-game__title-block{display:flex;flex-direction:column;gap:.15rem;flex:1 1 auto;min-width:0}@media (min-width: 900px) and (hover: hover) and (pointer: fine){.steam-game-stack{grid-template-columns:repeat(2,minmax(0,1fr));column-gap:1.5rem}}.steam-game{display:flex;flex-direction:column;min-height:0;padding:1.35rem 1.5rem;border-radius:var(--radius);background:var(--bg-elevated);border:1px solid var(--border)}.steam-game--featured{border-left:3px solid var(--accent)}.steam-game__head{display:flex;flex-wrap:nowrap;align-items:flex-start;gap:1rem 1.25rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.steam-game__capsule{width:231px;max-width:100%;height:auto;border-radius:6px;flex:0 0 231px}@media (max-width: 680px){.steam-game__head{flex-wrap:wrap;align-items:center}.steam-game__capsule{width:min(231px,100%);flex:0 1 auto}}.steam-game__title{font-family:var(--font-serif);font-size:1.35rem;font-weight:400;margin:0 0 .35rem;min-width:0}.steam-game__title a{color:var(--text);text-decoration:none;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden;white-space:normal;overflow-wrap:anywhere}.steam-game__title a:hover{color:var(--accent);text-decoration:underline}.steam-game__playtime{margin:0;font-size:.88rem;color:var(--text-muted)}.steam-game__ach-meta{margin:0;font-size:.85rem;color:var(--accent);font-weight:600}.steam-game__ach-summary{display:flex;align-items:center;gap:.75rem;margin:0 0 .65rem}.steam-ach-progress{flex:1;height:8px;border-radius:999px;background:#ffffff0d;border:1px solid var(--border);overflow:hidden}.steam-ach-progress__fill{height:100%;background:var(--accent-soft);box-shadow:0 0 0 1px #d4a57440 inset}.steam-ach-progress--complete .steam-ach-progress__fill{background:var(--accent);box-shadow:0 0 0 1px #ffffff14 inset}.steam-game__ach-note{margin:0;font-size:.88rem;color:var(--text-muted);line-height:1.5}.steam-library-head{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:1rem;width:100%}.steam-library-head__reveal:disabled{opacity:.65;cursor:default}.steam-game__ach-area{display:flex;flex-direction:column;flex:1 1 auto;min-height:0;overflow:hidden}.steam-ach-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem;flex:1 1 auto;min-height:0;height:100%;max-height:none;overflow-y:auto;padding-right:.25rem}@media (max-width: 899px),(hover: none) and (pointer: coarse){.steam-game{padding:1.1rem 1rem}.steam-game__head{flex-wrap:wrap;align-items:center;justify-content:center}.steam-game__title-block{width:100%;align-items:center;text-align:center}.steam-game__capsule{width:min(210px,100%)}.steam-ach-list{height:auto;max-height:250px}}@media ((max-width: 899px) and (orientation: landscape)),((hover: none) and (pointer: coarse) and (orientation: landscape)){.steam-game-stack{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}}@media (min-width: 900px) and (hover: hover) and (pointer: fine){.steam-game{height:560px}}.steam-ach{display:flex;align-items:stretch;padding:.45rem .5rem;border-radius:10px;background:#ffffff08;border:1px solid transparent}.steam-ach__inner{display:flex;align-items:center;gap:.65rem;min-width:0;flex:1 1 auto}.steam-ach__inner--blur{filter:blur(8px);-webkit-user-select:none;user-select:none}.steam-ach--spoiler{cursor:pointer;border-color:#d4a57438}.steam-ach--spoiler:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.steam-ach--locked{opacity:.55}.steam-ach__icon{border-radius:4px;flex-shrink:0}.steam-ach__icon-fallback{display:block;width:32px;height:32px;border-radius:4px;background:var(--border);flex-shrink:0}.steam-ach__text{display:flex;flex-direction:column;gap:.1rem;min-width:0}.steam-ach__name{font-size:.88rem;font-weight:600;color:var(--text)}.steam-ach__desc{font-size:.78rem;color:var(--text-muted);line-height:1.45}.portfolio-intro{margin:0 0 2rem;max-width:40rem;font-size:.95rem;color:var(--text-muted);line-height:1.55}.portfolio-empty{margin:0;padding:1.25rem 1.35rem;border-radius:var(--radius);border:1px dashed var(--border);color:var(--text-muted);font-size:.9rem;line-height:1.5}.portfolio-code{font-size:.85em;padding:.12rem .35rem;border-radius:6px;background:var(--bg-sidebar);border:1px solid var(--border);color:var(--text)}.portfolio-toc{margin:0;padding:1rem 1.15rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-elevated)}.portfolio-toc__title{margin:0 0 .7rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.portfolio-toc__list{margin:0;padding-left:1.1rem;display:grid;gap:.35rem}.portfolio-toc__link{color:var(--text);text-decoration:none}.portfolio-toc__link:hover,.portfolio-toc__link:focus-visible{color:var(--brand);text-decoration:underline}.portfolio-series-stack{display:flex;flex-direction:column;gap:2.75rem}.portfolio-series__head{margin-bottom:1.15rem}.portfolio-series__title{font-family:var(--font-serif);font-size:clamp(1.35rem,2.4vw,1.65rem);font-weight:400;margin:0 0 .35rem;color:var(--text)}.portfolio-series__desc{margin:0;max-width:42rem;font-size:.9rem;color:var(--text-muted);line-height:1.5}.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,260px),1fr));gap:1.05rem;align-items:start}.portfolio-media{margin:0;display:flex;flex-direction:column;gap:.5rem}.portfolio-media--clickable{cursor:pointer}.portfolio-media--clickable:focus-visible{outline:2px solid rgba(212,165,116,.85);outline-offset:3px;border-radius:calc(var(--radius) + 1px)}.portfolio-media__frame{border-radius:var(--radius);background:var(--bg-elevated);border:1px solid var(--border);overflow:hidden;line-height:0;transition:border-color .18s ease,box-shadow .18s ease}.portfolio-media__frame:hover{border-color:#d4a5744d;box-shadow:0 12px 32px #00000047}.portfolio-media__asset{width:100%;height:auto;display:block;vertical-align:middle}.portfolio-media__asset--image{object-fit:contain;max-height:min(75vh,720px)}.portfolio-media__asset--video{aspect-ratio:16 / 9;object-fit:contain;background:#1a1816;max-height:min(75vh,720px)}.portfolio-media__asset--embed{aspect-ratio:16 / 9;min-height:180px;border:0}.portfolio-modal__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#000000a6;display:flex;align-items:center;justify-content:center;padding:1.25rem}.portfolio-modal{width:min(1100px,100%);max-height:min(92vh,920px);overflow:hidden;border-radius:var(--radius);background:var(--bg-elevated);border:1px solid var(--border);box-shadow:0 40px 120px #00000080;display:flex;flex-direction:column}.portfolio-modal__toolbar{padding:.75rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.9rem;flex-wrap:wrap;justify-content:flex-end}.portfolio-modal__meta{display:flex;align-items:center;gap:.7rem;min-width:0;margin-right:auto;color:var(--text-muted);font-size:.88rem}.portfolio-modal__close{font-family:inherit;font-weight:600;color:var(--text);background:transparent;border:1px solid var(--border);border-radius:10px;padding:.45rem .75rem;cursor:pointer}.portfolio-modal__close:hover,.portfolio-modal__close:focus-visible{border-color:#d4a5748c;box-shadow:0 10px 30px #00000040;outline:none}.portfolio-modal__zoom-controls{display:inline-flex;border:1px solid var(--border);border-radius:10px;overflow:hidden}.portfolio-modal__zoom-btn{font-family:inherit;color:var(--text);background:transparent;border:0;border-right:1px solid var(--border);min-width:2.2rem;padding:.45rem .55rem;cursor:pointer}.portfolio-modal__zoom-btn:last-child{border-right:0}.portfolio-modal__zoom-btn:hover,.portfolio-modal__zoom-btn:focus-visible{background:#d4a5741f;outline:none}.portfolio-modal__body{padding:1rem;overflow:auto}.portfolio-modal__media{display:flex;justify-content:center}.portfolio-modal__zoom-surface{width:100%;max-height:min(78vh,820px);overflow:auto;display:flex;justify-content:flex-start;align-items:flex-start}.portfolio-modal__asset{width:100%;height:auto;display:block}.portfolio-modal__asset--image{object-fit:contain;max-height:min(78vh,820px);transform-origin:top left}.portfolio-modal__asset--video{aspect-ratio:16 / 9;object-fit:contain;background:#1a1816;max-height:min(78vh,820px)}.portfolio-modal__asset--embed{width:100%;height:min(70vh,640px);border:0;background:#1a1816}.portfolio-modal__date{font-size:.74rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--accent)}.portfolio-modal__title{font-size:.9rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:24rem}.portfolio-modal__text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:34rem}@media (max-width: 720px){.portfolio-modal__toolbar{justify-content:center}.portfolio-modal__meta{flex-basis:100%;margin-right:0;justify-content:center;text-align:center}.portfolio-modal__title,.portfolio-modal__text{max-width:100%}.portfolio-modal__zoom-controls{margin-right:0}}.portfolio-media__caption{display:flex;flex-direction:column;gap:.2rem;padding:0 .15rem;font-size:.82rem;color:var(--text-muted)}.portfolio-media__title{font-weight:600;color:var(--text)}.portfolio-media__date{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--accent)}.portfolio-media__text{line-height:1.45}.portfolio-hub-lede{margin:-.35rem 0 1.35rem;max-width:36rem;font-size:.95rem;color:var(--text-muted);line-height:1.55}.place-panel{margin-top:.5rem;padding:1rem 1.1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-elevated)}.place-toolbar{display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-start;justify-content:space-between;margin-bottom:1rem}.place-stats{display:flex;flex-wrap:wrap;gap:.65rem 1.1rem;font-size:.88rem;color:var(--text-muted)}.place-stat strong{color:var(--text);font-weight:600}.place-colors{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}.place-zoom{display:inline-flex;align-items:center;gap:.45rem;font-size:.82rem;color:var(--text-muted)}.place-zoom button{width:1.7rem;height:1.7rem;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--text);cursor:pointer}.place-zoom input[type=range]{width:8rem}.place-swatch{width:1.75rem;height:1.75rem;border-radius:6px;border:2px solid var(--border);cursor:pointer;padding:0}.place-swatch--active{outline:2px solid var(--accent);outline-offset:2px}.place-swatch--black{border-color:#505050ad}.place-color-custom{display:inline-flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--text-muted);margin-left:.25rem}.place-color-custom input[type=color]{width:2rem;height:1.75rem;padding:0;border:1px solid var(--border);border-radius:6px;cursor:pointer;background:transparent}.place-error{margin:0;padding:.5rem .65rem;border-radius:8px;background:#e945601f;color:var(--text);font-size:.9rem}.place-error-slot{min-height:2.45rem;margin-bottom:.55rem;display:flex;align-items:flex-start}@media (max-width: 700px){.place-error-slot{min-height:3.9rem}}.place-canvas-wrap{overflow:auto;max-width:100%;max-height:min(72vh,780px);border-radius:10px;border:1px solid var(--border);background:color-mix(in srgb,var(--bg-sidebar) 92%,#1a1a1a);padding:.65rem;display:flex;justify-content:center;align-items:flex-start}.place-canvas{display:block;cursor:crosshair;touch-action:none}.place-loading{margin:1rem;color:var(--text-muted)}.place-hint{margin:.85rem 0 0;font-size:.82rem}.portfolio-hub-grid{margin-top:.25rem}
