/* ============================================================
   Runi Blog — 런잉크 발행 본문 블록 스타일 (ri-*)
   명세: wp-publish-html-spec (ri-* 15블록). 디자인 thesis "정비 명세서".
   모든 색/간격은 theme.json 프리셋 토큰 위에 매핑.
   본문(.entry-content = core/post-content) 안에서만 렌더된다고 가정.
   ============================================================ */

:root {
  /* 브랜딩 훅 — 사업장별 사이트 CSS 변수로 오버라이드 가능 */
  --ri-accent:      var(--wp--preset--color--signal);        /* 번트 앰버 */
  --ri-accent-soft: var(--wp--preset--color--signal-soft);
  --ri-ink:         var(--wp--preset--color--contrast);
  --ri-steel:       var(--wp--preset--color--steel);
  --ri-line:        var(--wp--preset--color--steel-light);
  --ri-paper:       var(--wp--preset--color--base);
  --ri-card-bg:     #ffffff;
  --ri-radius:      8px;
  --ri-radius-sm:   4px;
  --ri-gap:         1rem;
  --ri-mono:        var(--wp--preset--font-family--mono);
}

/* 본문 블록 공통 세로 리듬 */
.entry-content > .ri-photo,
.entry-content > .ri-video,
.entry-content > .ri-gallery,
.entry-content > .ri-tip,
.entry-content > .ri-quote,
.entry-content > .ri-place,
.entry-content > .ri-link-card,
.entry-content > .ri-cta,
.entry-content > .ri-quote-card,
.entry-content > .ri-tag-cloud,
.entry-content > .ri-before-after,
.entry-content > .ri-product-card,
.entry-content > .ri-voice {
  margin-block: var(--wp--preset--spacing--50);
}

/* ---- 공통: 이미지 ---- */
.ri-img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: var(--ri-radius);
  background: var(--ri-line);   /* 로딩 전 플레이스홀더 톤 */
}

/* ---- 공통: 캡션 ---- */
.ri-caption {
  margin-top: 0.6rem;
  font-size: var(--wp--preset--font-size--small);
  line-height: 1.5;
  color: var(--ri-steel);
}
.ri-caption__title { display: block; font-weight: 700; color: var(--ri-ink); }
.ri-caption__desc  { display: block; }

/* ============================================================
   4.1 photo — 사진 (single | row | compare)
   ============================================================ */
.ri-photo { margin: 0; }
.ri-photo__media { display: grid; gap: var(--ri-gap); }
.ri-photo--row    .ri-photo__media,
.ri-photo--compare .ri-photo__media {
  grid-auto-flow: column;
  grid-auto-columns: 1fr;
}
.ri-photo--compare .ri-photo__media { gap: 0.5rem; }     /* 비교는 밀착 */
@media (max-width: 600px) {
  .ri-photo--row .ri-photo__media { grid-auto-flow: row; }  /* 모바일 세로 스택 */
}

/* ============================================================
   4.2 video — 동영상
   ============================================================ */
.ri-video { margin: 0; }
.ri-video__player {
  display: block;
  width: 100%;
  height: auto;
  border-radius: var(--ri-radius);
  background: #000;
}

/* ============================================================
   4.3 divider — 구분선 (정비 명세서 헤어라인)
   ============================================================ */
.ri-divider {
  border: 0;
  height: 1px;
  background: var(--ri-line);
  margin-block: var(--wp--preset--spacing--50);
}

/* ============================================================
   4.4 quote — 인용구
   ============================================================ */
.ri-quote {
  margin: 0;
  padding: 0.2rem 0 0.2rem 1.2rem;
  border-left: 3px solid var(--ri-accent);
  color: var(--ri-steel);
  font-size: var(--wp--preset--font-size--large);
  line-height: 1.55;
}
.ri-quote p { margin: 0; }

/* ============================================================
   4.5 tip — 팁/안내 박스
   ============================================================ */
.ri-tip {
  display: flex;
  gap: 0.75rem;
  padding: 1rem 1.1rem;
  background: var(--ri-accent-soft);
  border: 1px solid color-mix(in srgb, var(--ri-accent) 22%, transparent);
  border-radius: var(--ri-radius);
}
.ri-tip__icon { flex: 0 0 auto; font-size: 1.15rem; line-height: 1.5; }
.ri-tip__body { flex: 1; }
.ri-tip__body > :first-child { margin-top: 0; }
.ri-tip__body > :last-child  { margin-bottom: 0; }

