/* ════════════════════════════════════════════════════════
   커뮤니티 (Community) — 공개 목록/상세 + 회원 작성 폼(Summernote Lite)
   공지(.notice-*) 클래스를 재사용하고 부족한 부분만 .community-* 로 보강.
   ════════════════════════════════════════════════════════ */

/* 상단: 제목 + 글쓰기 버튼 */
.community-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-5);
}

/* 말머리 필터 (탭형 칩) */
.community-filter {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-5);
}
.community-filter a {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: var(--space-1) var(--space-4);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-full);
  background: #fff;
  color: var(--color-gray-600);
  font-size: var(--font-size-sm);
  font-weight: 600;
  text-decoration: none;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.community-filter a:hover {
  border-color: var(--color-primary-300);
  background: var(--color-primary-50);
  color: var(--color-primary-700);
  text-decoration: none;
}
.community-filter a.active {
  background: var(--color-primary-800);
  border-color: var(--color-primary-800);
  color: #fff;
}

/* 말머리 배지 (목록·상세 공용) */
.community-cat {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  padding: 2px 10px;
  border-radius: var(--radius-full);
  background: var(--color-primary-50);
  color: var(--color-primary-700);
  font-size: var(--font-size-xs);
  font-weight: 800;
  letter-spacing: -0.2px;
  border: 1px solid var(--color-primary-100);
}

/* ── 공개 게시글 목록 (리스트형) ── */
.community-list {
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1px solid var(--color-gray-200);
}
.community-list__item {
  border-bottom: 1px solid var(--color-gray-200);
}
.community-list__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-2);
  text-decoration: none;
  color: var(--color-gray-800);
  min-height: 44px;
  transition: background 0.15s;
}
.community-list__link:hover {
  background: var(--color-gray-50);
  text-decoration: none;
}
.community-list__main {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  min-width: 0;
}
.community-list__title {
  font-weight: 600;
  font-size: var(--font-size-base);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.community-list__link:hover .community-list__title { color: var(--color-primary-600); }
.community-list__meta {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-shrink: 0;
  font-size: var(--font-size-sm);
  color: var(--color-gray-500);
  white-space: nowrap;
}
.community-list__like { color: var(--color-primary-600); font-weight: 600; }

/* ── 좋아요 바 / 버튼 ── */
.community-like-bar {
  display: flex;
  justify-content: center;
  margin-top: var(--space-8);
}
.community-like-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  min-height: 44px;
  padding: var(--space-2) var(--space-5);
  border: 1.5px solid var(--color-gray-300);
  border-radius: var(--radius-full);
  background: #fff;
  color: var(--color-gray-600);
  font-size: var(--font-size-sm);
  font-weight: 700;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.15s, color 0.15s, border-color 0.15s, transform 0.1s;
}
.community-like-btn:hover {
  border-color: var(--color-primary-400);
  color: var(--color-primary-700);
  text-decoration: none;
}
.community-like-btn:active { transform: translateY(1px); }
.community-like-btn__icon { font-size: 1.1em; line-height: 1; color: var(--color-gray-400); transition: color 0.15s; }
.community-like-btn.is-liked {
  border-color: #e0245e;
  background: #fdeef2;
  color: #e0245e;
}
.community-like-btn.is-liked .community-like-btn__icon { color: #e0245e; }
.community-like-btn__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  padding: 0 6px;
  border-radius: var(--radius-full);
  background: var(--color-gray-100);
  font-weight: 800;
}
.community-like-btn.is-liked .community-like-btn__count { background: rgba(224, 36, 94, 0.12); }
.community-like-btn--guest { cursor: pointer; }

/* ── 수정/삭제 액션 ── */
.community-owner-actions {
  display: flex;
  gap: var(--space-3);
  justify-content: flex-end;
  margin-top: var(--space-5);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-gray-200);
}
.community-btn-danger { color: #dc2626; }
.community-btn-danger:hover { background: #fef2f2; color: #b91c1c; }

/* ── 댓글 ── */
.community-comments {
  margin-top: var(--space-8);
  padding-top: var(--space-6);
  border-top: 2px solid var(--color-gray-200);
}
.community-comments__title {
  font-size: var(--font-size-lg);
  font-weight: 800;
  color: var(--color-gray-900);
  margin-bottom: var(--space-5);
}
.community-comment-list {
  list-style: none;
  margin: 0 0 var(--space-6);
  padding: 0;
}
.community-comment {
  padding: var(--space-4) 0;
  border-bottom: 1px solid var(--color-gray-100);
}
.community-comment__head {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  color: var(--color-gray-500);
  margin-bottom: var(--space-2);
}
.community-comment__author { font-weight: 700; color: var(--color-gray-800); }
.community-comment__del { margin-left: auto; }
.community-comment__del-btn {
  border: none;
  background: none;
  padding: 2px 4px;
  font-size: var(--font-size-xs);
  color: var(--color-gray-400);
  cursor: pointer;
  border-radius: var(--radius-sm);
}
.community-comment__del-btn:hover { color: #dc2626; background: #fef2f2; }
.community-comment__body {
  color: var(--color-gray-700);
  font-size: var(--font-size-base);
  line-height: 1.7;
  white-space: pre-wrap;
  word-break: break-word;
  overflow-wrap: anywhere;
}

/* 댓글 작성 폼 */
.community-comment-form { margin-top: var(--space-4); }
.community-comment-form__actions {
  display: flex;
  justify-content: flex-end;
  margin-top: var(--space-3);
}
.community-login-hint {
  padding: var(--space-5);
  background: var(--color-gray-50);
  border: 1px dashed var(--color-gray-300);
  border-radius: var(--radius-md);
  text-align: center;
  font-size: var(--font-size-sm);
  color: var(--color-gray-500);
}
.community-login-hint a { color: var(--color-primary-600); font-weight: 700; text-decoration: underline; }

/* 작성/수정 폼 카드 */
.community-form-card {
  background: #fff;
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
}

/* ── 커뮤니티 반응형 (≤640px) ── */
@media (max-width: 640px) {
  .community-list__link {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-2);
  }
  .community-list__title { white-space: normal; }
  .community-form-card { padding: var(--space-4); }
}

@media (max-width: 479px) {
  .community-head { flex-wrap: wrap; }
  .community-list__meta .notice-list__sep:nth-of-type(1),
  .community-list__meta .community-list__author { display: none; }
}
