/* ===== 페이지 히어로 ===== */
.page-hero {
  background: linear-gradient(135deg, #FFF8F0 0%, #FAEEDA 100%);
  padding: 36px 0 28px;
  border-bottom: 1px solid var(--border);
}

.breadcrumb {
  font-size: 12px;
  color: var(--text-muted);
  margin-bottom: 10px;
}

.breadcrumb a {
  color: var(--orange);
}

.page-hero h1 {
  font-size: 26px;
  font-weight: 700;
  margin-bottom: 6px;
}

.page-hero p {
  font-size: 14px;
  color: var(--text-mid);
}

/* ===== 게시판 섹션 ===== */
.board-section {
  padding: 36px 0 60px;
  width: 100%;
}

/* ===== 툴바 ===== */
.board-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
}

.search-wrap {
  display: flex;
  align-items: center;
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  background: #fff;
  flex: 1;
  max-width: 360px;
}

.search-input {
  border: none;
  outline: none;
  padding: 10px 14px;
  font-size: 14px;
  font-family: 'Noto Sans KR', sans-serif;
  flex: 1;
  background: transparent;
  color: var(--text-dark);
}

.search-btn {
  background: none;
  border: none;
  padding: 10px 14px;
  cursor: pointer;
  font-size: 16px;
  color: var(--text-muted);
}

.write-btn {
  background: var(--orange);
  color: #fff;
  border: none;
  padding: 10px 20px;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  font-family: 'Noto Sans KR', sans-serif;
  transition: background 0.2s;
  white-space: nowrap;
}

.write-btn:hover { background: #a33808; }

/* ===== 글쓰기 안내 배너 ===== */
.notice-banner {
  background: #FFF3E0;
  border: 1px solid #FAEEDA;
  border-radius: 8px;
  padding: 12px 16px;
  font-size: 13px;
  color: #854F0B;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}

.notice-banner button {
  background: none;
  border: none;
  color: #854F0B;
  cursor: pointer;
  font-size: 16px;
  padding: 0 4px;
}

/* ===== 필터 버튼 ===== */
.filter-wrap {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}

.filter-btn {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 6px 16px;
  font-size: 13px;
  font-weight: 500;
  font-family: 'Noto Sans KR', sans-serif;
  cursor: pointer;
  color: var(--text-mid);
  transition: all 0.2s;
}

.filter-btn:hover {
  border-color: var(--orange);
  color: var(--orange);
}

.filter-btn.active {
  background: var(--orange);
  border-color: var(--orange);
  color: #fff;
}

/* ===== 게시글 목록 ===== */
.post-list {
  border-top: 2px solid var(--text-dark);
  margin-bottom: 24px;
}

.post-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 8px;
  border-bottom: 1px solid var(--border);
  transition: background 0.15s;
}

.post-item:hover { background: #FFFAF5; }

.notice-post {
  background: #FFFBF0;
}

.hot-post { background: #FFF8F5; }

.post-left {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  min-width: 52px;
}

.post-badge {
  display: inline-block;
  font-size: 11px;
  font-weight: 500;
  padding: 2px 8px;
  border-radius: 4px;
  white-space: nowrap;
}

.badge-notice { background: #1a1a1a; color: #fff; }
.badge-stock  { background: #E6F1FB; color: #185FA5; }
.badge-realty { background: #EAF3DE; color: #3B6D11; }
.badge-pension{ background: #EEEDFE; color: #534AB7; }
.badge-tax    { background: #FAEEDA; color: #854F0B; }
.badge-free   { background: #F1EFE8; color: #5F5E5A; }

.hot-badge {
  font-size: 10px;
  color: var(--orange);
  font-weight: 700;
}

.post-body {
  flex: 1;
  min-width: 0;
}

.post-title {
  font-size: 14px;
  font-weight: 500;
  color: var(--text-dark);
  display: block;
  margin-bottom: 5px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: color 0.15s;
}

.post-title:hover { color: var(--orange); }

.post-meta {
  display: flex;
  gap: 10px;
  font-size: 12px;
  color: var(--text-muted);
}

.post-author { font-weight: 500; color: var(--text-mid); }

.post-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
  flex-shrink: 0;
}

.post-comment,
.post-views {
  font-size: 12px;
  color: var(--text-muted);
  white-space: nowrap;
}

.post-comment { color: var(--orange); font-weight: 500; }

/* ===== 페이지네이션 ===== */
.pagination {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-bottom: 32px;
}

.page-btn {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: #fff;
  font-size: 14px;
  font-family: 'Noto Sans KR', sans-serif;
  cursor: pointer;
  color: var(--text-mid);
  transition: all 0.2s;
}

.page-btn:hover { border-color: var(--orange); color: var(--orange); }
.page-btn.active { background: var(--orange); border-color: var(--orange); color: #fff; }

/* ===== 회원 유도 배너 ===== */
.join-banner {
  background: linear-gradient(135deg, #FFF3E0, #FAEEDA);
  border: 1px solid #f0d5b0;
  border-radius: 12px;
  padding: 24px 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

.join-text strong {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-dark);
  display: block;
  margin-bottom: 6px;
}

.join-text p {
  font-size: 13px;
  color: var(--text-mid);
  line-height: 1.6;
}

/* ===== 현재 활성 메뉴 ===== */
.nav-active {
  color: var(--orange) !important;
  font-weight: 700 !important;
}

/* ===== 반응형 ===== */
@media (max-width: 768px) {
  .board-toolbar { flex-wrap: wrap; }
  .search-wrap { max-width: 100%; }
  .write-btn { width: 100%; text-align: center; }

  .post-title {
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
  }

  .post-right { display: none; }
  .post-left { min-width: 44px; }

  .join-banner { flex-direction: column; text-align: center; }
}
