.cfp-art-grid-wrap { color: var(--camp-ash, #3b2a1a); }
.cfp-art-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 12px;
}
.cfp-art-grid-item {
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,.05);
}
.cfp-art-grid-item img { width: 100%; height: auto; display: block; }
.cfp-art-grid-title { padding: 8px 10px; font-size: .95rem; font-weight: 600; }

/* Lightbox */
.cfp-art-lightbox[aria-hidden="false"] { display: block; }
.cfp-art-lightbox[hidden] { display: none; }
.cfp-art-lightbox {
  position: fixed; inset: 0; background: rgba(0,0,0,.65);
  z-index: 9999; display: none;
}
.cfp-art-lightbox-inner {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
  background: #fbf5ef; color: var(--camp-ash, #3b2a1a);
  max-width: min(920px, 92vw); width: 100%;
  border-radius: 14px; overflow: hidden; box-shadow: 0 10px 30px rgba(0,0,0,.35);
}
.cfp-art-lightbox-img { width: 100%; height: auto; display: block; }
.cfp-art-lightbox-meta { padding: 12px 14px; }
.cfp-art-lightbox-title { font-weight: 700; margin-bottom: 6px; }
.cfp-art-lightbox-caption { opacity: .9; margin-bottom: 8px; }
.cfp-art-lightbox-link { font-weight: 600; border-bottom: 2px solid currentColor; text-decoration: none; }

.cfp-art-lightbox-close {
  position: absolute; right: 8px; top: 6px;
  background: transparent; border: 0; font-size: 28px; cursor: pointer; color: #333;
}
.cfp-art-lightbox-prev, .cfp-art-lightbox-next {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: rgba(0,0,0,.35); color: #fff; border: 0; width: 36px; height: 42px;
  border-radius: 8px; cursor: pointer; font-size: 24px;
}
.cfp-art-lightbox-prev { left: 10px; }
.cfp-art-lightbox-next { right: 10px; }
.cfp-art-lightbox-prev:hover, .cfp-art-lightbox-next:hover { background: rgba(0,0,0,.5); }
