/* images/cover-masonry.css */

/* =========================================================
   hELLO Cover: Masonry Stable
   - 티스토리 커버 썸네일 사용
   - JS fetch 없음
   - 썸네일 비율 유지
   - hover 시 제목 표시
   - 화면 폭에 따라 최소 1열 ~ 최대 5열
   - 전용 클래스만 사용하여 hELLO 기본 모듈과 충돌 방지
========================================================= */

/* 커버 전체: 기존 1100px 제한을 풀고 main 영역 전체 사용 */
[data-cover-name="masonry"].cover-masonry-full {
  width: 100%;
  max-width: none;
  padding: 0;
  margin: 0;
}

/* 커버 제목 */
[data-cover-name="masonry"] .cover-masonry-header {
  padding: 0 1rem;
}

[data-cover-name="masonry"] .cover-masonry-heading {
  min-height: var(--h-h);
  display: flex;
  align-items: center;
  font-size: 1.875rem;
  line-height: 1.25;
  font-weight: 700;
  color: rgb(41 42 45);
}

.dark [data-cover-name="masonry"] .cover-masonry-heading {
  color: rgb(244 244 246);
}

[data-cover-name="masonry"] .cover-masonry-heading:empty {
  display: none;
}

/* Masonry 레이아웃: 최소 1열 ~ 최대 5열 */
[data-cover-name="masonry"] .cover-masonry-grid {
  display: block;
  width: 100%;
  column-count: 1;
  column-gap: 0;
}

/* 태블릿 */
@media (min-width: 640px) {
  [data-cover-name="masonry"] .cover-masonry-grid {
    column-count: 2;
  }
}

/* 노트북 */
@media (min-width: 1024px) {
  [data-cover-name="masonry"] .cover-masonry-grid {
    column-count: 3;
  }
}

/* 데스크톱 */
@media (min-width: 1280px) {
  [data-cover-name="masonry"] .cover-masonry-grid {
    column-count: 4;
  }
}

/* 큰 화면 */
@media (min-width: 1536px) {
  [data-cover-name="masonry"] .cover-masonry-grid {
    column-count: 5;
  }
}

/* 카드 */
[data-cover-name="masonry"] .cover-masonry-item {
  position: relative;
  display: inline-block;
  width: 100%;
  margin: 0;
  break-inside: avoid;
  overflow: hidden;
  vertical-align: top;
  background: rgb(229 231 235);
}

.dark [data-cover-name="masonry"] .cover-masonry-item {
  background: rgb(31 32 35);
}

/* 카드 전체 클릭 */
[data-cover-name="masonry"] .cover-masonry-link {
  position: absolute;
  inset: 0;
  z-index: 30;
}

/* 이미지 영역 */
[data-cover-name="masonry"] .cover-masonry-media {
  position: relative;
  width: 100%;
  background:
    linear-gradient(135deg, rgba(120, 120, 130, 0.22), rgba(120, 120, 130, 0.05)),
    rgb(229 231 235);
}

.dark [data-cover-name="masonry"] .cover-masonry-media {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.03)),
    rgb(31 32 35);
}

/* 커버 썸네일 비율 유지 */
[data-cover-name="masonry"] .cover-masonry-thumb {
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
  transition:
    transform 0.45s ease,
    filter 0.45s ease;
}

/* 썸네일 없는 글의 최소 높이 */
[data-cover-name="masonry"] .cover-masonry-media:empty {
  min-height: 14rem;
}

/* 제목 오버레이: 기본 숨김 */
[data-cover-name="masonry"] .cover-masonry-overlay {
  position: absolute;
  inset: 0;
  z-index: 20;
  display: flex;
  align-items: flex-end;
  padding: 1rem;
  opacity: 0;
  transform: translateY(0.5rem);
  transition:
    opacity 0.25s ease,
    transform 0.25s ease;
  background:
    linear-gradient(
      to bottom,
      rgba(0, 0, 0, 0.02) 0%,
      rgba(0, 0, 0, 0.25) 45%,
      rgba(0, 0, 0, 0.75) 100%
    );
}

/* hover/focus 시 제목 표시 */
[data-cover-name="masonry"] .cover-masonry-item:hover .cover-masonry-overlay,
[data-cover-name="masonry"] .cover-masonry-item:focus-within .cover-masonry-overlay {
  opacity: 1;
  transform: translateY(0);
}

/* hover/focus 시 이미지 살짝 확대 */
[data-cover-name="masonry"] .cover-masonry-item:hover .cover-masonry-thumb,
[data-cover-name="masonry"] .cover-masonry-item:focus-within .cover-masonry-thumb {
  transform: scale(1.04);
  filter: brightness(0.78);
}

/* 오버레이 텍스트 */
[data-cover-name="masonry"] .cover-masonry-info {
  width: 100%;
  color: #fff;
  pointer-events: none;
}

[data-cover-name="masonry"] .cover-masonry-title {
  font-size: clamp(0.875rem, 1.2vw, 1.125rem);
  line-height: 1.35;
  font-weight: 700;
  word-break: keep-all;
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.45);

  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* 터치 기기는 hover가 없으므로 제목을 항상 표시 */
@media (hover: none) {
  [data-cover-name="masonry"] .cover-masonry-overlay {
    opacity: 1;
    transform: none;
    padding: 0.75rem;
  }

  [data-cover-name="masonry"] .cover-masonry-title {
    font-size: 0.875rem;
    -webkit-line-clamp: 2;
  }
}

/* 더보기 버튼 */
[data-cover-name="masonry"] .cover-masonry-more {
  display: block;
  width: max-content;
  margin: 2rem auto 0;
  padding: 0.75rem 1rem;
  border-radius: 9999px;
  font-size: 0.875rem;
  font-weight: 700;
  color: rgb(244 244 246);
  background: rgb(41 42 45);
}

.dark [data-cover-name="masonry"] .cover-masonry-more {
  color: rgb(41 42 45);
  background: rgb(244 244 246);
}