:root{--bg:#ececed;--panel:#fff;--panel-alt:#f6f6f7;--header-bg:#1f2937;--header-ink:#e9eaec;--ink:#1a1a1a;--ink-2:#3f3f46;--ink-3:#6b6b72;--border:#d4d4d8;--border-strong:#b6b6bd;--link:#1a5cad;--link-hover:#103e75;--link-visited:#5b3a9e;--row-hover:#eef4fc;--ok:#2e7d32;--ok-bg:#e8f3e9;--wip:#a15c00;--wip-bg:#fbf0dd;--idle:#57575e;--idle-bg:#ececee;--sans:system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji", sans-serif;--mono:ui-monospace, SFMono-Regular, "Cascadia Code", "Consolas", "Liberation Mono", monospace;--maxw:1180px;--pad:clamp(.85rem, 3vw, 1.75rem);--gap:1rem;--radius:4px;--header-h:52px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;font-family:var(--sans);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;font-size:15px;line-height:1.5}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:auto}body{background:var(--bg);color:var(--ink);overflow-x:hidden}h1,h2,h3,h4{font-family:var(--sans);color:var(--ink);font-weight:700;line-height:1.25}h1{font-size:1.5rem}h2{font-size:1.15rem}h3{font-size:1rem}h4{font-size:.9rem}p{color:var(--ink-2)}a{color:var(--link);text-underline-offset:2px;text-decoration:underline}a:hover{color:var(--link-hover)}:focus-visible{outline:2px solid var(--link);outline-offset:2px}::selection{background:#cfe0f7}img,video{max-width:100%;display:block}ul,ol{list-style:none}.sr-only{clip:rect(0 0 0 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.skip-link{z-index:200;background:var(--panel);color:var(--link);border:1px solid var(--border-strong);border-radius:var(--radius);padding:.5rem .85rem;position:absolute;top:0;left:-9999px}.skip-link:focus{top:.5rem;left:.5rem}.wrap{width:100%;max-width:var(--maxw);padding-inline:var(--pad);margin:0 auto}.section{scroll-margin-top:calc(var(--header-h) + 8px);padding-block:clamp(1.5rem,4vw,2.5rem)}.section-head{border-bottom:2px solid var(--ink);justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:1rem;padding-bottom:.5rem;display:flex}.section-head h2{letter-spacing:.01em;font-size:1.1rem}.section-head .count{font-family:var(--mono);color:var(--ink-3);font-size:.8rem}.panel{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius)}.tag{font-family:var(--mono);color:var(--ink-2);background:var(--panel-alt);border:1px solid var(--border);white-space:nowrap;border-radius:3px;padding:.05rem .4rem;font-size:.74rem;line-height:1.4;display:inline-block}.tag-row{flex-wrap:wrap;gap:.35rem;display:flex}.status{font-family:var(--mono);text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;border:1px solid #0000;border-radius:3px;align-items:center;gap:.35rem;padding:.1rem .45rem;font-size:.72rem;font-weight:500;display:inline-flex}.status:before{content:"";background:currentColor;border-radius:50%;width:7px;height:7px}.status.is-ok{color:var(--ok);background:var(--ok-bg);border-color:color-mix(in srgb, var(--ok) 35%, transparent)}.status.is-wip{color:var(--wip);background:var(--wip-bg);border-color:color-mix(in srgb, var(--wip) 35%, transparent)}.status.is-idle{color:var(--idle);background:var(--idle-bg);border-color:var(--border-strong)}.btn{font-family:var(--sans);color:var(--ink);background:var(--panel);border:1px solid var(--border-strong);border-radius:var(--radius);cursor:pointer;align-items:center;gap:.35rem;padding:.35rem .7rem;font-size:.85rem;font-weight:500;text-decoration:none;display:inline-flex}.btn:hover{background:var(--row-hover);border-color:var(--link);color:var(--link-hover)}.btn-primary{background:var(--link);border-color:var(--link);color:#fff}.btn-primary:hover{background:var(--link-hover);border-color:var(--link-hover);color:#fff}.kv{grid-template-columns:130px 1fr;gap:.4rem 1rem;display:grid}.kv dt{font-family:var(--mono);color:var(--ink-3);text-transform:uppercase;letter-spacing:.03em;padding-top:.05rem;font-size:.78rem}.kv dd{color:var(--ink-2)}@media (width<=560px){.kv{grid-template-columns:1fr;gap:.15rem 0}.kv dd{margin-bottom:.6rem}}@media (width<=768px){:root{font-size:14.5px}}.nav{z-index:100;background:var(--header-bg);color:var(--header-ink);border-bottom:1px solid #000;position:sticky;top:0}.nav-inner{min-height:var(--header-h);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.25rem 1rem;padding-block:.4rem;display:flex}.nav-brand{color:var(--header-ink);align-items:baseline;gap:.6rem;min-width:0;text-decoration:none;display:flex}.nav-name{white-space:nowrap;font-size:1rem;font-weight:700}.nav-links{flex-wrap:wrap;align-items:center;gap:.25rem 1rem;font-size:.86rem;display:flex}.nav-links a{color:#d7dbe2;white-space:nowrap;padding:.15rem 0;text-decoration:none}.nav-links a:hover{color:#fff;text-underline-offset:3px;text-decoration:underline}.nav-sep{background:#3c4555;width:1px;height:16px}.nav-contact{border-radius:var(--radius);border:1px solid #4a5568;padding:.2rem .6rem!important}.nav-contact:hover{background:#2b3647;text-decoration:none!important}.nav :focus-visible{outline-offset:2px;outline:2px solid #8ab4f8}@media (width<=620px){.nav-links{gap:.2rem .85rem;font-size:.82rem}.nav-sep{display:none}}.intro{border-bottom:1px solid var(--border);background:var(--panel);padding-block:clamp(1.25rem,4vw,2rem)}.intro-inner{grid-template-columns:1fr;gap:1.25rem 2rem;display:grid}@media (width>=760px){.intro-inner{grid-template-columns:1fr 300px;align-items:start}}.intro-main h1{font-size:clamp(1.5rem,3vw,1.9rem);line-height:1.15}.intro-role{color:var(--ink);max-width:60ch;margin-top:.35rem;margin-bottom:.7rem;font-size:1.05rem;font-weight:600}.intro-text{color:var(--ink-2);max-width:68ch;margin-bottom:1.1rem}.intro-actions{flex-wrap:wrap;gap:.5rem;display:flex}.intro-facts{background:var(--panel-alt);grid-template-columns:auto 1fr;align-self:start;gap:.45rem .9rem;padding:.85rem 1rem;display:grid}.intro-facts dt{font-family:var(--mono);text-transform:uppercase;letter-spacing:.03em;color:var(--ink-3);padding-top:.05rem;font-size:.72rem}.intro-facts dd{color:var(--ink);font-size:.88rem}.pc-grid{gap:var(--gap);grid-template-columns:1fr;display:grid}.pc{flex-direction:column;display:flex;overflow:hidden}.pc:hover{border-color:var(--border-strong)}.pc-media{aspect-ratio:16/9;background:var(--panel-alt);border-bottom:1px solid var(--border);display:block;position:relative;overflow:hidden}.pc-poster,.pc-preview{object-fit:cover;width:100%;height:100%}.pc-preview{opacity:0;transition:opacity .35s;position:absolute;inset:0}.pc-preview.is-visible{opacity:1}.pc-noimg{width:100%;height:100%;font-family:var(--mono);color:var(--ink-3);background:repeating-linear-gradient(45deg, var(--panel-alt), var(--panel-alt) 10px, #efeff1 10px, #efeff1 20px);justify-content:center;align-items:center;font-size:.8rem;display:flex}.pc-body{flex-direction:column;gap:.55rem;padding:.85rem 1rem 1rem;display:flex}.pc-head{justify-content:space-between;align-items:baseline;gap:.75rem;display:flex}.pc-title{font-size:1.1rem;line-height:1.2}.pc-title a{color:var(--ink);text-decoration:none}.pc-title a:hover{color:var(--link);text-decoration:underline}.pc-headmeta{flex:none;align-items:center;gap:.5rem;display:flex}.pc-year{font-family:var(--mono);color:var(--ink-3);font-size:.78rem}.pc-kind{font-family:var(--mono);color:var(--ink-3);margin-top:-.2rem;font-size:.74rem}.pc-summary{color:var(--ink-2)}.pc-spec{border-top:1px solid var(--border);grid-template-columns:110px 1fr;gap:.35rem .85rem;padding-top:.5rem;display:grid}.pc-spec dt{font-family:var(--mono);text-transform:uppercase;letter-spacing:.03em;color:var(--ink-3);padding-top:.1rem;font-size:.72rem}.pc-spec dd{color:var(--ink-2);font-size:.9rem}.pc-built{flex-direction:column;gap:.25rem;display:flex}.pc-built li{padding-left:1.05rem;position:relative}.pc-built li:before{content:"";background:var(--link);border-radius:1px;width:5px;height:5px;position:absolute;top:.5em;left:0}@media (width>=720px){.pc{flex-direction:row}.pc .pc-media{aspect-ratio:auto;border-bottom:none;border-right:1px solid var(--border);flex:0 0 46%}.pc .pc-body{flex:auto;padding:1.1rem 1.25rem}}.pc-links{flex-wrap:wrap;gap:.45rem;margin-top:.35rem;display:flex}@media (width<=480px){.pc-spec{grid-template-columns:1fr;gap:.1rem}.pc-spec dd{margin-bottom:.45rem}}@media (prefers-reduced-motion:reduce){.pc-preview.is-visible{opacity:0}}.exp-table-wrap{overflow:hidden}.exp-table{border-collapse:collapse;width:100%;font-size:.9rem}.exp-table th{text-align:left;font-family:var(--mono);text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3);background:var(--panel-alt);border-bottom:1px solid var(--border-strong);padding:.55rem .85rem;font-size:.72rem;font-weight:600}.exp-table td{border-bottom:1px solid var(--border);color:var(--ink-2);vertical-align:top;padding:.55rem .85rem}.exp-table tbody tr:last-child td{border-bottom:none}.exp-table tbody tr:hover{background:var(--row-hover)}.exp-role{color:var(--ink);font-weight:600}.exp-period{font-family:var(--mono);white-space:nowrap;font-size:.82rem}.exp-edu{margin-top:var(--gap);padding:.75rem .9rem}.exp-edu-label{font-family:var(--mono);text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3);margin-bottom:.4rem;font-size:.72rem}.exp-edu-line{color:var(--ink-2)}.exp-edu-line strong{color:var(--ink)}.exp-edu-meta{font-family:var(--mono);color:var(--ink-3);margin-top:.2rem;font-size:.8rem}@media (width<=640px){.exp-table thead{clip:rect(0 0 0 0);width:1px;height:1px;position:absolute;overflow:hidden}.exp-table,.exp-table tbody,.exp-table tr,.exp-table td{width:100%;display:block}.exp-table tr{border-bottom:1px solid var(--border);padding:.6rem .85rem}.exp-table tbody tr:last-child{border-bottom:none}.exp-table td{border:none;grid-template-columns:90px 1fr;gap:.5rem;padding:.15rem 0;display:grid}.exp-table td:before{content:attr(data-label);font-family:var(--mono);text-transform:uppercase;letter-spacing:.03em;color:var(--ink-3);font-size:.7rem}.exp-role{font-size:1rem}}.skills-focus{color:var(--ink-2);max-width:70ch;margin-bottom:1rem}.skills-grid{gap:var(--gap);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.skill-group{padding:.75rem .9rem .9rem}.skill-group-title{font-size:.78rem;font-family:var(--mono);text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3);border-bottom:1px solid var(--border);margin-bottom:.6rem;padding-bottom:.5rem}.skill-items{flex-wrap:wrap;gap:.4rem;display:flex}.skill-items li{font-family:var(--mono);color:var(--ink-2);background:var(--panel-alt);border:1px solid var(--border);border-radius:3px;align-items:center;gap:.35rem;padding:.12rem .45rem;font-size:.8rem;display:inline-flex}.skill-items li.is-pro{color:var(--ink);border-color:var(--border-strong)}.skill-dot{background:var(--ok);border-radius:50%;flex:none;width:6px;height:6px}.skills-legend{font-family:var(--mono);color:var(--ink-3);align-items:center;gap:.4rem;font-size:.74rem;display:inline-flex}.skill-note{border-top:1px dashed var(--border);color:var(--ink-3);margin-top:.6rem;padding-top:.55rem;font-size:.8rem}.principles-intro{color:var(--ink-2);max-width:80ch;margin-bottom:1rem}.principles-grid{gap:var(--gap);grid-template-columns:1fr;display:grid}@media (width>=720px){.principles-grid{grid-template-columns:repeat(3,1fr)}}.principle{padding:.85rem 1rem .95rem}.principle-title{border-bottom:1px solid var(--border);margin-bottom:.4rem;padding-bottom:.45rem;font-size:.95rem}.principle-body{color:var(--ink-2);font-size:.9rem}.detail-layout{display:block}@media (width>=1000px){.detail-layout.has-toc{grid-template-columns:minmax(0,1fr) 170px;align-items:stretch;gap:2.75rem;display:grid}}.detail-toc{display:none}@media (width>=1000px){.detail-toc{display:block}}.detail-toc-nav{top:calc(var(--header-h) + 1.25rem);flex-direction:column;display:flex;position:sticky}.detail-toc-label{font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);margin-bottom:.6rem;padding-left:.85rem;font-size:.66rem}.detail-toc-link{color:var(--ink-3);border-left:2px solid var(--border);padding:.32rem 0 .32rem .85rem;font-size:.82rem;text-decoration:none;transition:color .12s,border-color .12s}.detail-toc-link:hover{color:var(--ink)}.detail-toc-link.is-active{color:var(--ink);border-left-color:var(--link);font-weight:600}.detail-back{margin-bottom:1rem;font-size:.88rem}.detail-head{border-bottom:2px solid var(--ink);flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem;padding-bottom:.85rem;display:flex}.detail-titleblock h1{margin-bottom:.5rem;font-size:clamp(1.5rem,4vw,2rem)}.detail-meta{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.detail-kind,.detail-year{font-family:var(--mono);color:var(--ink-3);font-size:.82rem}.detail-actions{flex-wrap:wrap;gap:.5rem;display:flex}.media-frame{border:1px solid var(--border);border-radius:var(--radius);background:var(--panel);overflow:hidden}.media-frame img,.media-frame video{width:100%;display:block}.media-video{aspect-ratio:16/9;position:relative}.media-video iframe,.media-video video{object-fit:cover;border:0;width:100%;height:100%;position:absolute;inset:0}.hero-media{margin:0 0 1rem}.hero-media figcaption{font-family:var(--mono);color:var(--ink-3);margin-top:.5rem;font-size:.78rem}.detail-tagline{color:var(--ink);max-width:72ch;margin-bottom:1.1rem;font-size:clamp(1.05rem,2.2vw,1.25rem);line-height:1.5}.detail-tools{flex-wrap:wrap;align-items:center;gap:.5rem .7rem;display:flex}.detail-tools-label{font-family:var(--mono);text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3);font-size:.68rem}.detail-intro{scroll-margin-top:calc(var(--header-h) + 1rem);margin-bottom:2.75rem}.detail-overview{margin-bottom:1.2rem}.detail-section{scroll-margin-top:calc(var(--header-h) + 1rem);margin-bottom:2.5rem}.detail-h2{letter-spacing:.01em;border-bottom:2px solid var(--ink);margin-bottom:1.1rem;padding-bottom:.4rem;font-size:1.15rem}.detail-desc{color:var(--ink-2);max-width:72ch;line-height:1.6}.hl-grid{grid-template-columns:1fr;gap:.6rem;display:grid}@media (width>=560px){.hl-grid{grid-template-columns:1fr 1fr}}@media (width>=880px){.hl-grid{grid-template-columns:repeat(3,1fr)}}.hl{background:var(--panel);border:1px solid var(--border);border-left:3px solid var(--border-strong);border-radius:var(--radius);flex-direction:column;gap:.2rem;padding:.65rem .85rem;display:flex}.hl:nth-child(6n+1){border-left-color:#4a73b8}.hl:nth-child(6n+2){border-left-color:#3f9488}.hl:nth-child(6n+3){border-left-color:#b5853c}.hl:nth-child(6n+4){border-left-color:#8a5cc0}.hl:nth-child(6n+5){border-left-color:#c0604d}.hl:nth-child(6n+6){border-left-color:#5a9450}.hl-title{color:var(--ink);font-size:.92rem;font-weight:600}.hl-detail{color:var(--ink-3);font-size:.84rem;line-height:1.4}.abil-grid{grid-template-columns:1fr;gap:.85rem;display:grid}@media (width>=720px){.abil-grid{grid-template-columns:repeat(3,1fr)}}.abil{flex-direction:column;display:flex;overflow:hidden}.abil .media-frame{border:0;border-bottom:1px solid var(--border);border-radius:0}.abil-body{flex-direction:column;gap:.7rem;padding:.8rem .85rem;display:flex}.abil-head{align-items:center;gap:.5rem;display:flex}.abil-dot{border-radius:50%;flex:none;width:11px;height:11px}.abil-name{font-size:1.05rem;font-weight:700}.abil-blurb{color:var(--ink-2);font-size:.9rem;line-height:1.45}.abil-kv{grid-template-columns:auto 1fr;gap:.35rem .7rem;display:grid}.abil-kv dt{font-family:var(--mono);text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3);padding-top:.1rem;font-size:.68rem}.abil-kv dd{color:var(--ink-2);font-size:.86rem;line-height:1.4}.build-list{flex-direction:column;display:flex}.build-row{border-top:1px solid var(--border);grid-template-columns:1fr;gap:.7rem 1.5rem;padding:1.1rem 0;display:grid}.build-row:first-child{border-top:0;padding-top:0}@media (width>=720px){.build-row{grid-template-columns:minmax(0,1fr) minmax(0,.9fr);align-items:start}}.build-title{margin-bottom:.4rem;font-size:1rem}.build-body{color:var(--ink-2);max-width:64ch;font-size:.92rem;line-height:1.55}.build-media{align-self:start}.learn-list{flex-direction:column;gap:.5rem;max-width:72ch;display:flex}.learn-list li{color:var(--ink-2);padding-left:1.15rem;line-height:1.55;position:relative}.learn-list li:before{content:"";background:var(--link);border-radius:1px;width:5px;height:5px;position:absolute;top:.62em;left:0}.media-placeholder{text-align:center;aspect-ratio:16/9;border:1px dashed var(--border-strong);border-radius:var(--radius);background:var(--panel-alt);background-image:repeating-linear-gradient(45deg,#0000,#0000 9px,#00000005 9px 18px);justify-content:center;align-items:center;padding:.9rem 1rem;display:flex}.media-placeholder-label{font-family:var(--mono);letter-spacing:.03em;text-transform:uppercase;color:var(--ink-2);font-size:.76rem;font-weight:500}.build-more{margin-top:.85rem}.build-more>summary{cursor:pointer;-webkit-user-select:none;user-select:none;width:fit-content;font-family:var(--mono);text-transform:uppercase;letter-spacing:.04em;color:var(--ink-2);background:var(--panel-alt);border:1px solid var(--border-strong);border-radius:var(--radius);align-items:center;gap:.45rem;padding:.32rem .65rem;font-size:.72rem;list-style:none;transition:background .12s,border-color .12s,color .12s;display:inline-flex}.build-more>summary::-webkit-details-marker{display:none}.build-more>summary:before{content:"›";font-size:1rem;line-height:1;transition:transform .15s}.build-more[open]>summary:before{transform:rotate(90deg)}.build-more>summary:hover,.build-more>summary:focus-visible,.build-more[open]>summary{background:var(--row-hover);border-color:var(--link);color:var(--link-hover)}.build-more-body{border-left:2px solid var(--border-strong);margin-top:.7rem;padding-left:.85rem}.build-more-body .build-body+.build-body{margin-top:.5rem}.build-row-wide{grid-template-columns:1fr}.cmap{background:var(--panel);border:1px solid var(--border-strong);border-radius:var(--radius);flex-direction:column;margin-top:.2rem;display:flex;overflow:hidden}.cmap-row{border-top:1px solid var(--border);grid-template-columns:1fr;gap:.1rem 1.1rem;padding:.6rem .9rem;display:grid}.cmap-row:first-child{border-top:0}.cmap-name{font-family:var(--mono);color:var(--ink);font-size:.78rem;font-weight:600}.cmap-role{color:var(--ink-2);font-size:.86rem;line-height:1.4}@media (width>=560px){.cmap-row{grid-template-columns:160px 1fr;align-items:baseline}}.clip-expand{cursor:zoom-in;background:0 0;border:0;justify-content:flex-end;align-items:flex-end;width:100%;height:100%;margin:0;padding:0;display:flex;position:absolute;inset:0}.clip-expand-icon{color:#fff;border-radius:var(--radius);opacity:.55;background:#0000008c;border:1px solid #ffffff4d;place-items:center;width:2rem;height:2rem;margin:.5rem;transition:opacity .12s,background .12s;display:grid}.clip-expand:hover .clip-expand-icon,.clip-expand:focus-visible .clip-expand-icon{opacity:1;background:#000000b8}.clip-expand-icon svg{display:block}.lightbox{z-index:100;background:#000000d9;justify-content:center;align-items:center;padding:clamp(1rem,4vw,3rem);animation:.14s ease-out lightbox-fade;display:flex;position:fixed;inset:0}.lightbox-inner{width:min(1100px,100%);animation:.14s ease-out lightbox-pop}@keyframes lightbox-fade{0%{opacity:0}to{opacity:1}}@keyframes lightbox-pop{0%{opacity:0;transform:scale(.985)}to{opacity:1;transform:none}}@media (prefers-reduced-motion:reduce){.lightbox,.lightbox-inner{animation:none}}.lightbox-inner video{border-radius:var(--radius);background:#000;width:100%;height:auto;max-height:85vh;display:block}.lightbox-close{color:#fff;border-radius:var(--radius);cursor:pointer;background:#ffffff1a;border:1px solid #ffffff4d;width:2.4rem;height:2.4rem;font-size:1.7rem;line-height:1;position:absolute;top:.75rem;right:1rem}.lightbox-close:hover{background:#fff3}.detail-missing h1{margin-bottom:.75rem}.footer{border-top:1px solid var(--border-strong);background:var(--panel);margin-top:1.5rem;padding-block:1.1rem}.footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem 1.25rem;font-size:.86rem;display:flex}.footer-links{flex-wrap:wrap;gap:1.1rem;display:flex}.footer-meta{font-family:var(--mono);color:var(--ink-3);font-size:.8rem}.app{flex-direction:column;min-height:100vh;display:flex}.app main{flex:1}
