/**
 * Post list layout variants: list (default), compact, pinterest, instagram.
 * Apply to a container with class .posts-list and .posts-list--{layout}.
 * Post cards inside must use .post-card__author, .post-card__body, .post-card__media, .post-card__link-card, .post-card__quote.
 */

/* Wrapper is a real box for list/compact/pinterest (sortable); only contents in Instagram (grid) */
.posts-list--instagram .post-card-outer.post-card-outer--instagram {
  display: contents;
}

.post-card-outer {
  min-width: 0;
}

/* List layout: constrain width and centre */
.posts-list--list.posts-list {
  max-width: 575px;
  margin-left: auto;
  margin-right: auto;
}

/* Layout switcher: icon-only buttons (radio style) */
.post-layout-switcher .post-layout-btn {
  padding: 0.35rem 0.5rem;
}
.post-layout-switcher .post-layout-icon {
  width: 1.25rem;
  height: 1.25rem;
  display: block;
}

/* ---------------------------------------------------------------------------
   Compact: author, text and date on LHS; all embeds (media, link card, quote) on RHS
   --------------------------------------------------------------------------- */
.posts-list--compact .post-card .post-content-link {
  display: grid;
  grid-template-columns: 1fr 140px;
  gap: 0.5rem;
  align-items: start;
}

/* LHS column */
.posts-list--compact .post-card__main {
  grid-column: 1;
  grid-row: 1;
  min-width: 0;
}

.posts-list--compact .post-card__date {
  grid-column: 1;
  grid-row: 3;
  margin-bottom: 0 !important;
}

.posts-list--compact .post-card__comment {
  grid-column: 1;
  grid-row: 2;
}

.posts-list--compact .post-main-alpine .post-card__body p {
  margin-bottom: 0 !important;
}

/* RHS column: all embeds stacked */
.posts-list--compact .post-card__media {
  grid-column: 2;
  grid-row: 1;
  margin-bottom: 0 !important;
  max-width: 140px;
  min-width: 0;
}

.posts-list--compact .post-card__media.post-images {
  display: flex !important;
  flex-wrap: wrap;
  gap: 2px;
  margin-bottom: 0 !important;
}

/* 4 images: 2x2 grid in compact, same 44px cell size as other rows */
.posts-list--compact .post-card__media[data-media-count="4"].post-images {
  display: grid !important;
  grid-template-columns: 44px 44px;
  grid-template-rows: 44px 44px;
  gap: 2px;
}

.posts-list--compact .post-card__media .image-container,
.posts-list--compact .post-card__media .video-thumbnail {
  width: 44px !important;
  max-width: 44px !important;
  min-width: 44px;
  aspect-ratio: 1;
  padding: 0 !important;
  margin: 0 !important;
}

.posts-list--compact .post-card__media[data-media-count="4"] .image-container,
.posts-list--compact .post-card__media[data-media-count="4"] .video-thumbnail,
.posts-list--compact .post-card__media[data-media-count="4"] .d-inline-block {
  width: 44px !important;
  max-width: 44px !important;
  min-width: 44px;
}

.posts-list--compact .post-card__media .image-container img,
.posts-list--compact .post-card__media .video-thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 4px;
}

/* Link card underneath (full width), thin thumbnail */
.posts-list--compact .post-card__link-card {
  grid-column: 1 / -1;
  grid-row: 4;
  max-width: 100%;
  margin: 0.25rem 0 0 !important;
  min-width: 0;
}

.posts-list--compact .post-card__link-card .link-card-wrapper {
  display: flex !important;
  flex-direction: row;
  align-items: stretch;
  gap: 0.5rem;
}

.posts-list--compact .post-card__link-card .link-card-thumbnail {
  width: 56px;
  min-width: 56px;
  height: 56px;
  flex-shrink: 0;
  overflow: hidden;
}

.posts-list--compact .post-card__link-card .link-card-content {
  flex: 1;
  min-width: 0;
  padding: 0.35rem 0.5rem !important;
}

.posts-list--compact .post-card__link-card .link-card-title {
  font-size: 13px !important;
  margin-bottom: 0.15rem !important;
}

.posts-list--compact .post-card__link-card .link-card-description {
  -webkit-line-clamp: 1;
  margin-bottom: 0 !important;
}

.posts-list--compact .post-card__quote {
  grid-column: 1 / -1;
  grid-row: 5;
  max-width: 100%;
  margin-top: 0.25rem !important;
  padding: 0.4rem 0.5rem !important;
  min-width: 0;
}

.posts-list--compact .post-card__quote .rounded-circle {
  width: 16px !important;
  height: 16px !important;
}

/* ---------------------------------------------------------------------------
   Pinterest: narrow cards, media on top; 2/3/4 image layouts
   --------------------------------------------------------------------------- */
