.photo-hero .page-btn { margin-top: 28px; }
.photo-page { max-width: 1180px; }
.photo-intro { display: flex; justify-content: space-between; align-items: end; gap: 24px; margin-bottom: 34px; }
.photo-intro h2 { margin-bottom: 8px; }
.photo-intro p { margin: 0; }
.photo-feed { columns: 3 280px; column-gap: 20px; }
.photo-post { break-inside: avoid; margin: 0 0 20px; overflow: hidden; border: 1px solid rgba(7,8,22,.08); border-radius: 24px; background: #fff; box-shadow: 0 16px 42px rgba(7,8,22,.08); }
.photo-post img { display: block; width: 100%; height: auto; background: #e8e5dc; }
.photo-post-copy { padding: 18px; }
.photo-post-head { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.photo-avatar { width: 38px; height: 38px; display: grid; place-items: center; flex: 0 0 auto; border-radius: 50%; color: #fff; background: linear-gradient(135deg, #ff4f8b, #7c5cff); font-weight: 950; }
.photo-post-head span { display: block; color: #737684; font-size: .76rem; }
.photo-post-copy p { margin: 0 0 14px; color: #353745; }
.photo-like { border: 0; padding: 8px 12px; border-radius: 999px; background: rgba(7,8,22,.06); font: inherit; font-weight: 900; cursor: pointer; }
.photo-like.liked { color: #fff; background: #ff4f8b; }
.photo-like:disabled { cursor: default; }
.photo-empty, .photo-loading { column-span: all; padding: 38px; border-radius: 24px; background: rgba(255,255,255,.75); text-align: center; }
.photo-upload { margin-top: 80px; padding: clamp(24px, 5vw, 52px); display: grid; grid-template-columns: .8fr 1.2fr; gap: 48px; border-radius: 32px; color: #fff; background: #070816; }
.photo-upload h2 { margin-top: 12px; }
.photo-upload p { color: rgba(255,255,255,.7); }
#photo-form { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
#photo-form label { display: grid; gap: 6px; color: rgba(255,255,255,.72); font-size: .8rem; font-weight: 850; }
#photo-form label span { font-weight: 500; }
#photo-form input, #photo-form textarea { width: 100%; border: 1px solid rgba(255,255,255,.14); border-radius: 14px; padding: 12px; color: #fff; background: rgba(255,255,255,.08); font: inherit; }
#photo-form textarea { min-height: 110px; resize: vertical; }
#photo-form label:nth-child(3), .photo-picker, #photo-preview, .photo-consent, #photo-form button, #photo-message { grid-column: 1 / -1; }
.photo-picker input { padding: 16px !important; }
#photo-preview { max-width: 100%; max-height: 360px; border-radius: 18px; object-fit: contain; background: #000; }
#photo-form .photo-consent { display: flex; align-items: flex-start; gap: 8px; }
#photo-form .photo-consent input { width: auto; margin-top: 4px; }
#photo-message { margin: 0; font-weight: 850; }
.admin-photo img { display: block; max-width: 100%; max-height: 420px; margin-bottom: 20px; border-radius: 18px; object-fit: contain; background: #eee; }
@media (max-width: 760px) {
  .photo-intro { align-items: flex-start; flex-direction: column; }
  .photo-upload { grid-template-columns: 1fr; gap: 24px; }
  #photo-form { grid-template-columns: 1fr; }
  #photo-form label { grid-column: 1 !important; }
}
