.proj-head{margin-top:var(--nav-h);padding:16px 32px 20px;display:flex;align-items:baseline;justify-content:space-between;gap:24px}.proj-title{font-family:var(--display);font-size:clamp(36px,6vw,72px);font-weight:400;text-transform:uppercase;letter-spacing:.01em;line-height:.95}.proj-meta{display:flex;gap:24px;align-items:baseline;flex-shrink:0}.proj-meta span{font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--dim);transition:letter-spacing .4s var(--expo),color .25s ease;cursor:default}.proj-meta span:hover{letter-spacing:.14em;color:var(--fg)}.gallery{padding:40px 32px 0;display:flex;flex-direction:column}.g-row{display:flex;gap:20px;align-items:flex-start;margin-bottom:28px}.g-row:last-child{margin-bottom:0}.g-img{overflow:hidden;opacity:0;transform:translateY(20px);transition:opacity .7s var(--expo),transform .7s var(--expo)}.g-img.vis{opacity:1;transform:translateY(0)}.g-img img{width:100%;height:auto;display:block;cursor:pointer}.g-full .g-img{flex:0 0 100%}.g-pair .g-img{flex:1 1}.g-pair-wide .g-img:first-child{flex:0 0 62%}.g-pair-narrow .g-img:first-child,.g-pair-wide .g-img:last-child{flex:1 1}.g-pair-narrow .g-img:last-child{flex:0 0 62%}.g-trio .g-img{flex:1 1}.g-cinematic{margin:20px -32px;padding:0}.g-cinematic .g-img{flex:0 0 100%}.g-cinematic img{width:100vw;max-width:100vw}.credits{margin-top:0;margin-bottom:60px;padding:0 32px;border-top:1px solid rgba(0,0,0,.12)}.credits.open{padding-bottom:32px}.credits-toggle{display:flex;align-items:center;justify-content:space-between;padding:10px 0;cursor:pointer;background:none;border:none;width:100%;font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--fg);transition:color .2s}.credits-toggle:hover{color:var(--fg)}.credits-toggle:hover .credits-icon{transform:rotate(90deg)}.credits-icon{font-size:14px;transition:transform .35s var(--expo);line-height:1}.credits.open .credits-icon{transform:rotate(45deg)}.credits.open .credits-toggle:hover .credits-icon{transform:rotate(90deg)}.credits-body{max-height:0;overflow:hidden;transition:max-height .4s var(--expo),opacity .3s ease;opacity:0}.credits.open .credits-body{max-height:200px;opacity:1}.credits-list{display:flex;flex-wrap:wrap;gap:4px 28px;font-size:10px;color:var(--dim2);letter-spacing:.03em;padding-bottom:16px}.proj-banner{position:fixed;bottom:0;left:0;right:0;height:34px;display:flex;align-items:center;justify-content:space-between;padding:0 28px;background:hsla(48,20%,95%,.9);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--line);z-index:150;transform:translateY(100%);transition:transform .45s var(--expo)}.proj-banner.show{transform:translateY(0)}.proj-banner-title{font-family:var(--display);font-size:15px;text-transform:uppercase;letter-spacing:.02em}.proj-banner-meta{display:flex;gap:20px}.proj-banner-meta span{font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--dim)}.lightbox{position:fixed;inset:0;z-index:500;background:hsla(0,0%,4%,.95);display:flex;align-items:center;justify-content:center;cursor:zoom-out}.lightbox img{max-width:92vw;max-height:90vh;object-fit:contain}.lightbox-close{position:absolute;top:20px;right:24px;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:#888;cursor:pointer;transition:color .2s;background:none;border:none;font-family:var(--mono)}.lightbox-close:hover{color:#fff}@media (max-width:768px){.proj-head{flex-direction:column;gap:12px;padding:12px 20px 16px}.proj-meta{gap:16px}.g-row{flex-direction:column;gap:14px}.g-pair-narrow .g-img:first-child,.g-pair-narrow .g-img:last-child,.g-pair-wide .g-img:first-child,.g-pair-wide .g-img:last-child{flex:0 0 100%}.credits{padding:0 20px}.gallery{padding:24px 20px 0}.g-cinematic{margin:12px -20px}.proj-banner{padding:0 16px}}