/* ============================================================
   4.6 gallery — 갤러리 (collage|slide|grid|single|hero)
   ============================================================ */
.ri-gallery { margin: 0; }
.ri-gallery__items { display: grid; gap: 0.5rem; }

/* grid: data-columns 로 열 수 제어 (기본 3) */
.ri-gallery--grid .ri-gallery__items   { grid-template-columns: repeat(3, 1fr); }
.ri-gallery--grid[data-columns="2"] .ri-gallery__items { grid-template-columns: repeat(2, 1fr); }
.ri-gallery--grid[data-columns="4"] .ri-gallery__items { grid-template-columns: repeat(4, 1fr); }

/* collage: 첫 장 크게 */
.ri-gallery--collage .ri-gallery__items { grid-template-columns: repeat(2, 1fr); }
.ri-gallery--collage .ri-gallery__items > .ri-img:first-child { grid-column: 1 / -1; }

/* single / hero: 1열 풀폭 */
.ri-gallery--single .ri-gallery__items,
.ri-gallery--hero   .ri-gallery__items { grid-template-columns: 1fr; }

/* slide: 가로 스크롤 캐러셀 (JS 없이 스냅) */
.ri-gallery--slide .ri-gallery__items {
  grid-auto-flow: column;
  grid-auto-columns: 80%;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}
.ri-gallery--slide .ri-gallery__items > .ri-img { scroll-snap-align: start; }

/* aspect 훅 — 지정 시 비율 고정 + 크롭 */
.ri-gallery[data-aspect="1:1"]  .ri-img { aspect-ratio: 1 / 1;  object-fit: cover; }
.ri-gallery[data-aspect="4:3"]  .ri-img { aspect-ratio: 4 / 3;  object-fit: cover; }
.ri-gallery[data-aspect="16:9"] .ri-img { aspect-ratio: 16 / 9; object-fit: cover; }

@media (max-width: 600px) {
  .ri-gallery--grid .ri-gallery__items,
  .ri-gallery--grid[data-columns="4"] .ri-gallery__items { grid-template-columns: repeat(2, 1fr); }
}

/* ============================================================
   4.7 place — 장소/지도 (MVP: 링크 버튼)
   ============================================================ */
