/* ==========================================================================
   Post Detail Page
   포스트 상세 페이지 스타일
   Header styles moved to components/header.css
   ========================================================================== */

/* Post detail: thread-detail과 동일한 inner scroll 패턴 */
body:has(.post-detail) {
  overflow: hidden;
  position: fixed;
  width: 100%;
  height: 100%;
  padding-top: 0;
}

html:has(.post-detail) {
  overflow: hidden;
  height: 100%;
}

body:has(.post-detail) > div {
  height: 100%;
}

/* NOTE: "> div > div" 제거 — #flash 등 sibling div에 height:100%가 적용되어
   main을 viewport 아래로 밀어내는 버그 발생. main은 아래에서 직접 타겟. */

body:has(.post-detail) main {
  height: 100%;
  overflow: hidden;
  padding-bottom: 0;
}

.post-detail {
  height: 100%;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: var(--color-bg-primary);
}

/* iOS native: web header is hidden, add safe-area top to push content below native nav bar */
[data-bridge-components~="nav-bar"] .post-detail {
  padding-top: calc(env(safe-area-inset-top) + var(--spacing-list-sm));
}

/* 헤더: flex-shrink: 0으로 상단 고정, safe-area 직접 처리 */
.post-detail > .header {
  flex-shrink: 0;
  position: relative;
  padding-top: calc(var(--spacing-2) + env(safe-area-inset-top));
  margin-top: 0;
}

/* 스크롤 영역: 나머지 공간 전부 */
.post-detail__scrollable {
  flex: 1 1 0;
  min-height: 0;
  overflow-y: scroll;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-y: auto;
}

/* iOS bounce scroll 활성화: 콘텐츠가 짧아도 스크롤 동작 */
.post-detail__scrollable-inner {
  min-height: calc(100% + 1px);
}


/* ---------------------------------------------------------------------------
   Content
   --------------------------------------------------------------------------- */
.post-detail__content {
  padding: 0 0 var(--spacing-section) 0;  /* top padding removed - header handles gap */
}

/* ---------------------------------------------------------------------------
   Author
   --------------------------------------------------------------------------- */
.post-detail__author {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--spacing-section);
}

.post-detail__author-right {
  display: flex;
  align-items: center;
  gap: var(--spacing-list-sm);
}

.post-detail__author-link {
  display: flex;
  align-items: center;
  gap: var(--spacing-list-md);
  text-decoration: none;
}

.post-detail__author-info {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-title-subtitle);
}

.post-detail__author-name {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-primary);
  line-height: 1.3;
  margin: 0;
}

.post-detail__author-time {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-normal);
  color: var(--color-text-secondary);
  line-height: 1.3;
  margin: 0;
}

/* ---------------------------------------------------------------------------
   Body
   --------------------------------------------------------------------------- */
.post-detail__body-title {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  margin: 0 0 var(--spacing-list-sm) 0;
  line-height: 1.3;
}

.post-detail__text {
  font-size: var(--font-size-md);
  color: var(--color-text-primary);
  line-height: 1.5;
  white-space: pre-wrap;
  margin: 0;
}

.post-detail__image {
  border-radius: var(--radius-base);
  overflow: hidden;
  margin-top: var(--spacing-section);
}

.post-detail__image img {
  width: 100%;
  aspect-ratio: 3 / 2;
  object-fit: cover;
  display: block;
}

/* ---------------------------------------------------------------------------
   Actions
   --------------------------------------------------------------------------- */
.post-detail__actions {
  display: flex;
  align-items: center;
  gap: var(--spacing-section-gap);
  margin-top: 0;
  padding: var(--spacing-section) 0;
  border-bottom: 1px solid var(--color-border-soft);
}