.posts-list--pinterest.posts-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1rem;
}

.posts-list--pinterest .post-card {
  break-inside: avoid;
  margin-bottom: 0 !important;
  min-width: 0;
  overflow: hidden;
}

.posts-list--pinterest .post-card .card-body {
  position: relative;
  display: flex;
  flex-direction: column;
  padding: 0.5rem !important;
  min-width: 0;
  overflow: hidden;
}

.posts-list--pinterest .post-card .card-body > .d-flex {
  min-width: 0;
}

/* Action buttons float top-right inside the card in gallery mode */
.posts-list--pinterest .post-card .post-actions.saved-post-actions {
  position: absolute;
  top: 0.25rem;
  right: 0.25rem;
  margin: 0;
  z-index: 2;
  background: rgba(255, 255, 255, 0.92);
  border-radius: 6px;
  padding: 0.15rem 0.2rem;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.posts-list--pinterest .post-card .post-actions .btn,
.posts-list--pinterest .post-card .post-actions .btn-group .btn {
  padding: 0.2rem 0.35rem;
}

.posts-list--pinterest .post-card .post-content-link {
  display: flex;
  flex-direction: column;
  order: 0;
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
}

/* Contain embeds wrapper (overrides post-embeds-alpine max-width in gallery) */
.posts-list--pinterest .post-card .post-embeds-alpine,
.posts-list--pinterest .post-card .post-card__embeds {
  max-width: 100% !important;
  min-width: 0;
}

.posts-list--pinterest .post-card__media {
  order: 1;
  margin-bottom: 0.5rem !important;
  max-width: 100%;
  min-width: 0;
  overflow: hidden;
}

.posts-list--pinterest .post-card__media.post-images {
  display: grid !important;
  gap: 2px;
  margin-bottom: 0 !important;
  min-width: 0;
  max-width: 100%;
}


.posts-list--pinterest .post-card__media .image-container,
.posts-list--pinterest .post-card__media .video-thumbnail,
.posts-list--pinterest .post-card__media .d-inline-block {
  aspect-ratio: 1;
  overflow: hidden;
  padding: 0 !important;
  margin: 0 !important;
  min-width: 0;
  max-width: 100% !important;
  width: 100% !important;
}

/* 2 images: side by side */
.posts-list--pinterest .post-card__media[data-media-count="2"].post-images {
  grid-template-columns: 1fr 1fr;
}


/* 3 images: one main, row of two underneath */
.posts-list--pinterest .post-card__media[data-media-count="3"].post-images {
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
}

.posts-list--pinterest .post-card__media[data-media-count="3"].post-images > *:first-child {
  grid-column: 1 / -1;
}

/* 4 images: 2x2 grid */
.posts-list--pinterest .post-card__media[data-media-count="4"].post-images {
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
}


.posts-list--pinterest .post-card__media .image-container img,
.posts-list--pinterest .post-card__media .video-thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  max-width: 100%;
  display: block;
}

.posts-list--pinterest .post-card__media .video-thumbnail {
  max-width: 100% !important;
}

/* Link card: stay within card width */
.posts-list--pinterest .post-card__link-card {
  max-width: 100%;
  min-width: 0;
  overflow: hidden;
  order: 1;
}

.posts-list--pinterest .post-card__link-card .link-card-thumbnail img {
  max-width: 100%;
  object-fit: cover;
}

.posts-list--pinterest .post-card__main {
  order: 2;
}

.posts-list--pinterest .post-card__link-card {
  margin-bottom: 0.25rem !important;
}

.posts-list--pinterest .post-card__quote {
  order: 4;
  margin-top: 0.25rem !important;
  max-width: 100%;
  min-width: 0;
  overflow: hidden;
}

.posts-list--pinterest .post-card__comment {
  order: 5;
}

.posts-list--pinterest .post-card__date {
  order: 6;
}

/* Pinterest: hide drag handle when in pinterest layout to avoid clutter; optional */
.posts-list--pinterest .collection-drag-handle {
  order: 0;
}

/* ---------------------------------------------------------------------------
   Instagram: grid of images only; no post details; click opens post in Bluesky
   --------------------------------------------------------------------------- */
.posts-list--instagram.posts-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
}

/* Thumbnail cell in grid */
.posts-list--instagram .instagram-thumb-cell {
  aspect-ratio: 1;
  overflow: hidden;
  cursor: pointer;
  position: relative;
  background: var(--bs-secondary-bg, #f0f0f0);
  border-radius: 4px;
}

.posts-list--instagram .instagram-thumb-cell img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.posts-list--instagram .instagram-thumb-cell .play-icon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 1.5rem;
  color: rgba(255, 255, 255, 0.9);
  pointer-events: none;
}
