.lv-gallery-section {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px dashed var(--jr-gray-200);
}
.lv-gallery-count {
  font-size: 11.5px;
  color: var(--jr-gray-500);
  font-weight: 500;
  margin-left: auto;
}

/* ============================================================
   Just Pitch — Per-venue photo gallery slide + form section
   ============================================================ */


/* ============== Slide (rendered in deck) ============== */
.slide.venue-gallery {
  display: flex;
  flex-direction: column;
  background: #fff;
  padding: 56px 64px 32px;
  position: relative;
  height: 100%;
}

.slide.venue-gallery .vg-header {
  margin-bottom: 28px;
  flex-shrink: 0;
}
.slide.venue-gallery .vg-eyebrow {
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--jr-blue);
  margin-bottom: 6px;
}
.slide.venue-gallery .vg-title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 42px;
  letter-spacing: -.01em;
  margin: 0 0 4px;
  color: var(--jr-blue-900);
  line-height: 1.05;
}
.slide.venue-gallery .vg-sub {
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--jr-gray-600);
  margin: 0;
  font-weight: 500;
  letter-spacing: .01em;
}

.slide.venue-gallery .vg-grid {
  flex: 1;
  display: grid;
  gap: 14px;
  min-height: 0;
  grid-template-rows: minmax(0, 1fr);
}
.slide.venue-gallery .vg-grid.cols-1 { grid-template-columns: 1fr; }
.slide.venue-gallery .vg-grid.cols-2 { grid-template-columns: repeat(2, 1fr); }
.slide.venue-gallery .vg-grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
.slide.venue-gallery .vg-grid.cols-4 { grid-template-columns: repeat(4, 1fr); }

/* Auto-rows when there's more than one row */
.slide.venue-gallery .vg-grid.count-4  { grid-template-rows: repeat(2, 1fr); }
.slide.venue-gallery .vg-grid.count-5,
.slide.venue-gallery .vg-grid.count-6  { grid-template-rows: repeat(2, 1fr); }
.slide.venue-gallery .vg-grid.count-7,
.slide.venue-gallery .vg-grid.count-8,
.slide.venue-gallery .vg-grid.count-9  { grid-template-rows: repeat(3, 1fr); }
.slide.venue-gallery .vg-grid.count-10,
.slide.venue-gallery .vg-grid.count-11,
.slide.venue-gallery .vg-grid.count-12 { grid-template-rows: repeat(3, 1fr); }

.slide.venue-gallery .vg-cell {
  position: relative;
  margin: 0;
  border-radius: 8px;
  overflow: hidden;
  background: var(--jr-gray-100);
  display: flex;
  flex-direction: column;
}
.slide.venue-gallery .vg-cell.single { aspect-ratio: 16 / 9; max-height: 100%; }

.slide.venue-gallery .vg-img {
  flex: 1;
  min-height: 0;
  background-size: cover;
  background-position: center;
  background-color: var(--jr-gray-200);
}
.slide.venue-gallery .vg-cell figcaption {
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 600;
  color: var(--jr-gray-700);
  padding: 6px 10px 8px;
  background: #fff;
  letter-spacing: .01em;
  border-top: 1px solid var(--jr-gray-100);
}

.slide.venue-gallery .footer-bar { flex-shrink: 0; margin-top: 18px; }


/* ============== Form panel — gallery editor ============== */
.sub-block-hint {
  font-weight: 500;
  font-size: 11.5px;
  color: var(--jr-gray-500);
  letter-spacing: 0;
  text-transform: none;
  margin-left: 8px;
}
.sub-block-head { display: flex; align-items: baseline; flex-wrap: wrap; }

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 10px;
  margin: 12px 0;
}
.gallery-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.gallery-thumb {
  position: relative;
  aspect-ratio: 4 / 3;
  border-radius: 6px;
  background: var(--jr-gray-100);
  background-size: cover;
  background-position: center;
  overflow: hidden;
  border: 1px solid var(--jr-gray-200);
}
.gallery-thumb-ph {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-size: 11px;
  color: var(--jr-gray-500);
  font-weight: 600;
}
.gallery-thumb-overlay {
  position: absolute;
  inset: auto 0 0 0;
  display: flex;
  justify-content: center;
  gap: 4px;
  padding: 6px;
  background: linear-gradient(180deg, transparent, rgba(15, 40, 60, .6));
  opacity: 0;
  transition: opacity var(--dur-fast);
}
.gallery-thumb:hover .gallery-thumb-overlay { opacity: 1; }
.g-overlay-btn {
  background: rgba(255, 255, 255, .92);
  color: var(--jr-blue-900);
  border: none;
  width: 24px;
  height: 24px;
  border-radius: 4px;
  font-size: 14px;
  line-height: 1;
  font-weight: 700;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: background var(--dur-fast);
}
.g-overlay-btn:hover:not(:disabled) { background: #fff; }
.g-overlay-btn:disabled { opacity: .35; cursor: not-allowed; }
.g-overlay-btn.danger { color: #B0473D; }
.g-overlay-btn.danger:hover:not(:disabled) { background: #fff; color: #7F1D1D; }

.gallery-caption {
  font-family: var(--font-sans);
  font-size: 11.5px;
  padding: 5px 8px;
  border: 1px solid var(--jr-gray-200);
  border-radius: 4px;
  color: var(--jr-gray-800);
  background: #fff;
  width: 100%;
  transition: border-color var(--dur-fast);
}
.gallery-caption:focus {
  outline: none;
  border-color: var(--jr-blue);
}

.gallery-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.gallery-actions .btn-add {
  font-size: 12px;
  padding: 7px 12px;
}
.gallery-actions .btn-add.ghost {
  background: transparent;
  color: var(--jr-blue-700);
  border: 1px solid var(--jr-gray-300);
}
.gallery-actions .btn-add.ghost:hover { background: var(--jr-gray-50); border-color: var(--jr-blue); }

/* ===== Gallery on/off toggle ===== */
.gallery-sub-block .sub-block-head {
  gap: 10px;
}
.gallery-sub-block.is-disabled .gallery-grid {
  opacity: .5;
  filter: grayscale(0.4);
}
.gallery-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  user-select: none;
}
.gallery-toggle input { display: none; }
.gallery-toggle-track {
  width: 30px;
  height: 17px;
  border-radius: 99px;
  background: var(--jr-gray-300);
  position: relative;
  transition: background var(--dur-fast);
}
.gallery-toggle-thumb {
  position: absolute;
  top: 2px;
  left: 2px;
  width: 13px;
  height: 13px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 1px 2px rgba(0, 0, 0, .15);
  transition: transform var(--dur-fast);
}
.gallery-toggle input:checked ~ .gallery-toggle-track { background: var(--jr-blue); }
.gallery-toggle input:checked ~ .gallery-toggle-track .gallery-toggle-thumb { transform: translateX(13px); }
.gallery-toggle-label {
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--jr-gray-700);
}
.gallery-sub-block.is-disabled .gallery-toggle-label { color: var(--jr-gray-500); }