.ri-place {
  padding: 1rem 1.1rem;
  border: 1px solid var(--ri-line);
  border-radius: var(--ri-radius);
  background: var(--ri-card-bg);
}
.ri-place__name { font-weight: 700; color: var(--ri-ink); }
.ri-place__map {
  margin-top: 0.6rem;
  min-height: 0;            /* JS 임베드 시 높이 부여. MVP는 비표시 */
  font-size: var(--wp--preset--font-size--small);
  color: var(--ri-steel);
}
.ri-place__map:empty { display: none; }
.ri-place__link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  margin-top: 0.7rem;
  padding: 0.45em 0.9em;
  font-size: var(--wp--preset--font-size--small);
  font-weight: 700;
  color: var(--ri-accent);
  border: 1px solid currentColor;
  border-radius: var(--ri-radius-sm);
  text-decoration: none;
}
.ri-place__link:hover { background: var(--ri-accent); color: #fff; }

/* ============================================================
   4.8 link — 링크 카드 / 인라인
   ============================================================ */
.ri-link-card {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  padding: 0.85rem 1rem;
  border: 1px solid var(--ri-line);
  border-radius: var(--ri-radius);
  background: var(--ri-card-bg);
  text-decoration: none;
}
.ri-link-card:hover { border-color: var(--ri-accent); }
.ri-link-card__label { font-weight: 700; color: var(--ri-ink); }
.ri-link-card__url {
  font-family: var(--ri-mono);
  font-size: var(--wp--preset--font-size--small);
  color: var(--ri-steel);
}
.ri-link { color: var(--ri-accent); text-underline-offset: 2px; }

/* ============================================================
   4.9 cta — 행동유도 버튼 (primary|secondary|outline)
   ============================================================ */
.ri-cta { display: flex; }
.ri-cta__btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75em 1.4em;
  border-radius: var(--ri-radius-sm);
  font-weight: 700;
  text-decoration: none;
  border: 1.5px solid var(--ri-accent);
  transition: background 0.14s, color 0.14s;
}
.ri-cta__btn--primary   { background: var(--ri-accent); color: #fff; }
.ri-cta__btn--primary:hover { background: var(--ri-ink); border-color: var(--ri-ink); }
.ri-cta__btn--secondary { background: var(--ri-ink); color: var(--ri-paper); border-color: var(--ri-ink); }
.ri-cta__btn--secondary:hover { background: var(--ri-accent); border-color: var(--ri-accent); }
.ri-cta__btn--outline   { background: transparent; color: var(--ri-accent); }
.ri-cta__btn--outline:hover { background: var(--ri-accent); color: #fff; }
.ri-cta__icon { font-size: 1.05em; line-height: 1; }

/* ============================================================
   4.10 quote_card — 후기/리뷰 카드
   ============================================================ */
.ri-quote-card {
  margin: 0;
  padding: 1.1rem 1.2rem;
  border: 1px solid var(--ri-line);
  border-left: 3px solid var(--ri-accent);
  border-radius: var(--ri-radius);
  background: var(--ri-card-bg);
}
.ri-quote-card__rating {
  font-size: var(--wp--preset--font-size--small);
  letter-spacing: 0.1em;
  color: var(--ri-accent);
}
.ri-quote-card__text {
  margin: 0.4rem 0 0;
  font-size: var(--wp--preset--font-size--medium);
  line-height: 1.6;
  color: var(--ri-ink);
}
.ri-quote-card__author {
  margin-top: 0.6rem;
  font-size: var(--wp--preset--font-size--small);
  font-weight: 700;
  color: var(--ri-ink);
}
.ri-quote-card__source {
  margin-left: 0.4rem;
  font-weight: 400;
  color: var(--ri-steel);
}

/* ============================================================
   4.11 tag_cloud — 태그 모음
   ============================================================ */
.ri-tag-cloud {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}
.ri-tag {
  padding: 0.25em 0.7em;
  font-size: var(--wp--preset--font-size--small);
  color: var(--ri-steel);
  background: var(--wp--preset--color--base-2);
  border-radius: 999px;
}

/* ============================================================
   4.12 before_after — 비포/애프터 (MVP: 나란히)
   ============================================================ */
.ri-before-after { margin: 0; }
.ri-before-after__pair {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem;
}
.ri-before-after__item { position: relative; }
.ri-before-after__item .ri-img { aspect-ratio: 4 / 3; object-fit: cover; }
.ri-before-after__label {
  position: absolute;
  top: 0.5rem;
  left: 0.5rem;
  padding: 0.15em 0.6em;
  font-family: var(--ri-mono);
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #fff;
  background: color-mix(in srgb, var(--ri-ink) 78%, transparent);
  border-radius: var(--ri-radius-sm);
}
.ri-before-after__item--after .ri-before-after__label { background: var(--ri-accent); }

/* ============================================================
   4.13 product_card — 상품/서비스 카드
   ============================================================ */
.ri-product-card {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 1rem;
  padding: 0.9rem 1rem;
  border: 1px solid var(--ri-line);
  border-radius: var(--ri-radius);
  background: var(--ri-card-bg);
  align-items: center;
}
.ri-product-card:not(:has(.ri-product-card__media)) { grid-template-columns: 1fr; }
.ri-product-card__media .ri-img { aspect-ratio: 1 / 1; object-fit: cover; }
.ri-product-card__title { font-weight: 700; color: var(--ri-ink); line-height: 1.4; }
.ri-product-card__price {
  margin-top: 0.2rem;
  font-family: var(--ri-mono);
  font-weight: 700;
  color: var(--ri-accent);
}
.ri-product-card__link {
  display: inline-block;
  margin-top: 0.4rem;
  font-size: var(--wp--preset--font-size--small);
  font-weight: 700;
  color: var(--ri-accent);
  text-decoration: none;
}
.ri-product-card__link:hover { text-decoration: underline; }

/* ============================================================
   4.14 voice — 음성 메모 인용
   ============================================================ */
.ri-voice {
  padding: 1rem 1.1rem;
  border: 1px dashed var(--ri-line);
  border-radius: var(--ri-radius);
  background: var(--ri-paper);
}
.ri-voice__speaker {
  font-size: var(--wp--preset--font-size--small);
  font-weight: 700;
  color: var(--ri-steel);
}
.ri-voice__speaker::before { content: "🎙 "; }
.ri-voice__text {
  margin: 0.35rem 0 0;
  font-style: italic;
  line-height: 1.6;
  color: var(--ri-ink);
}
.ri-voice[data-highlight="true"] {
  background: var(--ri-accent-soft);
  border-style: solid;
  border-color: color-mix(in srgb, var(--ri-accent) 22%, transparent);
}

/* ---- 섹션 묶음 (메타 그룹, 시각 효과 없음) ---- */
.ri-section { display: block; }
