.blog-content {
  font-size: 15px;
  line-height: 1.75;
}

.blog-content p {
  margin-bottom: 0.9rem;
}

/* Image gallery (TinyMCE often outputs <p><img>... patterns) */
.blog-content img {
  max-width: 100%;
  height: auto;
  border-radius: 14px;
  display: block;
  margin: 14px auto;
  cursor: zoom-in;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.10);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.blog-content img:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 30px rgba(15, 23, 42, 0.14);
}

/* 3-up grid when images are sequential */
.blog-content p:has(> img),
.blog-content figure:has(img),
.blog-content div:has(> img) {
  margin: 0;
}

.blog-content .blog-image-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin: 14px 0 18px;
}

.blog-content .blog-image-grid img {
  margin: 0;
  width: 100%;
  height: 170px;
  object-fit: cover;
}

@media (max-width: 992px) {
  .blog-content .blog-image-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }
  .blog-content .blog-image-grid img {
    height: 160px;
  }
}

@media (max-width: 576px) {
  .blog-content {
    font-size: 14px;
  }
  .blog-content img {
    border-radius: 12px;
    margin: 10px auto;
  }
  .blog-content .blog-image-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .blog-content .blog-image-grid img {
    height: auto;
  }
}

/* Modal image preview */
.blog-image-preview-modal .modal-content {
  background: transparent;
  border: 0;
}

.blog-image-preview-modal .modal-body {
  padding: 0;
}

.blog-image-preview-modal img {
  max-height: calc(100vh - 110px);
  width: auto;
}

