.page-head .lead { font-size: 18px; color: var(--ink-2); max-width: 680px; line-height: 1.6; }
.ph-stats { display: flex; gap: 44px; margin-top: 30px; flex-wrap: wrap; }
.ph-stats .stat { display: flex; flex-direction: column; gap: 2px; }
.ph-stats .stat b { font-size: clamp(26px, 3.4vw, 36px); font-weight: 900; color: var(--blue-600); letter-spacing: -.02em; }
.ph-stats .stat span { font-size: 13.5px; font-weight: 600; color: var(--muted); }

.gallery-wrap { padding: 38px 0 96px; }
.gallery-bar { display: flex; align-items: center; justify-content: space-between; gap: 20px; margin-bottom: 30px; flex-wrap: wrap; }
.filters { display: flex; gap: 10px; flex-wrap: wrap; }
.filter-chip { font-family: inherit; font-size: 14px; font-weight: 700; color: var(--ink-2); background: #fff; border: 1.5px solid var(--line); padding: 10px 18px; border-radius: var(--r-pill); cursor: pointer; transition: .15s; }
.filter-chip:hover { border-color: var(--blue); color: var(--blue-600); }
.filter-chip.active { background: var(--blue); border-color: var(--blue); color: #fff; box-shadow: var(--sh-blue); }
.g-count { font-size: 14.5px; color: var(--muted); font-weight: 600; white-space: nowrap; }
.g-count b { color: var(--ink); }

/* masonry */
.masonry { columns: 4; column-gap: 20px; }
@media (max-width: 1320px) { .masonry { columns: 3; } }
@media (max-width: 980px)  { .masonry { columns: 2; } }
@media (max-width: 520px)  { .masonry { columns: 1; } }

.show-card { position: relative; display: block; break-inside: avoid; margin-bottom: 20px; border-radius: var(--r); overflow: hidden; box-shadow: var(--sh-sm); background: #fff; transition: transform .2s ease, box-shadow .2s ease; }
.show-card:hover { transform: translateY(-4px); box-shadow: var(--sh-lg); }
.show-card.is-hidden { display: none; }

.show-card .shot { position: relative; background-color: #12314c; background-image: repeating-linear-gradient(-45deg, rgba(255,255,255,.05) 0 13px, transparent 13px 26px); display: grid; place-items: center; }
.show-card .shot-lbl { font-family: ui-monospace, Menlo, monospace; font-size: 12px; font-weight: 600; color: rgba(255,255,255,.72); background: rgba(0,0,0,.28); padding: 6px 12px; border-radius: var(--r-pill); text-align: center; max-width: 78%; margin-bottom: 46px; }
.t-a .shot { aspect-ratio: 3/4; }
.t-b .shot { aspect-ratio: 4/3; }
.t-c .shot { aspect-ratio: 1/1; }
.t-d .shot { aspect-ratio: 4/4.6; }

.cat-badge { position: absolute; top: 12px; left: 12px; background: rgba(255,255,255,.94); color: var(--blue-700); font-size: 11.5px; font-weight: 800; letter-spacing: .02em; padding: 5px 11px; border-radius: var(--r-pill); backdrop-filter: blur(4px); }

.card-cap { position: absolute; left: 0; right: 0; bottom: 0; padding: 46px 16px 15px; color: #fff; background: linear-gradient(to top, rgba(7,18,30,.94) 0%, rgba(7,18,30,.55) 52%, transparent 100%); }
.card-cap h3 { font-size: 16.5px; font-weight: 800; color: #fff; line-height: 1.25; letter-spacing: -.01em; }
.cap-meta { display: flex; align-items: center; gap: 8px; margin-top: 6px; font-size: 12.5px; font-weight: 600; color: rgba(255,255,255,.82); }
.cap-meta .dot { width: 3px; height: 3px; border-radius: 50%; background: rgba(255,255,255,.5); flex: none; }
.view-hint { display: inline-flex; align-items: center; gap: 6px; margin-top: 11px; font-size: 13px; font-weight: 800; color: #5FC7F0; max-height: 0; opacity: 0; overflow: hidden; transform: translateY(4px); transition: .22s ease; }
.view-hint svg { width: 15px; height: 15px; }
.show-card:hover .view-hint { max-height: 24px; opacity: 1; transform: none; }

.helpbar2 { margin-top: 44px; background: var(--sky); border-radius: var(--r-lg); padding: 34px 40px; display: flex; align-items: center; justify-content: space-between; gap: 28px; flex-wrap: wrap; }
.helpbar2 .hb-copy h3 { font-size: 22px; margin-bottom: 8px; }
.helpbar2 .hb-copy p { color: var(--ink-2); font-size: 15px; max-width: 480px; }
.g-empty { text-align: center; color: var(--muted); font-size: 15px; padding: 60px 20px; }

@media (max-width: 720px) {
  .ph-stats { gap: 28px; }
  .helpbar2 { padding: 26px 22px; }
}
