/* Work archive — masthead (Work pages don't load inner.css), index grid, album masonry, lightbox */

/* page-head masthead — ported from inner.css since Work pages don't load it */
.page-head { padding: clamp(72px, 9vw, 132px) 0 clamp(56px, 7vw, 92px); border-bottom: 1px solid var(--rule); }
.page-head-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: clamp(40px, 6vw, 96px); align-items: end; }
.page-head h1 { font-size: clamp(46px, 6.2vw, 100px); }
@media (max-width: 880px) { .page-head-grid { grid-template-columns: 1fr; } }

/* index */
.work-index { padding: clamp(40px, 6vw, 80px) 0 var(--section); }
.work-card-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: clamp(16px, 2vw, 28px);
}
.work-card { display: grid; gap: 14px; }
.work-card-photo { position: relative; aspect-ratio: 4/3; overflow: hidden; background: var(--paper-warm); display: block; }
.work-card-photo img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.work-card:hover .work-card-photo img { transform: scale(1.04); }
.work-card-meta { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; }
.work-card-name { font-family: var(--display); font-weight: 500; font-size: 19px; letter-spacing: -0.01em; }
.work-card-count { font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-mute); white-space: nowrap; }

/* album */
.work-album-head { display: grid; gap: 6px; }
.work-album { padding: clamp(32px, 4vw, 64px) 0 var(--section); }
.work-grid { columns: 4 240px; column-gap: 14px; }
.work-tile { display: block; margin: 0 0 14px; break-inside: avoid; position: relative; }
.work-thumb { width: 100%; height: auto; display: block; background-size: cover; background-position: center; }
.work-tile:focus-visible { outline: 2px solid var(--lime); outline-offset: 3px; }

/* lightbox */
.work-lb { position: fixed; inset: 0; z-index: 100; background: var(--ink-deep);
  display: none; align-items: center; justify-content: center; }
.work-lb.open { display: flex; }
.work-lb img { max-width: 92vw; max-height: 86vh; object-fit: contain; }
/* expanded: image fills the entire viewport (contain, no crop) */
.work-lb.filled img { max-width: none; max-height: none; width: 100vw; height: 100vh; object-fit: contain; }
.work-lb-close, .work-lb-prev, .work-lb-next, .work-lb-expand {
  position: absolute; background: none; border: 0; color: var(--paper); cursor: pointer;
  font-family: var(--display); font-size: 32px; padding: 16px; line-height: 1; }
.work-lb-close { top: 8px; right: 12px; }
.work-lb-expand { top: 8px; right: 60px; font-size: 26px; }
.work-lb-prev { left: 8px; top: 50%; transform: translateY(-50%); }
.work-lb-next { right: 8px; top: 50%; transform: translateY(-50%); }
.work-lb-counter { position: absolute; bottom: 18px; left: 0; right: 0; text-align: center;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; color: color-mix(in oklab, var(--paper) 70%, transparent); }
@media (prefers-reduced-motion: reduce) { .work-card-photo img { transition: none; } }
