:root{--bg:#3f3f37;--bg-elev:#494331;--bg-elev-2:#524b39;--surface:#494331;--surface-2:#524b39;--surface-hov:#5a5340;--border:#555045;--border-2:#6f6a59;--rule:#d6d6b121;--text:#d6d6b1;--text-strong:#ebe9c5;--text-muted:#878472;--text-faint:#6a6757;--accent:#de541e;--accent-soft:#b8431a;--accent-bg:#de541e1f;--accent-line:#de541e6b;--accent-ink:#1a0e07;--rust:#de541e;--olive:#878472;--status-active:#a3a570;--status-prog:#de541e;--status-proto:#c79a72;--status-done:#878472;--radius-sm:4px;--radius:8px;--radius-lg:12px;--shadow-sm:0 1px 0 #0000004d;--shadow:0 12px 28px -16px #0009, 0 4px 10px -6px #0006;--shadow-lg:0 30px 60px -20px #000000b3, 0 12px 24px -10px #00000073;--ease:cubic-bezier(.2, .7, .2, 1);--t-fast:.15s var(--ease);--t-med:.24s var(--ease);--t-slow:.42s var(--ease);--sans:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Inter, system-ui, sans-serif;--mono:"JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;--serif:"Iowan Old Style", "Palatino Linotype", Georgia, serif;--max-w:1180px;--gutter:28px;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}@media (prefers-color-scheme:light){:root{--bg:#d6d6b1;--bg-elev:#e0e0bd;--bg-elev-2:#cccca0;--surface:#e0e0bd;--surface-2:#d0d0a8;--surface-hov:#c8c89e;--border:#b9b78f;--border-2:#878472;--rule:#3f3f3729;--text:#3f3f37;--text-strong:#1f1d18;--text-muted:#5d5b4f;--text-faint:#878472;--accent:#de541e;--accent-soft:#b8431a;--accent-bg:#de541e1f;--accent-line:#de541e80;--accent-ink:#fdf6e3;--rust:#de541e;--olive:#878472;--status-active:#6e7842;--status-prog:#de541e;--status-proto:#a86a3a;--status-done:#878472;--shadow-sm:0 1px 0 #3f3f371f;--shadow:0 8px 24px -12px #3f3f3740, 0 2px 6px -3px #3f3f3726;--shadow-lg:0 24px 48px -16px #3f3f374d, 0 8px 16px -8px #3f3f3733;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}}*,:before,:after{box-sizing:border-box}html,body{background:var(--bg);color:var(--text);font-family:var(--sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;margin:0;padding:0;font-size:16px;line-height:1.55}html{scroll-behavior:smooth;scroll-padding-top:88px}body{min-height:100svh}#root{text-align:left;border:0;width:100%;max-width:none;min-height:100svh;margin:0;display:block}h1,h2,h3,h4{font-family:var(--sans);color:var(--text-strong);letter-spacing:-.01em;margin:0;font-weight:500}p{margin:0}ul{margin:0;padding:0;list-style:none}button{font-family:inherit}a{color:var(--accent);transition:color var(--t-fast);text-decoration:none}a:not(.btn):hover{color:var(--accent-soft)}::selection{background:var(--accent-bg);color:var(--text-strong)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--radius-sm)}code,.mono{font-family:var(--mono)}.app{z-index:1;flex-direction:column;min-height:100svh;display:flex;position:relative}main{flex:1}.section{padding:96px 0;position:relative}.section--featured{padding-top:64px}.section__inner{max-width:var(--max-w);padding:0 var(--gutter);margin:0 auto}.section__head-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:36px;display:flex}.nav{z-index:50;background:color-mix(in srgb, var(--bg) 85%, transparent);-webkit-backdrop-filter:blur(10px);transition:background var(--t-med), border-color var(--t-med);border-bottom:1px solid #0000;position:sticky;top:0}.nav--scrolled{background:color-mix(in srgb, var(--bg) 94%, transparent);border-bottom-color:var(--border)}.nav__inner{max-width:var(--max-w);padding:14px var(--gutter);justify-content:space-between;align-items:center;gap:16px;margin:0 auto;display:flex}.nav__brand{cursor:pointer;border-radius:var(--radius-sm);color:var(--text-strong);letter-spacing:-.01em;transition:color var(--t-fast);background:0 0;border:0;align-items:center;gap:10px;padding:4px 6px;font-weight:500;display:inline-flex}.nav__brand:hover{color:var(--accent)}.nav__brand-mark{font-family:var(--mono);color:var(--accent);letter-spacing:.02em;font-size:13px}.nav__brand-text{font-size:15px}.nav__list{align-items:center;gap:2px;display:flex}.nav__link{cursor:pointer;border-radius:var(--radius);color:var(--text-muted);letter-spacing:.01em;transition:color var(--t-fast), background var(--t-fast);background:0 0;border:0;align-items:baseline;gap:6px;padding:8px 12px;font-size:14px;font-weight:500;display:inline-flex;position:relative}.nav__link-num{font-family:var(--mono);color:var(--text-faint);transition:color var(--t-fast);font-size:11px}.nav__link:hover{color:var(--text-strong);background:var(--surface-hov)}.nav__link:hover .nav__link-num{color:var(--accent)}.nav__link--active{color:var(--text-strong);background:var(--accent-bg)}.nav__link--active .nav__link-num{color:var(--accent)}.nav__link--active:after{content:"";background:var(--accent);transform-origin:0;height:1px;animation:underline .22s var(--ease) both;position:absolute;bottom:4px;left:12px;right:12px}@keyframes underline{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.nav__menu-toggle{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-strong);background:0 0;padding:8px;display:none}.hamburger{width:18px;height:12px;transition:background-position var(--t-fast);background-image:linear-gradient(currentColor,currentColor),linear-gradient(currentColor,currentColor),linear-gradient(currentColor,currentColor);background-position:top,50%,bottom;background-repeat:no-repeat;background-size:100% 2px;display:block}.hamburger--open{background-position:50%,50%,50%}.footer{border-top:1px solid var(--border);background:var(--bg-elev);margin-top:56px;padding:28px 0}.footer__inner{max-width:var(--max-w);padding:0 var(--gutter);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin:0 auto;display:flex}.footer__copy,.footer__meta{color:var(--text-muted);align-items:center;gap:10px;font-size:13px;display:inline-flex}.footer__mono{font-family:var(--mono);color:var(--text-faint);font-size:12px}.section-header{max-width:720px;margin-bottom:36px}.section-header--center{text-align:center;margin-left:auto;margin-right:auto}.section-header__tab{font-family:var(--mono);letter-spacing:.04em;color:var(--text-faint);border-bottom:1px solid var(--border-2);align-items:baseline;gap:8px;min-width:220px;margin-bottom:14px;padding:4px 0 10px;font-size:12.5px;display:inline-flex;position:relative}.section-header__tab:after{content:"";background:var(--accent);width:28px;height:1px;position:absolute;bottom:-1px;left:0}.section-header__num{color:var(--accent);font-weight:500}.section-header__sep{color:var(--text-faint);opacity:.6}.section-header__eyebrow{color:var(--text-muted);text-transform:lowercase}.section-header__title{color:var(--text-strong);margin-bottom:12px;font-size:clamp(28px,3.5vw,40px);font-weight:500;line-height:1.15}.section-header__desc{color:var(--text-muted);max-width:60ch;font-size:16.5px;line-height:1.6}.hero{min-height:clamp(560px,92vh,880px);padding:96px 0 80px;position:relative;overflow:hidden}.hero__bg{z-index:0;position:absolute;inset:0}.hero__inner{max-width:var(--max-w);padding:0 var(--gutter);z-index:1;padding-right:calc(var(--gutter) + 320px);pointer-events:none;margin:0 auto;position:relative}.hero__inner a,.hero__inner button,.hero__inner .btn,.hero__side a,.hero__side button{pointer-events:auto}.hero__main{padding-top:8px}.hero__tab{font-family:var(--mono);color:var(--text-faint);border-bottom:1px solid var(--border-2);align-items:center;gap:8px;min-width:180px;margin-bottom:24px;padding:6px 0 8px;font-size:12.5px;display:inline-flex;position:relative}.hero__tab:after{content:"";background:var(--accent);width:24px;height:1px;position:absolute;bottom:-1px;left:0}.hero__tab-num{color:var(--accent)}.hero__tab-sep{opacity:.5}.hero__tab-label{color:var(--text-muted)}.hero__title{letter-spacing:-.02em;color:var(--text-strong);margin-bottom:24px;font-size:clamp(34px,5vw,60px);font-weight:500;line-height:1.08}.hero__title-line{display:block}.hero__accent{color:var(--accent);font-style:italic;font-family:var(--serif);letter-spacing:-.01em;font-weight:500}.hero__lead{color:var(--text-muted);max-width:56ch;margin-bottom:36px;font-size:clamp(16px,1.4vw,18.5px);line-height:1.65}.hero__actions{flex-wrap:wrap;gap:10px;display:flex}.hero__terrain-note{z-index:2;font-family:var(--mono);letter-spacing:.08em;text-transform:lowercase;color:var(--text);text-align:right;pointer-events:none;max-width:60vw;margin:0;font-size:11.5px;position:absolute;bottom:28px;right:32px}.hero__terrain-note span{border-radius:999px;padding:6px 10px;display:inline-block}@media (width<=720px){.hero__terrain-note{font-size:10.5px;bottom:16px;right:16px}}.hero__card{background:color-mix(in srgb, var(--surface) 90%, transparent);border:1px solid var(--border-2);border-radius:var(--radius-lg);width:100%;height:100%;font-family:var(--mono);box-shadow:var(--shadow);pointer-events:auto;-webkit-backdrop-filter:blur(6px);flex-direction:column;padding:20px 22px 18px;display:flex;position:relative}.hero__card-head{border-bottom:1px dashed var(--border-2);flex-shrink:0;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;display:flex}.hero__card-title{color:var(--text-faint);letter-spacing:.04em;font-size:11.5px}.hero__card-dot{background:var(--status-active);width:8px;height:8px;box-shadow:0 0 0 3px color-mix(in srgb, var(--status-active) 25%, transparent);border-radius:50%}.hero__card-rows{flex-direction:column;flex:1;gap:14px;margin:0;display:flex}.hero__card-row{flex-direction:column;gap:4px;display:flex}.hero__card-row dt{color:var(--text-faint);text-transform:lowercase;letter-spacing:.08em;font-size:10.5px}.hero__card-row dd{color:var(--text-strong);word-break:break-word;margin:0;font-size:13px;line-height:1.45}.hero__card-foot{border-top:1px dashed var(--border-2);color:var(--text-muted);flex-shrink:0;align-items:center;gap:8px;margin:16px 0 0;padding-top:12px;font-size:11.5px;display:inline-flex}.hero__card-pulse{background:var(--status-active);width:7px;height:7px;animation:pulse 2.6s var(--ease) infinite;border-radius:50%;display:inline-block}@keyframes pulse{0%,to{box-shadow:0 0 0 0 color-mix(in srgb, var(--status-active) 35%, transparent)}50%{box-shadow:0 0 0 8px #0000}}.hero__paper{pointer-events:none;z-index:0;background:radial-gradient(60% 50% at 88% 12%,#d4a35614,#0000 60%),radial-gradient(60% 50% at 8% 92%,#b8593a0d,#0000 60%);position:absolute;inset:0}.btn{border-radius:var(--radius);background:var(--accent);color:var(--accent-ink);letter-spacing:.01em;cursor:pointer;-webkit-user-select:none;user-select:none;transition:transform var(--t-fast), background var(--t-fast), border-color var(--t-fast), color var(--t-fast), box-shadow var(--t-fast);border:1px solid #0000;justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-size:14px;font-weight:600;text-decoration:none;display:inline-flex}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn--sm{border-radius:var(--radius-sm);padding:7px 12px;font-size:13px}.btn--md{padding:10px 16px}.btn--primary{background:var(--accent);color:var(--accent-ink);box-shadow:0 4px 0 -2px var(--accent-soft)}.btn--primary:hover{background:var(--accent-soft);color:var(--accent-ink)}.btn--secondary{background:var(--surface);color:var(--text-strong);border-color:var(--border-2)}.btn--secondary:hover{background:var(--surface-hov);border-color:var(--accent-line)}.btn--ghost{color:var(--text);border-color:var(--border);background:0 0}.btn--ghost:hover{background:var(--surface-hov);color:var(--text-strong);border-color:var(--border-2)}.btn__icon{align-items:center;display:inline-flex}.tech-badge{font-size:11.5px;font-weight:500;font-family:var(--mono);background:var(--bg-elev-2);color:var(--text);border:1px solid var(--border);white-space:nowrap;transition:background var(--t-fast), color var(--t-fast), border-color var(--t-fast);border-radius:999px;align-items:center;padding:3px 9px;display:inline-flex}.tech-badge--accent{background:var(--accent-bg);color:var(--accent);border-color:var(--accent-line)}.tech-badge--muted{color:var(--text-muted);background:0 0;border-style:dashed}.filter-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:12px;display:flex}.filter-bar__chips{flex-wrap:wrap;gap:6px;display:flex}.filter-bar__count{color:var(--text-faint);font-size:12.5px;font-family:var(--mono);margin-bottom:24px}.chip{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;transition:background var(--t-fast), color var(--t-fast), border-color var(--t-fast);background:0 0;border-radius:999px;padding:6px 12px;font-size:13px;font-weight:500}.chip:hover{color:var(--text-strong);border-color:var(--border-2)}.chip--active{background:var(--accent-bg);color:var(--accent);border-color:var(--accent-line)}.search{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);min-width:240px;transition:border-color var(--t-fast), box-shadow var(--t-fast);align-items:center;gap:8px;padding:8px 12px;display:inline-flex}.search:focus-within{border-color:var(--accent-line);box-shadow:0 0 0 3px var(--accent-bg)}.search__icon{color:var(--text-faint);display:inline-flex}.search__input{color:var(--text-strong);background:0 0;border:0;outline:0;flex:1;min-width:0;font-size:14px}.search__input::placeholder{color:var(--text-faint);font-family:var(--mono);font-size:13px}.search__clear{color:var(--text-faint);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--t-fast), background var(--t-fast);background:0 0;border:0;padding:2px;display:inline-flex}.search__clear:hover{color:var(--text-strong);background:var(--surface-hov)}.empty-state{text-align:center;background:var(--surface);border:1px dashed var(--border-2);border-radius:var(--radius-lg);padding:48px 24px}.empty-state__title{color:var(--text-strong);margin-bottom:4px;font-weight:500}.empty-state__desc{color:var(--text-muted);font-size:14px}.project-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:18px;display:grid}.project-grid--featured{grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:22px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:transform var(--t-med), border-color var(--t-med), background var(--t-med), box-shadow var(--t-med);flex-direction:column;display:flex;position:relative;overflow:hidden}.card:hover,.card:focus-visible{border-color:var(--accent-line);background:var(--surface-2);box-shadow:var(--shadow);transform:translateY(-3px)}.card:focus-visible{outline:none}.card__topbar{border-bottom:1px dashed var(--border-2);font-family:var(--mono);color:var(--text-faint);letter-spacing:.02em;align-items:center;gap:12px;padding:12px 18px;font-size:11.5px;display:flex}.card__id{color:var(--accent)}.card__category{color:var(--text-muted);flex:1}.card__status{letter-spacing:.04em;background:var(--bg-elev-2);color:var(--text-muted);border:1px solid var(--border);border-radius:999px;align-items:center;gap:6px;padding:2px 9px;font-size:11px;display:inline-flex}.card__status-dot{background:var(--text-faint);border-radius:50%;width:6px;height:6px}.card__status--active{color:var(--status-active);border-color:color-mix(in srgb, var(--status-active) 40%, var(--border))}.card__status--active .card__status-dot{background:var(--status-active)}.card__status--in-development{color:var(--status-prog);border-color:color-mix(in srgb, var(--status-prog) 40%, var(--border))}.card__status--in-development .card__status-dot{background:var(--status-prog)}.card__status--prototype{color:var(--status-proto);border-color:color-mix(in srgb, var(--status-proto) 40%, var(--border))}.card__status--prototype .card__status-dot{background:var(--status-proto)}.card__status--completed{color:var(--status-done);border-color:var(--border-2)}.card__status--completed .card__status-dot{background:var(--status-done)}.card__body{flex-direction:column;flex:1;gap:12px;padding:18px 20px 16px;display:flex}.card__title{color:var(--text-strong);letter-spacing:-.01em;font-size:20px;font-weight:500;line-height:1.2}.card--featured .card__title{font-size:22px}.card__subtitle{color:var(--text-muted);margin-top:-6px;font-size:13px}.card__desc{color:var(--text);font-size:14.5px;line-height:1.6}.card__highlights{flex-direction:column;gap:6px;padding-left:0;display:flex}.card__highlights li{color:var(--text);align-items:baseline;gap:8px;font-size:13.5px;line-height:1.5;display:flex}.card__highlight-mark{font-family:var(--mono);color:var(--accent);flex-shrink:0;font-size:12px}.card__meta{border-top:1px dashed var(--border-2);font-family:var(--mono);gap:6px;margin:4px 0 0;padding:12px 0 0;font-size:12px;display:grid}.card__meta-row{grid-template-columns:60px 1fr;align-items:baseline;gap:12px;display:grid}.card__meta-row dt{color:var(--text-muted);letter-spacing:.02em}.card__meta-row dd{color:var(--text);word-break:break-word;margin:0}.card__langs{flex-wrap:wrap;gap:5px;margin-top:4px;display:flex}.card__footer{border-top:1px solid var(--border);background:var(--bg-elev-2);justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.card__cta{font-family:var(--mono);color:var(--accent);letter-spacing:.02em;transition:gap var(--t-fast), color var(--t-fast);align-items:center;gap:6px;font-size:12.5px;display:inline-flex}.card:hover .card__cta{color:var(--accent-soft);gap:10px}.card__github{border-radius:var(--radius-sm);width:30px;height:30px;color:var(--text-muted);border:1px solid var(--border);transition:color var(--t-fast), border-color var(--t-fast), background var(--t-fast);justify-content:center;align-items:center;display:inline-flex}.card__github:hover{color:var(--accent);border-color:var(--accent-line);background:var(--accent-bg)}.detail-overlay{z-index:100;-webkit-backdrop-filter:blur(6px);animation:fadeIn .22s var(--ease);background:#000000a6;place-items:start center;padding:60px 20px;display:grid;position:fixed;inset:0;overflow-y:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.detail{background:var(--bg-elev);border:1px solid var(--border-2);border-radius:var(--radius-lg);width:min(880px,100%);box-shadow:var(--shadow-lg);animation:slideUp .28s var(--ease);outline:none;position:relative}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)scale(.99)}to{opacity:1;transform:translateY(0)scale(1)}}.detail__close{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-muted);cursor:pointer;transition:color var(--t-fast), background var(--t-fast), border-color var(--t-fast), transform var(--t-fast);z-index:2;place-items:center;display:grid;position:absolute;top:14px;right:14px}.detail__close:hover{color:var(--text-strong);background:var(--surface-hov);border-color:var(--accent-line);transform:rotate(90deg)}.detail__head{padding:32px 40px 24px}.detail__tab{font-family:var(--mono);color:var(--text-faint);letter-spacing:.04em;align-items:baseline;gap:8px;margin-bottom:14px;font-size:12px;display:inline-flex}.detail__tab-label{color:var(--accent)}.detail__tab-cat,.detail__tab-year{color:var(--text-muted)}.detail__tab-sep{opacity:.5}.detail__title{letter-spacing:-.02em;color:var(--text-strong);margin-bottom:4px;font-size:clamp(26px,3vw,36px);font-weight:500;line-height:1.15}.detail__subtitle{color:var(--text-muted);margin-bottom:22px;font-size:16px;font-style:normal}.detail__actions{flex-wrap:wrap;gap:10px;display:flex}.detail__lead{color:var(--text);font-size:16px;line-height:1.7}.detail__section{padding:14px 40px;position:relative}.detail__section:last-child{padding-bottom:36px}.detail__section-head{font-family:var(--mono);color:var(--text-faint);letter-spacing:.04em;align-items:baseline;gap:8px;margin-bottom:14px;font-size:12px;font-weight:500;display:inline-flex}.detail__section-num{color:var(--accent)}.detail__section-sep{opacity:.5}.detail__section-label{color:var(--text-muted);text-transform:lowercase}.detail__section-body p{color:var(--text);font-size:15px;line-height:1.65}.detail__tags{flex-wrap:wrap;gap:6px;display:flex}.detail__list{flex-direction:column;gap:10px;display:flex}.detail__list li{color:var(--text);padding-left:18px;font-size:15px;line-height:1.6;position:relative}.detail__list li:before{content:"";opacity:.7;background:currentColor;border-radius:2px;width:8px;height:1.5px;position:absolute;top:11px;left:0}.detail__demo{background:var(--accent-bg);border:1px solid var(--accent-line);border-radius:var(--radius);gap:14px;padding:14px 16px;display:flex}.detail__demo-icon{border-radius:var(--radius-sm);background:var(--bg-elev);width:32px;height:32px;color:var(--accent);flex-shrink:0;place-items:center;display:inline-grid}.detail__demo-body{flex-direction:column;flex:1;gap:6px;display:flex}.detail__demo-status{font-family:var(--mono);align-items:baseline;gap:8px;font-size:12px;display:inline-flex}.detail__demo-label{color:var(--text-faint)}.detail__demo-value{color:var(--accent)}.detail__demo-note{color:var(--text);font-size:14.5px;line-height:1.55}.detail__gallery{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;display:grid}.detail__shot{cursor:pointer;text-align:left;background:0 0;border:0;width:100%;margin:0;padding:0;display:block}.detail__shot-frame{aspect-ratio:16/9;background:var(--bg-elev-2);border:1px dashed var(--border-2);border-radius:var(--radius);transition:border-color var(--t-fast), transform var(--t-fast);display:block;position:relative;overflow:hidden}.detail__shot:hover .detail__shot-frame,.detail__shot:focus-visible .detail__shot-frame{border-color:var(--accent-line);transform:translateY(-1px)}.detail__shot:focus-visible{outline:none}.detail__shot-frame img,.detail__shot-frame video{object-fit:cover;z-index:1;background:var(--bg-elev-2);width:100%;height:100%;display:block;position:absolute;inset:0}.detail__shot-play{background:color-mix(in srgb, var(--bg) 70%, transparent);border:1px solid color-mix(in srgb, var(--text-strong) 25%, transparent);width:38px;height:38px;color:var(--text-strong);pointer-events:none;-webkit-backdrop-filter:blur(4px);z-index:2;border-radius:50%;place-items:center;display:grid;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.detail__shot-fallback{font-family:var(--mono);color:var(--text-faint);text-align:center;pointer-events:none;z-index:0;place-items:center;padding:12px;font-size:11.5px;display:grid;position:absolute;inset:0}.detail__shot-fallback code{color:var(--text-muted);font-size:11.5px}.lightbox{z-index:200;animation:fadeIn .2s var(--ease);background:#000000eb;place-items:center;display:grid;position:fixed;inset:0}.lightbox__zone{cursor:pointer;z-index:1;width:50%;transition:background var(--t-fast);background:0 0;border:0;align-items:center;display:flex;position:absolute;top:0;bottom:0}.lightbox__zone--prev{justify-content:flex-start;padding-left:28px;left:0}.lightbox__zone--next{justify-content:flex-end;padding-right:28px;right:0}.lightbox__zone:hover{background:linear-gradient(to var(--lightbox-fade,right), #00000059, transparent 35%)}.lightbox__zone--prev{--lightbox-fade:right}.lightbox__zone--next{--lightbox-fade:left}.lightbox__zone-icon{background:color-mix(in srgb, var(--bg) 60%, transparent);border:1px solid color-mix(in srgb, var(--text-strong) 18%, transparent);width:48px;height:48px;color:var(--text-strong);opacity:0;transition:opacity var(--t-med), transform var(--t-med);-webkit-backdrop-filter:blur(6px);border-radius:999px;place-items:center;display:inline-grid;transform:translateY(0)scale(.94)}.lightbox__zone:hover .lightbox__zone-icon,.lightbox__zone:focus-visible .lightbox__zone-icon{opacity:1;transform:translateY(0)scale(1)}.lightbox__stage{z-index:2;pointer-events:none;max-width:92vw;max-height:84vh;position:relative}.lightbox__stage img,.lightbox__stage video{object-fit:contain;border-radius:var(--radius);pointer-events:auto;background:var(--bg-elev);width:auto;max-width:92vw;height:auto;max-height:84vh;display:block;box-shadow:0 30px 80px -20px #000000b3}.lightbox__close{z-index:3;background:color-mix(in srgb, var(--bg) 60%, transparent);border:1px solid color-mix(in srgb, var(--text-strong) 18%, transparent);border-radius:var(--radius-sm);width:36px;height:36px;color:var(--text-strong);cursor:pointer;transition:transform var(--t-fast), background var(--t-fast), border-color var(--t-fast);-webkit-backdrop-filter:blur(6px);place-items:center;display:grid;position:absolute;top:20px;right:24px}.lightbox__close:hover{background:color-mix(in srgb, var(--bg) 80%, transparent);border-color:var(--accent-line);transform:rotate(90deg)}.lightbox__count{z-index:3;font-family:var(--mono);letter-spacing:.06em;color:var(--text-muted);pointer-events:none;font-size:12px;position:absolute;bottom:24px;left:50%;transform:translate(-50%)}.lightbox__count-sep{color:var(--text-faint);opacity:.6;margin:0 4px}@media (width<=720px){.lightbox__zone--prev{padding-left:12px}.lightbox__zone--next{padding-right:12px}.lightbox__zone-icon{opacity:.85;width:40px;height:40px}.lightbox__close{top:12px;right:12px}}.demo{cursor:default;outline:none;flex-direction:column;gap:8px;display:flex;position:relative}.demo:focus-visible .demo__canvas{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.demo__stage{width:100%;position:relative}.demo__canvas{border-radius:var(--radius);border:1px solid var(--border-2);width:100%;height:auto;image-rendering:pixelated;cursor:pointer;transition:border-color var(--t-fast), box-shadow var(--t-fast);background:#3f3f37;display:block}.demo__overlay{background:color-mix(in srgb, var(--bg) 75%, transparent);-webkit-backdrop-filter:blur(2px);border-radius:var(--radius);pointer-events:none;text-align:center;place-items:center;padding:24px;display:grid;position:absolute;inset:0}.demo__overlay-title{color:var(--text-strong);letter-spacing:-.01em;margin-bottom:6px;font-size:22px;font-weight:500}.demo__overlay-hint{font-family:var(--mono);letter-spacing:.06em;color:var(--text-muted);font-size:12px}.demo__hud{font-family:var(--mono);letter-spacing:.06em;color:var(--text-faint);flex-wrap:wrap;align-items:center;gap:14px;padding:0 4px;font-size:11.5px;display:flex}.demo__hud-stat{color:var(--text-muted)}.demo__hud-stat strong{color:var(--text-strong);margin-left:4px;font-weight:600}.demo__hud-spacer{flex:1}.demo__hud-keys{color:var(--text-faint);text-transform:lowercase}.demo--snake .demo__canvas{max-width:500px;margin:0 auto}.demo--platformer .demo__canvas{max-width:100%}.skills-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.skill-group{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--t-med), background var(--t-med);padding:20px 22px}.skill-group:hover{border-color:var(--accent-line);background:var(--surface-2)}.skill-group__title{font-size:13px;font-weight:500;font-family:var(--mono);letter-spacing:.04em;color:var(--accent);text-transform:lowercase;margin-bottom:8px}.skill-group__caption{color:var(--text-muted);margin-bottom:14px;font-size:13.5px;line-height:1.55}.skill-group__items{flex-wrap:wrap;gap:5px;display:flex}.about-grid{grid-template-columns:1.6fr 1fr;align-items:start;gap:32px;display:grid}.about-grid__main p{color:var(--text);margin-bottom:16px;font-size:16px;line-height:1.75}.about-grid__main p:last-child{margin-bottom:0}.about-grid__main em{color:var(--text-strong);font-family:var(--serif);font-style:italic}.about-grid__side{flex-direction:column;gap:16px;display:flex}.about-grid__panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px}.about-grid__panel-title{font-family:var(--mono);letter-spacing:.06em;color:var(--accent);text-transform:lowercase;border-bottom:1px dashed var(--border-2);margin-bottom:12px;padding-bottom:8px;font-size:12px}.about-list li{color:var(--text);margin-bottom:8px;padding-left:18px;font-size:14.5px;line-height:1.55;position:relative}.about-list li:last-child{margin-bottom:0}.about-list li:before{content:"";background:var(--accent);width:6px;height:1px;position:absolute;top:10px;left:0}.about-list em{color:var(--text-strong);font-family:var(--serif);font-style:italic}.contact-card{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius-lg);grid-template-columns:1.1fr 1fr;gap:36px;padding:32px;display:grid;position:relative;overflow:hidden}.contact-card:after{content:"";pointer-events:none;background:radial-gradient(circle at 0% 0%, var(--accent-bg), transparent 50%);opacity:.7;position:absolute;inset:0}.contact-card__primary,.contact-list{z-index:1;position:relative}.contact-card__pitch{color:var(--text);margin-bottom:22px;font-size:16.5px;line-height:1.65}.contact-card__actions{flex-wrap:wrap;gap:10px;display:flex}.contact-list{flex-direction:column;gap:8px;display:flex}.contact-link{background:var(--bg-elev-2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);transition:transform var(--t-fast), border-color var(--t-fast), background var(--t-fast), color var(--t-fast);align-items:center;gap:14px;padding:12px 14px;text-decoration:none;display:flex}.contact-link:hover{border-color:var(--accent-line);background:var(--surface-hov);transform:translate(2px)}.contact-link__icon{border-radius:var(--radius-sm);background:var(--accent-bg);width:34px;height:34px;color:var(--accent);place-items:center;display:inline-grid}.contact-link__body{flex-direction:column;flex:1;min-width:0;display:flex}.contact-link__label{font-family:var(--mono);letter-spacing:.06em;color:var(--text-faint);font-size:11.5px}.contact-link__value{color:var(--text-strong);text-overflow:ellipsis;white-space:nowrap;font-size:14px;overflow:hidden}.contact-link__chev{color:var(--text-faint);transition:color var(--t-fast), transform var(--t-fast);display:inline-flex}.contact-link:hover .contact-link__chev{color:var(--accent);transform:translate(2px)}.reveal{opacity:0;transition:opacity .6s var(--ease), transform .6s var(--ease);will-change:opacity, transform;transform:translateY(14px)}.reveal--visible{opacity:1;transform:translateY(0)}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}.reveal{opacity:1;transform:none}}@media (width<=1024px){.hero__inner{padding-right:var(--gutter)}.hero__side{width:auto;max-width:520px;padding:0 var(--gutter);z-index:1;margin:36px auto 0;position:static}.hero__card{max-width:520px;height:auto}.hero__card-rows{gap:12px}.hero__card-row{flex-direction:row;align-items:baseline;gap:14px}.hero__card-row dt{flex-shrink:0;min-width:80px}}@media (width<=880px){.skills-grid,.about-grid{grid-template-columns:1fr}.contact-card{grid-template-columns:1fr;padding:26px}.hero{padding:80px 0 56px}.section{padding:72px 0}.detail:before{display:none}.detail__head{padding:28px 24px 20px}.detail__section{padding:22px 24px}}@media (width<=720px){:root{--gutter:18px}.nav__menu-toggle{display:inline-flex}.nav__list{padding:12px var(--gutter) 16px;background:var(--bg-elev);border-bottom:1px solid var(--border);opacity:0;pointer-events:none;transition:transform var(--t-med), opacity var(--t-med);flex-direction:column;align-items:stretch;gap:2px;position:absolute;top:100%;left:0;right:0;transform:translateY(-8px)}.nav__list--open{opacity:1;pointer-events:auto;transform:translateY(0)}.nav__link{text-align:left;border-radius:var(--radius-sm);padding:10px 12px}.nav__link--active:after,.nav__brand-text{display:none}.filter-bar{flex-direction:column;align-items:stretch}.search{width:100%}.section__head-row{flex-direction:column;align-items:flex-start}.hero__title{font-size:clamp(30px,8vw,44px)}.card__meta-row{grid-template-columns:50px 1fr}.hero__card-row{flex-direction:column;gap:4px}.hero__card-row dt{min-width:0}}body.intro-locked{overflow:hidden}.intro{z-index:200;background:var(--bg);cursor:pointer;animation:intro-in .22s var(--ease) both;place-items:center;display:grid;position:fixed;inset:0}.intro--leaving{animation:.36s cubic-bezier(.55,0,.2,1) forwards intro-out}@keyframes intro-in{0%{opacity:0}to{opacity:1}}@keyframes intro-out{0%{opacity:1;transform:translateY(0)}to{opacity:1;transform:translateY(-100%)}}.intro__panel{z-index:1;text-align:center;border:1px solid var(--border-2);border-radius:var(--radius);background:var(--bg-elev);box-shadow:var(--shadow);min-width:min(420px,86vw);animation:intro-panel .36s var(--ease) 40ms both;flex-direction:column;align-items:center;gap:18px;padding:28px 36px 22px;display:flex;position:relative}@keyframes intro-panel{0%{opacity:0;transform:translateY(8px)scale(.99)}to{opacity:1;transform:translateY(0)scale(1)}}.intro__line{font-family:var(--mono);color:var(--text-faint);letter-spacing:.04em;justify-content:center;align-items:baseline;gap:8px;margin:0;font-size:13px;display:inline-flex}.intro__hint{font-family:var(--mono);color:var(--text-faint);letter-spacing:.08em;text-transform:lowercase;opacity:.7;border-top:1px dashed var(--border-2);width:100%;animation:intro-hint .6s var(--ease) .38s both;margin:0;padding-top:10px;font-size:11px}@keyframes intro-hint{0%{opacity:0}to{opacity:.7}}.intro__name{font-family:var(--sans);letter-spacing:-.02em;color:var(--text-strong);white-space:nowrap;align-items:baseline;gap:10px;margin:0;font-size:clamp(28px,5vw,44px);font-weight:500;line-height:1.1;display:inline-flex}.intro__name-mark{color:var(--accent);font-family:var(--mono);animation:bracket-fade .32s var(--ease) .1s both;font-size:.55em;position:relative;top:-.1em}.intro__name-text{background-image:linear-gradient(90deg, var(--text-strong) 0 100%);color:#0000;background-repeat:no-repeat;background-size:0% 100%;-webkit-background-clip:text;background-clip:text;animation:.44s cubic-bezier(.4,0,.2,1) .14s both name-wipe;position:relative}@keyframes name-wipe{0%{background-size:0% 100%}to{background-size:100% 100%}}@keyframes bracket-fade{0%{opacity:0;transform:translateY(2px)}to{opacity:1;transform:translateY(0)}}.intro__caret{color:var(--accent);animation:.9s ease-in-out infinite blink}@keyframes blink{0%,60%{opacity:1}70%,to{opacity:.25}}.intro__loading{color:var(--text-muted)}.intro__dots{align-items:center;gap:3px;margin-left:4px;display:inline-flex}.intro__dots span{background:var(--accent);opacity:.3;border-radius:50%;width:4px;height:4px;animation:1s ease-in-out infinite dot}.intro__dots span:nth-child(2){animation-delay:.14s}.intro__dots span:nth-child(3){animation-delay:.28s}@keyframes dot{0%,80%,to{opacity:.3;transform:translateY(0)}40%{opacity:1;transform:translateY(-2px)}}@media (prefers-reduced-motion:reduce){.intro,.intro--leaving,.intro__panel,.intro__grid,.intro__name-text,.intro__name-mark,.intro__caret,.intro__dots span{animation:none!important}}.hero__side{z-index:2;pointer-events:none;align-items:stretch;width:300px;display:flex;position:absolute;top:112px;bottom:72px;right:32px}.hero-diagram{aspect-ratio:5/4;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius-lg);width:100%;color:var(--accent);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.hero-diagram:after{content:"";pointer-events:none;background:radial-gradient(60% 50%,#0000 50%,#00000059 100%);position:absolute;inset:0}.hero-diagram__svg{width:100%;height:100%;display:block}.hero-diagram__face{fill:var(--bg-elev);stroke:var(--accent);stroke-width:1.1px;opacity:.85}.hero-diagram__face--top{fill:color-mix(in srgb, var(--accent) 14%, var(--bg-elev))}.hero-diagram__face--left{fill:color-mix(in srgb, var(--accent) 6%, var(--bg-elev))}.hero-diagram__face--right{fill:color-mix(in srgb, var(--rust) 6%, var(--bg-elev))}.hero-diagram__outline{stroke:var(--accent);stroke-width:1.4px;stroke-linecap:round;stroke-linejoin:round;opacity:.95;filter:drop-shadow(0 0 6px color-mix(in srgb, var(--accent) 50%, transparent))}.hero-diagram__chunk{transform-origin:0 24px;animation:9s ease-in-out infinite chunk-float}@keyframes chunk-float{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-3px)rotate(.4deg)}}.hero-diagram__orbit{transform-origin:0 24px}.hero-diagram__orbit-line{fill:none;stroke:var(--accent);stroke-width:.5px;stroke-dasharray:1 5;opacity:.45}.hero-diagram__node{fill:var(--accent);filter:drop-shadow(0 0 4px color-mix(in srgb, var(--accent) 60%, transparent))}.hero-diagram__orbit--a{animation:14s linear infinite orbit}.hero-diagram__orbit--b{animation:22s linear infinite reverse orbit}.hero-diagram__orbit--c{animation:9s linear infinite orbit}@keyframes orbit{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.hero-diagram__marks{color:var(--text-faint);opacity:.7}.hero-diagram__cap{font-family:var(--mono);fill:var(--text-faint);letter-spacing:.12em;opacity:.85;font-size:7.5px}@media (prefers-reduced-motion:reduce){.hero-diagram__chunk,.hero-diagram__orbit--a,.hero-diagram__orbit--b,.hero-diagram__orbit--c{animation:none!important}}.card__topbar{border-bottom:0;padding-bottom:10px}.pmedia{aspect-ratio:16/9;background:var(--bg-elev-2);border-bottom:1px dashed var(--border-2);isolation:isolate;position:relative;overflow:hidden}.pmedia__rest,.pmedia__hover{object-fit:cover;width:100%;height:calc(100% + 48px);transition:opacity .36s var(--ease), transform .48s var(--ease);will-change:opacity, transform;display:block;position:absolute;top:-24px;left:0;right:0}.pmedia__rest{z-index:1;opacity:1;transform:translate3d(0, var(--pmedia-py,0px), 0)}.pmedia__hover{z-index:2;opacity:0;transform:scale(1.02)}.card:hover .pmedia__rest,.card:focus-visible .pmedia__rest{opacity:0;transform:translate3d(0, var(--pmedia-py,0px), 0) scale(1.04)}.card:hover .pmedia__hover,.card:focus-visible .pmedia__hover{opacity:1;transform:scale(1)}.pmedia__placeholder{background:linear-gradient(180deg, #0000 0%, #00000040 100%), repeating-linear-gradient(0deg, transparent 0 22px, var(--rule) 22px 23px);flex-direction:column;justify-content:center;width:100%;height:100%;padding:18px 22px;display:flex}.pmedia__placeholder-title{color:var(--text-strong);letter-spacing:-.01em;margin-bottom:4px;font-size:16px;font-weight:500}.pmedia__placeholder-sub{color:var(--text-muted);margin-bottom:12px;font-size:12.5px}.pmedia__placeholder-foot{font-family:var(--mono);color:var(--text-faint);margin-top:auto;font-size:10.5px}.card__body{padding-top:16px}@media (width<=720px){.pmedia{aspect-ratio:16/9}.hero-diagram{aspect-ratio:4/3}}.voxel{cursor:grab;background:0 0;border:0;outline:none;width:100%;height:100%;position:relative}.voxel:active{cursor:grabbing}.voxel>canvas{width:100%;height:100%;display:block}.voxel--unsupported{cursor:default;place-items:center;padding:40px 24px;display:grid}.voxel__fallback{text-align:center;color:var(--text-muted);font-size:13px;font-family:var(--mono)}
