.projects{padding-block:clamp(56px,9vh,120px) clamp(36px,5vh,64px)}.proj-head{display:flex;flex-direction:column;gap:14px;max-width:720px;margin-bottom:clamp(28px,4vh,52px)}.proj-title{font-family:var(--font-sans);font-weight:700;font-size:clamp(36px,6vw,80px);line-height:.95;letter-spacing:-.045em;margin:0;color:var(--text-1)}.proj-lede{color:var(--text-2);margin:0;max-width:60ch;font-size:15px}.fp-section{margin-bottom:clamp(40px,6vh,64px)}.fp-heading{display:flex;align-items:center;gap:14px;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.2em;color:var(--accent);font-weight:600;margin:0 0 20px}.fp-heading:before{content:"";width:28px;height:1.5px;background:var(--accent);flex-shrink:0}.fp-heading:after{content:"";flex:1;height:1px;background:var(--hairline)}.fp-carousel{display:flex;flex-direction:column;gap:12px}.fp-stage{position:relative;width:100%;aspect-ratio:21 / 9;border-radius:16px;overflow:hidden;border:1px solid var(--hairline);background:var(--surface-2)}.fp-slide{position:absolute;inset:0;width:100%;height:100%;border:none;padding:0;cursor:none;background:none}.fp-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--ease-out)}.fp-slide:hover .fp-img{transform:scale(1.03)}.fp-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.78) 0%,rgba(0,0,0,.3) 40%,transparent 70%);display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-start;padding:clamp(18px,3vw,32px);gap:4px;pointer-events:none}.fp-sub{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;color:#ffffff8c;margin:0;text-transform:uppercase}.fp-title{font-family:var(--font-sans);font-weight:700;font-size:clamp(22px,2.8vw,36px);color:#fff;letter-spacing:-.025em;line-height:1.1;margin:0}.fp-cta{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;color:var(--accent);opacity:0;transform:translateY(5px);transition:opacity .22s var(--ease-out),transform .22s var(--ease-out);margin-top:2px}.fp-slide:hover .fp-cta{opacity:1;transform:translateY(0)}.fp-progress{position:absolute;bottom:0;left:0;height:2px;width:100%;background:var(--accent);transform-origin:left center;pointer-events:none}.fp-dots{display:flex;gap:6px;justify-content:center;padding:2px 0}.fp-dot{width:6px;height:6px;border-radius:999px;border:none;padding:0;background:var(--text-3);cursor:none;transition:background .2s var(--ease-out),width .25s var(--ease-out)}.fp-dot.is-active{background:var(--accent);width:22px}@media(max-width:640px){.fp-stage{aspect-ratio:16 / 9}}.all-projects-head{display:flex;align-items:center;gap:16px;margin-bottom:20px}.all-projects-head:after{content:"";flex:1;height:1px;background:var(--hairline)}.all-projects-label{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--text-3);margin:0;font-weight:500;flex-shrink:0}@media(max-width:600px){.fp-grid{grid-template-columns:1fr}}.pg-pills{display:flex;flex-wrap:wrap;gap:4px;padding:4px;border:1px solid var(--hairline);border-radius:999px;background:color-mix(in oklab,var(--surface-2) 60%,transparent);width:max-content;margin-bottom:clamp(24px,4vh,40px)}.pg-pills-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.pg-pills-scroll::-webkit-scrollbar{display:none}.pg-pill{position:relative;padding:8px 16px;border:none;background:transparent;color:var(--text-2);font-size:12.5px;font-weight:500;border-radius:999px;cursor:none;transition:color .2s var(--ease-out)}.pg-pill:hover,.pg-pill.is-active{color:var(--text-1)}.pg-pill-bg{position:absolute;inset:0;background:var(--accent-soft);border-radius:999px;z-index:0}.pg-pill-label{position:relative;z-index:1}.pg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:18px}.pg-cell{display:flex}.pcard{position:relative;display:grid;grid-template-columns:128px 1fr;gap:18px;padding:18px 18px 56px;width:100%;border-radius:14px;border:1px solid var(--hairline);background:color-mix(in oklab,var(--surface-2) 50%,transparent);backdrop-filter:blur(2px);transition:border-color .22s var(--ease-out),background .22s var(--ease-out)}.pcard:hover{border-color:var(--hairline-2);background:color-mix(in oklab,var(--surface-2) 80%,transparent)}.pcard-image{width:128px;height:104px;overflow:hidden;border-radius:10px;background:var(--surface-3, var(--surface-2));border:1px solid var(--hairline)}.pcard-image img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .38s var(--ease-out)}.pcard:hover .pcard-image img{transform:scale(1.04)}.pcard-image-fallback{display:grid;place-items:center;background:linear-gradient(135deg,color-mix(in oklab,var(--accent) 12%,transparent),color-mix(in oklab,var(--text-3) 8%,transparent))}.pcard-fallback-num{font-family:var(--font-mono);font-size:36px;color:var(--text-3);letter-spacing:.04em}.pcard-body{min-width:0;display:flex;flex-direction:column}.pcard-header{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:6px}.pcard-title{font-family:var(--font-sans);font-weight:600;font-size:17px;line-height:1.2;letter-spacing:-.015em;margin:0;color:var(--text-1);min-width:0}.pcard-period{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);flex-shrink:0}.pcard-blurb{margin:0;color:var(--text-2);font-size:13px;line-height:1.5}.pcard-tags{list-style:none;margin:12px 0 0;padding:0;display:flex;flex-wrap:wrap;gap:4px 12px}.pcard-tags li{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3)}.pcard-tags li:before{content:"·";margin-right:12px;color:var(--text-3)}.pcard-tags li:first-child:before{content:"";margin:0}.pcard-actions{position:absolute;bottom:14px;right:14px;display:inline-flex;gap:8px}.pcard-code,.pcard-watch{display:inline-flex;align-items:center;gap:6px;padding:7px 12px 7px 10px;border-radius:999px;font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;text-decoration:none;cursor:none;transition:transform .2s var(--ease-out),border-color .2s var(--ease-out),color .2s var(--ease-out),box-shadow .2s var(--ease-out)}.pcard-code{background:color-mix(in oklab,var(--surface-2) 80%,transparent);color:var(--text-1);border:1px solid var(--hairline-2)}.pcard-code:hover{transform:translateY(-2px);border-color:var(--accent);color:var(--accent)}.pcard-watch{background:var(--accent);color:#fff;box-shadow:0 6px 18px color-mix(in oklab,var(--accent) 35%,transparent)}.pcard-watch:hover{transform:translateY(-2px) scale(1.04);box-shadow:0 10px 24px color-mix(in oklab,var(--accent) 45%,transparent)}.pcard-code svg,.pcard-watch svg{display:block;width:13px;height:13px}@keyframes card-glow{0%{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in oklab,var(--accent) 60%,transparent),0 0 28px color-mix(in oklab,var(--accent) 35%,transparent)}65%{border-color:color-mix(in oklab,var(--accent) 60%,var(--hairline));box-shadow:0 0 0 1px color-mix(in oklab,var(--accent) 25%,transparent),0 0 12px color-mix(in oklab,var(--accent) 15%,transparent)}to{border-color:var(--hairline);box-shadow:none}}.pg-cell.is-highlighted .pcard{animation:card-glow 2s var(--ease-out) forwards}@media(max-width:720px){.pcard{grid-template-columns:1fr;padding:18px 18px 56px}.pcard-image{width:100%;height:180px}.pcard-actions{bottom:10px;right:10px}.pcard-code,.pcard-watch{padding:6px 10px 6px 8px;font-size:9.5px}.pg-grid{grid-template-columns:1fr}.pg-pills{flex-wrap:nowrap;width:max-content}.pg-pill{white-space:nowrap}}@media(max-width:480px){.pcard{padding:16px}.pcard-actions{position:static;margin-top:14px;justify-content:flex-end}.pcard-image{height:160px}.pcard-title{font-size:16px}.pcard-blurb{font-size:12.5px}.pcard-code,.pcard-watch{padding:6px 10px 6px 8px;font-size:9px}}
