/**
 * FluxShop for WordPress - Main Stylesheet
 * Clean & minimal Korean board design with Pretendard font
 * BEM Naming: .fluxshop-{block}__{element}--{modifier}
 *
 * @package FluxShop
 * @since 1.0.0
 */

/* ==========================================================================
   CSS Variables
   ========================================================================== */

:root {
  --fs-primary: #222222;
  --fs-primary-light: #555555;
  --fs-primary-hover: #000000;
  --fs-primary-bg: #F5F5F5;
  --fs-primary-border: #D1D5DB;
  --fs-accent: #DC2626;
  --fs-success: #16A34A;
  --fs-warning: #D97706;
  --fs-text: #111111;
  --fs-text-sub: #555555;
  --fs-text-muted: #999999;
  --fs-bg: #FFFFFF;
  --fs-bg-light: #F9F9F9;
  --fs-bg-hover: #F5F5F5;
  --fs-border: #E5E5E5;
  --fs-border-dark: #CCCCCC;
  --fs-radius: 6px;
  --fs-radius-sm: 4px;
  --fs-radius-pill: 100px;
  --fs-font: 'Pretendard Variable', 'Pretendard', -apple-system, BlinkMacSystemFont, system-ui, 'Segoe UI', sans-serif;
  --fs-font-sm: 13px;
  --fs-font-base: 14px;
  --fs-font-lg: 16px;
  --fs-shadow: 0 1px 3px rgba(0, 0, 0, 0.08), 0 1px 2px rgba(0, 0, 0, 0.06);
  --fs-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
  --fs-transition: 0.15s ease;
}

/* ==========================================================================
   Base Reset & Global Font
   ========================================================================== */

.fluxshop-board.fluxshop-board,
.fluxshop-board-view.fluxshop-board-view,
.fluxshop-board-write.fluxshop-board-write,
.fluxshop-gallery.fluxshop-gallery,
.fluxshop-comment.fluxshop-comment {
  font-family: var(--fs-font);
  font-size: var(--fs-font-base);
  line-height: 1.6;
  color: var(--fs-text);
  max-width: 960px;
  margin: 0 auto;
  padding: 24px 16px 0;
  box-sizing: border-box;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.fluxshop-board *,
.fluxshop-board-view *,
.fluxshop-board-write *,
.fluxshop-gallery *,
.fluxshop-comment * {
  box-sizing: border-box;
}

.fluxshop-board,
.fluxshop-board-view,
.fluxshop-board-write,
.fluxshop-gallery,
.fluxshop-comment,
.fluxshop-board *,
.fluxshop-board-view *,
.fluxshop-board-write *,
.fluxshop-gallery *,
.fluxshop-comment * {
  font-family: inherit;
}

.fluxshop-board.fluxshop-board input,
.fluxshop-board.fluxshop-board select,
.fluxshop-board.fluxshop-board textarea,
.fluxshop-board.fluxshop-board button,
.fluxshop-board-view.fluxshop-board-view input,
.fluxshop-board-view.fluxshop-board-view select,
.fluxshop-board-view.fluxshop-board-view textarea,
.fluxshop-board-view.fluxshop-board-view button,
.fluxshop-board-write.fluxshop-board-write input,
.fluxshop-board-write.fluxshop-board-write select,
.fluxshop-board-write.fluxshop-board-write textarea,
.fluxshop-board-write.fluxshop-board-write button,
.fluxshop-comment.fluxshop-comment input,
.fluxshop-comment.fluxshop-comment select,
.fluxshop-comment.fluxshop-comment textarea,
.fluxshop-comment.fluxshop-comment button {
  font-family: var(--fs-font);
}

.fluxshop-board.fluxshop-board button,
.fluxshop-board-view.fluxshop-board-view button,
.fluxshop-board-write.fluxshop-board-write button,
.fluxshop-comment.fluxshop-comment button {
  -webkit-appearance: none;
  appearance: none;
  outline: none;
}

.fluxshop-board a,
.fluxshop-board-view a,
.fluxshop-comment a {
  text-decoration: none;
}

/* ==========================================================================
   Avatar
   ========================================================================== */

.fluxshop-avatar {
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.fluxshop-avatar__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 50%;
}

.fluxshop-avatar--initial {
  color: #fff;
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1;
}

/* ==========================================================================
   Board List (목록)
   ========================================================================== */

/* 게시판 헤더 (타이틀/부제목) */
.fluxshop-board__header {
  margin-bottom: 24px;
}

.fluxshop-board__header-title {
  font-size: var(--fs-font-2xl);
  font-weight: 700;
  color: var(--fs-text-primary);
  margin: 0 0 6px;
  line-height: 1.3;
}

.fluxshop-board__header-subtitle {
  font-size: var(--fs-font-sm);
  color: var(--fs-text-muted);
  margin: 0;
  line-height: 1.6;
}

/* 상단 툴바 */
.fluxshop-board__toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
  gap: 12px;
}

.fluxshop-board__total {
  font-size: var(--fs-font-sm);
  color: var(--fs-text-muted);
  white-space: nowrap;
}

.fluxshop-board__total strong {
  color: var(--fs-text);
  font-weight: 600;
}

/* 검색 폼 */
.fluxshop-board__search-form {
  display: flex;
  align-items: center;
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius);
  overflow: hidden;
  background: var(--fs-bg);
  transition: border-color var(--fs-transition), box-shadow var(--fs-transition);
}

.fluxshop-board__search-form:focus-within {
  border-color: var(--fs-border-dark);
  box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.04);
}

.fluxshop-board__search-field {
  border: none;
  border-right: 1px solid var(--fs-border);
  padding: 8px 10px;
  font-size: var(--fs-font-sm);
  font-family: var(--fs-font);
  background: var(--fs-bg-light);
  color: var(--fs-text-sub);
  outline: none;
  cursor: pointer;
}

.fluxshop-board__search-input {
  border: none;
  outline: none;
  padding: 8px 12px;
  font-size: var(--fs-font-sm);
  font-family: var(--fs-font);
  background: transparent;
  width: 180px;
  color: var(--fs-text);
}

.fluxshop-board__search-input::placeholder {
  color: var(--fs-text-muted);
}

.fluxshop-board__search-btn.fluxshop-board__search-btn {
  border: none;
  background: transparent;
  box-shadow: none;
  cursor: pointer;
  padding: 8px 12px;
  color: var(--fs-text-muted);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color var(--fs-transition);
  border-radius: 0;
}

.fluxshop-board__search-btn.fluxshop-board__search-btn:hover {
  color: var(--fs-text);
  background: transparent;
}

/* 카테고리 필터 (pill) */
.fluxshop-board__cats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}

.fluxshop-board__cat {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 16px;
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius-pill);
  font-size: var(--fs-font-sm);
  font-weight: 500;
  color: var(--fs-text-sub);
  text-decoration: none;
  background: var(--fs-bg);
  transition: all var(--fs-transition);
  white-space: nowrap;
}

.fluxshop-board__cat:hover {
  border-color: var(--fs-border-dark);
  color: var(--fs-text);
  background: var(--fs-bg-hover);
}

.fluxshop-board__cat--active {
  background: var(--fs-primary);
  border-color: var(--fs-primary);
  color: #fff;
  font-weight: 600;
}

.fluxshop-board__cat--active:hover {
  background: var(--fs-primary-hover);
  border-color: var(--fs-primary-hover);
  color: #fff;
}

.fluxshop-board__cat-arrow {
  margin-left: 2px;
  vertical-align: middle;
  transition: transform 0.2s;
}

.fluxshop-board__cat-arrow--open {
  transform: rotate(180deg);
}

/* 하위 카테고리 */
.fluxshop-board__subcats {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: -8px;
  margin-bottom: 16px;
  padding-left: 8px;
}

.fluxshop-board__subcat {
  display: inline-block;
  padding: 4px 12px;
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius-pill);
  font-size: 12px;
  font-weight: 500;
  color: var(--fs-text-sub);
  text-decoration: none;
  background: var(--fs-bg);
  transition: all var(--fs-transition);
  white-space: nowrap;
}

.fluxshop-board__subcat:hover {
  border-color: var(--fs-border-dark);
  color: var(--fs-text);
}

.fluxshop-board__subcat--active {
  background: var(--fs-primary);
  border-color: var(--fs-primary);
  color: #fff;
  font-weight: 600;
}

.fluxshop-board__subcat--active:hover {
  background: var(--fs-primary-hover);
  border-color: var(--fs-primary-hover);
  color: #fff;
}

/* 게시글 테이블 */
.fluxshop-board__table {
  width: 100%;
  border-collapse: collapse;
  border-top: 2px solid var(--fs-text);
  margin-bottom: 12px;
  font-size: var(--fs-font-base);
}

.fluxshop-board__table colgroup .fluxshop-board__col--num {
  width: 60px;
}

.fluxshop-board__table colgroup .fluxshop-board__col--cat {
  width: 84px;
}

.fluxshop-board__table colgroup .fluxshop-board__col--subject {
  /* auto */
}

.fluxshop-board__table colgroup .fluxshop-board__col--author {
  width: 100px;
}

.fluxshop-board__table colgroup .fluxshop-board__col--date {
  width: 90px;
}

.fluxshop-board__table colgroup .fluxshop-board__col--hit {
  width: 60px;
}

.fluxshop-board__table colgroup .fluxshop-board__col--good {
  width: 54px;
}

.fluxshop-board__table thead th {
  padding: 12px 8px;
  text-align: center;
  font-size: var(--fs-font-sm);
  font-weight: 600;
  color: var(--fs-text-sub);
  background: var(--fs-bg-light);
  border-bottom: 1px solid var(--fs-border);
  letter-spacing: -0.01em;
}

.fluxshop-board__table thead th:nth-child(3) {
  text-align: left;
}

.fluxshop-board__row {
  border-bottom: 1px solid var(--fs-border);
  transition: background var(--fs-transition);
}

.fluxshop-board__row:hover {
  background: var(--fs-bg-light);
}

.fluxshop-board__row--notice {
  background: var(--fs-bg-light);
}

.fluxshop-board__row--notice:hover {
  background: var(--fs-bg-hover);
}

.fluxshop-board__row td {
  padding: 12px 8px;
  vertical-align: middle;
}

/* 번호 셀 */
.fluxshop-board__num {
  text-align: center;
  font-size: var(--fs-font-sm);
  color: var(--fs-text-muted);
  font-variant-numeric: tabular-nums;
}

/* 공지 배지 */
.fluxshop-board__badge-notice {
  display: inline-block;
  padding: 2px 8px;
  background: var(--fs-primary);
  color: #fff;
  border-radius: var(--fs-radius-sm);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.02em;
}

/* 인기 배지 */
.fluxshop-board__badge-popular {
  display: inline-block;
  padding: 2px 8px;
  background: #e74c3c;
  color: #fff;
  border-radius: var(--fs-radius-sm);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.02em;
}

/* 인기글 행 */
.fluxshop-board__row--popular {
  background: #fff8f8;
}

/* 읽은 글 행 */
.fluxshop-board__row--read .fluxshop-board__subject-link {
  color: var(--fs-text-muted);
}

/* 카테고리 셀 */
.fluxshop-board__cat-cell {
  text-align: center;
}

.fluxshop-board__cat-badge {
  display: inline-block;
  padding: 2px 8px;
  background: var(--fs-bg-light);
  color: var(--fs-text-sub);
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius-sm);
  font-size: 11px;
  font-weight: 500;
  white-space: nowrap;
  max-width: 76px;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* 제목 셀 */
.fluxshop-board__subject-cell {
  text-align: left;
}

.fluxshop-board__subject-link {
  text-decoration: none;
  color: var(--fs-text);
  font-size: var(--fs-font-base);
  font-weight: 500;
  display: inline;
  word-break: keep-all;
  transition: color var(--fs-transition);
}

.fluxshop-board__subject-link:hover {
  text-decoration: underline;
}

.fluxshop-board__secret-icon {
  font-size: 12px;
  margin-right: 3px;
}

.fluxshop-board__file-icon {
  font-size: 12px;
  margin-left: 3px;
  opacity: 0.6;
}

.fluxshop-board__content-preview {
  margin: 4px 0 0;
  font-size: var(--fs-font-sm, 13px);
  color: var(--fs-text-light, #888);
  line-height: 1.4;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 500px;
}

.fluxshop-board__comment-bubble {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  margin-left: 6px;
  color: var(--fs-text-muted);
  font-size: 12px;
  font-weight: 600;
  vertical-align: middle;
}

.fluxshop-board__comment-bubble svg {
  stroke: var(--fs-text-muted);
  flex-shrink: 0;
}

.fluxshop-board__reply-prefix {
  display: inline-block;
}

.fluxshop-board__reply-arrow {
  color: var(--fs-text-muted);
  margin-right: 4px;
  font-size: 13px;
}

/* 작성자 셀 */
.fluxshop-board__author-cell {
  text-align: center;
  font-size: var(--fs-font-sm);
  color: var(--fs-text-sub);
}

/* 날짜 셀 */
.fluxshop-board__date-cell {
  text-align: center;
  font-size: var(--fs-font-sm);
  color: var(--fs-text-muted);
}

/* 조회수 셀 */
.fluxshop-board__hit-cell {
  text-align: center;
  font-size: var(--fs-font-sm);
  color: var(--fs-text-muted);
  font-variant-numeric: tabular-nums;
}

/* 좋아요 셀 */
.fluxshop-board__good-cell {
  text-align: center;
  font-size: var(--fs-font-sm);
  color: var(--fs-text-muted);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}

/* 빈 메시지 */
.fluxshop-board__empty {
  padding: 60px 20px;
  text-align: center;
  color: var(--fs-text-muted);
  font-size: var(--fs-font-base);
}

.fluxshop-board__empty-wrap {
  padding: 60px 20px;
  text-align: center;
  color: var(--fs-text-muted);
  border-top: 2px solid var(--fs-text);
  border-bottom: 1px solid var(--fs-border);
}

/* ==========================================================================
   Pagination
   ========================================================================== */

.fluxshop-board__paging {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4px;
  margin: 20px 0 14px;
  flex-wrap: wrap;
}

.fluxshop-paging__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 34px;
  height: 34px;
  padding: 0 8px;
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius-sm);
  text-decoration: none;
  color: var(--fs-text-sub);
  font-size: var(--fs-font-sm);
  font-weight: 500;
  background: var(--fs-bg);
  transition: all var(--fs-transition);
  cursor: pointer;
}

.fluxshop-paging__btn:hover {
  border-color: var(--fs-border-dark);
  color: var(--fs-text);
  background: var(--fs-bg-hover);
}

.fluxshop-paging__btn--active {
  background: var(--fs-primary);
  border-color: var(--fs-primary);
  color: #fff;
  font-weight: 700;
}

.fluxshop-paging__btn--active:hover {
  background: var(--fs-primary-hover);
  border-color: var(--fs-primary-hover);
  color: #fff;
}

/* ==========================================================================
   하단 액션 바
   ========================================================================== */

.fluxshop-board__bottom-bar {
  display: flex;
  justify-content: flex-end;
  padding: 12px 0 0;
}

.fluxshop-board__write-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 24px;
  background: var(--fs-primary);
  color: #fff;
  text-decoration: none;
  border-radius: var(--fs-radius);
  font-size: var(--fs-font-base);
  font-weight: 600;
  transition: background var(--fs-transition), box-shadow var(--fs-transition);
  border: none;
  cursor: pointer;
}

.fluxshop-board__write-btn:hover {
  background: var(--fs-primary-hover);
  color: #fff;
  box-shadow: var(--fs-shadow);
}

/* ==========================================================================
   Board View (게시글 보기)
   ========================================================================== */

.fluxshop-board-view__header {
  padding: 24px 0 20px;
  border-bottom: 1px solid var(--fs-border);
  margin-bottom: 0;
}

.fluxshop-board-view__category-pill {
  display: inline-block;
  padding: 3px 10px;
  background: var(--fs-bg-light);
  color: var(--fs-text-sub);
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius-sm);
  font-size: 12px;
  font-weight: 500;
  margin-bottom: 12px;
}

.fluxshop-board-view__title {
  font-size: 24px;
  font-weight: 700;
  margin: 0 0 16px;
  line-height: 1.4;
  color: var(--fs-text);
  word-break: keep-all;
  letter-spacing: -0.02em;
}

.fluxshop-board-view__secret-icon {
  font-size: 18px;
  margin-right: 6px;
}

/* 메타 바 */
.fluxshop-board-view__meta-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

.fluxshop-board-view__author-info {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.fluxshop-board-view__author-name {
  font-weight: 600;
  color: var(--fs-text);
  font-size: var(--fs-font-base);
}

.fluxshop-board-view__meta-divider {
  color: var(--fs-border-dark);
  font-size: var(--fs-font-sm);
}

.fluxshop-board-view__date,
.fluxshop-board-view__hit {
  color: var(--fs-text-muted);
  font-size: var(--fs-font-sm);
}

/* 수정/삭제 버튼 */
.fluxshop-board-view__post-actions {
  display: flex;
  gap: 6px;
}

.fluxshop-board-view__post-btn.fluxshop-board-view__post-btn {
  padding: 5px 14px;
  font-size: var(--fs-font-sm);
  font-weight: 500;
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius-sm);
  background: var(--fs-bg);
  color: var(--fs-text-sub);
  text-decoration: none;
  cursor: pointer;
  font-family: var(--fs-font);
  transition: all var(--fs-transition);
  display: inline-block;
  box-shadow: none;
}

.fluxshop-board-view__post-btn.fluxshop-board-view__post-btn:hover {
  border-color: var(--fs-border-dark);
  color: var(--fs-text);
  background: var(--fs-bg-hover);
}

.fluxshop-board-view__post-btn--delete.fluxshop-board-view__post-btn--delete:hover {
  border-color: var(--fs-accent);
  color: var(--fs-accent);
  background: #FEF2F2;
}

/* 링크 */
.fluxshop-board-view__links {
  padding: 12px 0;
  border-bottom: 1px solid var(--fs-border);
}

.fluxshop-board-view__links a {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: var(--fs-text-sub);
  text-decoration: underline;
  font-size: var(--fs-font-sm);
  padding: 3px 0;
  word-break: break-all;
}

.fluxshop-board-view__links a:hover {
  text-decoration: underline;
}

/* 본문 */
.fluxshop-board-view__content {
  padding: 32px 0;
  line-height: 1.8;
  min-height: 180px;
  border-bottom: 1px solid var(--fs-border);
  word-break: keep-all;
  overflow-wrap: break-word;
  color: var(--fs-text);
  font-size: 15px;
}

.fluxshop-board-view__content img {
  max-width: 100%;
  height: auto;
  border-radius: 0;
}

/* 에디터 내 이미지도 라운드 없음 */
.note-editor.note-frame .note-editable img {
  border-radius: 0 !important;
}

.fluxshop-board-view__content p {
  margin: 0px;
}

/* 커스텀 필드 (상세) */
.fluxshop-board-view__custom-fields {
  margin: 20px 0;
  padding: 16px 20px;
  background: var(--fs-bg-subtle, #f9fafb);
  border-radius: 8px;
  border: 1px solid var(--fs-border);
}

.fluxshop-board-view__cf-table {
  width: 100%;
  border-collapse: collapse;
}

.fluxshop-board-view__cf-row th {
  text-align: left;
  padding: 8px 12px 8px 0;
  color: var(--fs-text-sub, #6b7280);
  font-size: var(--fs-font-sm, 13px);
  font-weight: 600;
  width: 140px;
  vertical-align: top;
  white-space: nowrap;
}

.fluxshop-board-view__cf-row td {
  padding: 8px 0;
  font-size: var(--fs-font-sm, 13px);
  color: var(--fs-text);
}

.fluxshop-board-view__cf-row.fluxshop-board-view__cf-row td a {
  color: var(--fs-text);
  text-decoration: underline;
}

.fluxshop-board-view__cf-row.fluxshop-board-view__cf-row td a:hover {
  color: var(--fs-text-sub);
}

.fluxshop-board-view__cf-color {
  display: inline-block;
  width: 16px;
  height: 16px;
  border-radius: 3px;
  border: 1px solid rgba(0, 0, 0, .1);
  vertical-align: middle;
  margin-right: 4px;
}

/* 커스텀 필드 뱃지 (목록) */
.fluxshop-board__cf-badge {
  display: inline-block;
  font-size: 11px;
  padding: 1px 6px;
  border-radius: 3px;
  background: var(--fs-bg-light);
  color: var(--fs-text-sub);
  border: 1px solid var(--fs-border);
  margin-left: 4px;
  vertical-align: middle;
}

/* 커스텀 필드 (글쓰기 폼) */
.fluxshop-board-write__field--cf .fluxshop-board-write__radio-group,
.fluxshop-board-write__field--cf .fluxshop-board-write__checkbox-group {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  padding: 12px 14px;
}

.fluxshop-board-write__radio-label.fluxshop-board-write__radio-label,
.fluxshop-board-write__checkbox-label.fluxshop-board-write__checkbox-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: var(--fs-font-sm);
  font-family: var(--fs-font);
  cursor: pointer;
  color: var(--fs-text);
}

.fluxshop-board-write__radio-label.fluxshop-board-write__radio-label input[type="radio"],
.fluxshop-board-write__checkbox-label.fluxshop-board-write__checkbox-label input[type="checkbox"] {
  accent-color: var(--fs-text);
  width: 16px;
  height: 16px;
}

.fluxshop-board-write__field--cf.fluxshop-board-write__field--cf input[type="color"] {
  width: 50px;
  height: 36px;
  padding: 2px;
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius-sm);
  background: var(--fs-bg);
  cursor: pointer;
  margin: 12px 14px;
}

.fluxshop-board-write__field--cf.fluxshop-board-write__field--cf select {
  padding: 12px 14px;
  border: none;
  border-radius: 0;
  font-size: var(--fs-font-base);
  font-family: var(--fs-font);
  background: var(--fs-bg);
  color: var(--fs-text);
  outline: none;
  box-shadow: none;
  -webkit-appearance: none;
  appearance: none;
  flex: 1;
}

.fluxshop-board-write__field--cf.fluxshop-board-write__field--cf textarea {
  width: 100%;
  resize: vertical;
}

/* 첨부파일 */
.fluxshop-board-view__files {
  padding: 16px 0;
  border-bottom: 1px solid var(--fs-border);
}

.fluxshop-board-view__files-label {
  display: block;
  font-size: var(--fs-font-sm);
  font-weight: 600;
  color: var(--fs-text-sub);
  margin-bottom: 8px;
}

.fluxshop-board-view__files-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.fluxshop-board-view__files-list li {
  margin-bottom: 4px;
}

.fluxshop-board-view__file-link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  text-decoration: none;
  color: var(--fs-text);
  font-size: var(--fs-font-sm);
  padding: 4px 0;
  transition: color var(--fs-transition);
}

.fluxshop-board-view__file-link:hover {
  color: var(--fs-text);
  text-decoration: underline;
}

.fluxshop-board-view__file-link--disabled {
  color: var(--fs-text-muted);
  cursor: default;
}

.fluxshop-board-view__file-meta {
  color: var(--fs-text-muted);
  font-size: 12px;
  margin-left: 4px;
}

/* 공유/알림 툴바 (헤더 ↔ 본문 사이) */
.fluxshop-board-view__toolbar {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 6px;
  padding: 12px 0;
}

.fluxshop-board-view__toolbar-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 12px;
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius);
  background: var(--fs-bg);
  color: var(--fs-text-sub);
  font-size: 13px;
  font-weight: 500;
  font-family: var(--fs-font);
  cursor: pointer;
  transition: all var(--fs-transition);
  box-shadow: none;
  line-height: 1;
}

.fluxshop-board-view__toolbar-btn:hover {
  border-color: var(--fs-border-dark);
  color: var(--fs-text);
  background: var(--fs-bg-hover);
}

.fluxshop-board-view__toolbar-icon {
  flex-shrink: 0;
  transition: stroke var(--fs-transition);
}

.fluxshop-board-view__toolbar-btn:hover .fluxshop-board-view__toolbar-icon {
  stroke: var(--fs-text);
}

.fluxshop-board-view__toolbar-btn--subscribe.fluxshop-board-view__toolbar-btn--active {
  border-color: var(--fs-primary);
  color: var(--fs-primary);
  background: var(--fs-primary-bg);
}

.fluxshop-board-view__toolbar-btn--subscribe.fluxshop-board-view__toolbar-btn--active svg {
  fill: var(--fs-primary);
  stroke: var(--fs-primary);
}

.fluxshop-board-view__toolbar-btn--subscribe:hover {
  border-color: var(--fs-primary);
  color: var(--fs-primary);
  background: var(--fs-primary-bg);
}

.fluxshop-board-view__toolbar-label {
  font-size: 12px;
}

/* 반응 버튼 */
.fluxshop-board-view__reactions {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  padding: 20px 0;
  border-bottom: 1px solid var(--fs-border);
}

.fluxshop-board-view__react-btn.fluxshop-board-view__react-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 12px;
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius);
  background: var(--fs-bg);
  color: var(--fs-text-sub);
  font-size: var(--fs-font-sm);
  font-weight: 500;
  font-family: var(--fs-font);
  cursor: pointer;
  transition: all var(--fs-transition);
  box-shadow: none;
}

.fluxshop-board-view__react-btn.fluxshop-board-view__react-btn:hover {
  border-color: var(--fs-border-dark);
  color: var(--fs-text);
  background: var(--fs-bg-hover);
}

.fluxshop-board-view__react-btn:hover .fluxshop-board-view__react-icon {
  stroke: var(--fs-text);
}

.fluxshop-board-view__react-icon {
  flex-shrink: 0;
  transition: stroke var(--fs-transition);
}

.fluxshop-board-view__react-btn--active.fluxshop-board-view__react-btn--active {
  border-color: var(--fs-primary);
  color: var(--fs-primary);
  background: var(--fs-primary-bg);
}

.fluxshop-board-view__react-btn--active .fluxshop-board-view__react-icon {
  stroke: var(--fs-primary);
  fill: var(--fs-primary);
  fill-opacity: 0.2;
}

.fluxshop-board-view__react-btn--share.fluxshop-board-view__react-btn--share {
  padding: 10px 14px;
}

/* 이전/다음 글 */
.fluxshop-board-view__nav {
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius);
  margin-top: 4px;
}

.fluxshop-board-view__nav-row {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 14px 20px;
  border-bottom: 1px solid var(--fs-border);
}

.fluxshop-board-view__nav-row:last-child {
  border-bottom: none;
}

.fluxshop-board-view__nav-label {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--fs-font-sm);
  font-weight: 600;
  color: var(--fs-text-muted);
  min-width: 56px;
  flex-shrink: 0;
}

.fluxshop-board-view__nav-link {
  color: var(--fs-text);
  text-decoration: none;
  font-size: var(--fs-font-base);
  font-weight: 500;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  overflow: hidden;
  transition: color var(--fs-transition);
}

.fluxshop-board-view__nav-link:hover {
  text-decoration: underline;
}

/* 하단 버튼 */
.fluxshop-board-view__footer {
  padding: 16px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.fluxshop-board-view__footer-left,
.fluxshop-board-view__footer-right {
  display: flex;
  gap: 6px;
}

.fluxshop-board-view__list-btn {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius-sm);
  background: var(--fs-bg);
  color: var(--fs-text-sub);
  text-decoration: none;
  font-size: 12px;
  font-weight: 500;
  font-family: var(--fs-font);
  cursor: pointer;
  transition: all var(--fs-transition);
  box-shadow: none;
  -webkit-appearance: none;
  appearance: none;
}

.fluxshop-board-view__list-btn:hover {
  border-color: var(--fs-border-dark);
  color: var(--fs-text);
  background: var(--fs-bg-hover);
}

.fluxshop-board-view__list-btn--delete:hover {
  border-color: var(--fs-accent);
  color: var(--fs-accent);
  background: #FEF2F2;
}

/* ==========================================================================
   Board Write (글쓰기)
   ========================================================================== */

/* WP 테마 스타일 리셋 */
.fluxshop-board-write.fluxshop-board-write input[type="text"],
.fluxshop-board-write.fluxshop-board-write input[type="email"],
.fluxshop-board-write.fluxshop-board-write input[type="url"],
.fluxshop-board-write.fluxshop-board-write input[type="password"],
.fluxshop-board-write.fluxshop-board-write input[type="number"],
.fluxshop-board-write.fluxshop-board-write input[type="tel"],
.fluxshop-board-write.fluxshop-board-write input[type="date"],
.fluxshop-board-write.fluxshop-board-write input[type="search"],
.fluxshop-board-write.fluxshop-board-write select,
.fluxshop-board-write.fluxshop-board-write textarea {
  border: none;
  border-radius: 0;
  box-shadow: none;
  outline: none;
  font-family: var(--fs-font);
  font-size: var(--fs-font-base);
  color: var(--fs-text);
  background: var(--fs-bg);
  padding: 12px 14px;
  margin: 0;
  width: auto;
  max-width: none;
  -webkit-appearance: none;
  appearance: none;
  transition: background var(--fs-transition);
}

.fluxshop-board-write.fluxshop-board-write input[type="text"]:focus,
.fluxshop-board-write.fluxshop-board-write input[type="email"]:focus,
.fluxshop-board-write.fluxshop-board-write input[type="url"]:focus,
.fluxshop-board-write.fluxshop-board-write input[type="password"]:focus,
.fluxshop-board-write.fluxshop-board-write input[type="number"]:focus,
.fluxshop-board-write.fluxshop-board-write input[type="tel"]:focus,
.fluxshop-board-write.fluxshop-board-write input[type="date"]:focus,
.fluxshop-board-write.fluxshop-board-write input[type="search"]:focus,
.fluxshop-board-write.fluxshop-board-write select:focus,
.fluxshop-board-write.fluxshop-board-write textarea:focus {
  background: var(--fs-bg-light);
  box-shadow: none;
  border: none;
  outline: none;
}

.fluxshop-board-write textarea {
  width: 100%;
}

.fluxshop-board-write {
  padding: 0;
}

.fluxshop-board-write__header {
  padding: 20px 0 16px;
  border-bottom: 2px solid var(--fs-text);
  margin-bottom: 0;
}

.fluxshop-board-write__title.fluxshop-board-write__title {
  font-size: 20px;
  font-weight: 700;
  margin: 0;
  padding: 0;
  color: var(--fs-text);
  letter-spacing: -0.02em;
  font-family: var(--fs-font);
  line-height: 1.4;
}

.fluxshop-board-write__form.fluxshop-board-write__form {
  border-top: none;
  border: none;
  box-shadow: none;
  background: transparent;
  padding: 0;
  margin: 0;
}

.fluxshop-board-write__field.fluxshop-board-write__field {
  display: flex;
  align-items: stretch;
  border-bottom: 1px solid var(--fs-border);
  margin: 0;
  padding: 0;
  background: var(--fs-bg-light);
}

.fluxshop-board-write__field--editor {
  align-items: stretch;
}

.fluxshop-board-write__field--editor .fluxshop-board-write__label {
  align-items: flex-start;
  padding-top: 14px;
}

.fluxshop-board-write__label.fluxshop-board-write__label {
  display: flex;
  align-items: center;
  width: 120px;
  min-width: 120px;
  padding: 12px 16px;
  background: var(--fs-bg-light);
  font-size: var(--fs-font-sm);
  font-weight: 600;
  color: var(--fs-text-sub);
  border-right: 1px solid var(--fs-border);
  min-height: 46px;
  font-family: var(--fs-font);
}

.fluxshop-board-write__required {
  color: var(--fs-accent);
  margin-left: 2px;
}

.fluxshop-board-write__input.fluxshop-board-write__input,
.fluxshop-board-write__select.fluxshop-board-write__select,
.fluxshop-board-write.fluxshop-board-write textarea {
  flex: 1;
  padding: 12px 14px;
  border: none;
  border-radius: 0;
  font-size: var(--fs-font-base);
  font-family: var(--fs-font);
  outline: none;
  background: var(--fs-bg);
  color: var(--fs-text);
  transition: background var(--fs-transition);
  box-shadow: none;
  -webkit-appearance: none;
  appearance: none;
  line-height: 1.6;
  min-height: 0;
}

.fluxshop-board-write.fluxshop-board-write textarea {
  width: 100%;
  height: 100%;
}

.fluxshop-board-write__input[readonly] {
  background: var(--fs-bg-light);
  color: var(--fs-text-sub);
  cursor: default;
}

.fluxshop-board-write__input.fluxshop-board-write__input::placeholder,
.fluxshop-board-write.fluxshop-board-write textarea::placeholder {
  color: var(--fs-text-muted);
}

.fluxshop-board-write__input.fluxshop-board-write__input:focus,
.fluxshop-board-write__select.fluxshop-board-write__select:focus,
.fluxshop-board-write.fluxshop-board-write textarea:focus {
  background: var(--fs-bg-light);
  box-shadow: none;
  border: none;
}

.fluxshop-board-write__select.fluxshop-board-write__select {
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 32px;
}

.fluxshop-board-write__help {
  display: block;
  padding: 6px 14px;
  color: var(--fs-text-muted);
  font-size: 12px;
}

.fluxshop-board-write__editor {
  flex: 1;
  min-width: 0;
  padding: 0;
}

.fluxshop-board-write__textarea.fluxshop-board-write__textarea {
  width: 100%;
  padding: 14px;
  border: none;
  border-radius: 0;
  font-size: var(--fs-font-base);
  font-family: var(--fs-font);
  line-height: 1.7;
  outline: none;
  resize: vertical;
  color: var(--fs-text);
  box-shadow: none;
  background: var(--fs-bg);
}

.fluxshop-board-write__editor .wp-editor-wrap {
  width: 100%;
}

.fluxshop-board-write__files {
  flex: 1;
  padding: 12px 14px;
}

.fluxshop-board-write__file-item {
  margin-bottom: 10px;
}

.fluxshop-board-write__file-input.fluxshop-board-write__file-input {
  font-size: var(--fs-font-sm);
  font-family: var(--fs-font);
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius-sm);
  padding: 6px 8px;
  background: var(--fs-bg);
  cursor: pointer;
}

.fluxshop-board-write__file-input.fluxshop-board-write__file-input::file-selector-button {
  font-family: var(--fs-font);
  font-size: var(--fs-font-sm);
  padding: 4px 12px;
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius-sm);
  background: var(--fs-bg-light);
  color: var(--fs-text-sub);
  cursor: pointer;
  margin-right: 8px;
}

.fluxshop-board-write__file-existing {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 6px;
  font-size: var(--fs-font-sm);
  color: var(--fs-text-sub);
}

.fluxshop-board-write__options {
  flex: 1;
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  padding: 12px 14px;
  align-items: center;
}

.fluxshop-board-write__checkbox.fluxshop-board-write__checkbox {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: var(--fs-font-base);
  color: var(--fs-text-sub);
  cursor: pointer;
  font-family: var(--fs-font);
}

.fluxshop-board-write__checkbox.fluxshop-board-write__checkbox input[type="checkbox"] {
  accent-color: var(--fs-text);
  width: 16px;
  height: 16px;
}

.fluxshop-board-write__footer.fluxshop-board-write__footer {
  display: flex;
  justify-content: center;
  gap: 10px;
  padding: 28px 0;
  border: none;
  background: transparent;
}

/* WP 버튼 스타일 리셋 */
.fluxshop-board-write.fluxshop-board-write button[type="submit"],
.fluxshop-board-write.fluxshop-board-write button[type="button"],
.fluxshop-board-write.fluxshop-board-write .fluxshop-btn {
  -webkit-appearance: none;
  appearance: none;
  text-transform: none;
  letter-spacing: normal;
  text-shadow: none;
  min-height: 0;
}

/* 공통 버튼 */
.fluxshop-btn.fluxshop-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 24px;
  font-size: var(--fs-font-base);
  font-family: var(--fs-font);
  font-weight: 500;
  line-height: 1.5;
  text-align: center;
  text-decoration: none;
  vertical-align: middle;
  cursor: pointer;
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius);
  background: var(--fs-bg);
  color: var(--fs-text-sub);
  transition: all var(--fs-transition);
  box-shadow: none;
  -webkit-appearance: none;
  appearance: none;
}

.fluxshop-btn.fluxshop-btn:hover {
  border-color: var(--fs-border-dark);
  color: var(--fs-text);
  background: var(--fs-bg-hover);
}

.fluxshop-btn--primary.fluxshop-btn--primary {
  background: var(--fs-primary);
  border-color: var(--fs-primary);
  color: #fff;
  font-weight: 600;
}

.fluxshop-btn--primary.fluxshop-btn--primary:hover {
  background: var(--fs-primary-hover);
  border-color: var(--fs-primary-hover);
  color: #fff;
  box-shadow: var(--fs-shadow);
}

.fluxshop-btn--delete.fluxshop-btn--delete {
  background: var(--fs-bg);
  border-color: var(--fs-accent);
  color: var(--fs-accent);
}

.fluxshop-btn--delete.fluxshop-btn--delete:hover {
  background: var(--fs-accent);
  color: #fff;
}

.fluxshop-btn--cancel.fluxshop-btn--cancel {
  background: var(--fs-bg);
  border-color: var(--fs-border);
  color: var(--fs-text-muted);
}

/* ==========================================================================
   Comment Section (댓글)
   ========================================================================== */

.fluxshop-comment {
  margin-top: 32px;
  padding: 0;
}

.fluxshop-comment__header {
  padding: 16px 0 14px;
  border-bottom: 2px solid var(--fs-text);
}

.fluxshop-comment__title {
  font-size: var(--fs-font-lg);
  font-weight: 700;
  color: var(--fs-text);
}

.fluxshop-comment__count {
  color: var(--fs-text);
  font-weight: 700;
}

/* 댓글 목록 */
.fluxshop-comment__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.fluxshop-comment__item {
  border-bottom: 1px solid var(--fs-border);
}

.fluxshop-comment__item--reply {
  background: var(--fs-bg-light);
}

.fluxshop-comment__body {
  display: flex;
  gap: 12px;
  padding: 16px 12px;
}

.fluxshop-comment__avatar-wrap {
  flex-shrink: 0;
}

.fluxshop-comment__content-wrap {
  flex: 1;
  min-width: 0;
}

.fluxshop-comment__meta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
  flex-wrap: wrap;
}

.fluxshop-comment__reply-arrow {
  color: var(--fs-text-muted);
  font-size: 14px;
}

.fluxshop-comment__author {
  font-weight: 600;
  font-size: var(--fs-font-base);
  color: var(--fs-text);
}

.fluxshop-comment__date {
  font-size: 12px;
  color: var(--fs-text-muted);
}

/* 수정/삭제 */
.fluxshop-comment__admin-btns {
  display: flex;
  gap: 8px;
  margin-left: auto;
  align-items: center;
}

.fluxshop-comment__text-btn.fluxshop-comment__text-btn {
  padding: 0;
  margin: 0;
  font-size: 12px;
  background: none;
  border: none;
  border-radius: 0;
  box-shadow: none;
  color: var(--fs-text-muted);
  cursor: pointer;
  font-family: var(--fs-font);
  transition: color var(--fs-transition);
  text-decoration: none;
  line-height: 1;
  min-height: 0;
  height: auto;
  display: inline;
}

.fluxshop-comment__text-btn.fluxshop-comment__text-btn:hover {
  color: var(--fs-text);
  background: none;
}

.fluxshop-comment__text-btn--delete.fluxshop-comment__text-btn--delete:hover {
  color: var(--fs-accent);
}

/* 댓글 인라인 편집 */
.fluxshop-comment__edit-textarea {
  width: 100%;
  min-height: 60px;
  padding: 8px 10px;
  font-size: var(--fs-font-base);
  font-family: var(--fs-font);
  line-height: 1.6;
  color: var(--fs-text);
  background: var(--fs-bg);
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius-sm, 6px);
  resize: vertical;
  box-sizing: border-box;
  transition: border-color var(--fs-transition);
}

.fluxshop-comment__edit-textarea:focus {
  outline: none;
  border-color: var(--fs-primary);
}

.fluxshop-comment__edit-actions {
  display: flex;
  gap: 6px;
  margin-top: 6px;
}

.fluxshop-comment__edit-save,
.fluxshop-comment__edit-cancel {
  padding: 4px 12px;
  font-size: 12px;
  font-family: var(--fs-font);
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius-sm, 6px);
  cursor: pointer;
  transition: all var(--fs-transition);
  line-height: 1.4;
}

.fluxshop-comment__edit-save {
  background: var(--fs-primary);
  color: #fff;
  border-color: var(--fs-primary);
}

.fluxshop-comment__edit-save:hover {
  opacity: 0.85;
}

.fluxshop-comment__edit-cancel {
  background: var(--fs-bg);
  color: var(--fs-text-muted);
}

.fluxshop-comment__edit-cancel:hover {
  color: var(--fs-text);
  border-color: var(--fs-text-muted);
}

/* 댓글 내용 */
.fluxshop-comment__text {
  font-size: var(--fs-font-base);
  line-height: 1.65;
  color: var(--fs-text);
  margin-bottom: 6px;
  word-break: keep-all;
  overflow-wrap: break-word;
}

.fluxshop-comment__secret-notice {
  color: var(--fs-text-muted);
  font-style: normal;
  font-size: var(--fs-font-sm);
}

/* 답글 버튼 */
.fluxshop-comment__reply-area {
  margin-top: 4px;
}

.fluxshop-comment__reply-btn.fluxshop-comment__reply-btn {
  background: none;
  border: none;
  border-radius: 0;
  box-shadow: none;
  padding: 0;
  margin: 0;
  font-size: 12px;
  color: var(--fs-text-muted);
  cursor: pointer;
  font-family: var(--fs-font);
  transition: color var(--fs-transition);
  min-height: 0;
  height: auto;
  display: inline;
  line-height: 1;
}

.fluxshop-comment__reply-btn.fluxshop-comment__reply-btn:hover {
  color: var(--fs-text);
  background: none;
}

/* ===================
   댓글 추천/비추천 버튼
   =================== */
.fluxshop-comment__actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 6px;
}

.fluxshop-comment__reactions {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-left: auto;
}

.fluxshop-comment__react-btn {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  padding: 1px 5px;
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius-sm);
  background: var(--fs-bg);
  color: var(--fs-text-muted);
  font-size: 11px;
  line-height: 1;
  cursor: pointer;
  transition: all var(--fs-transition);
}

.fluxshop-comment__react-btn:hover {
  border-color: var(--fs-border-dark, var(--fs-border));
  color: var(--fs-text);
  background: var(--fs-bg-hover, var(--fs-bg));
}

.fluxshop-comment__react-btn--active {
  border-color: var(--fs-primary);
  color: var(--fs-primary);
  background: var(--fs-primary-bg, rgba(var(--fs-primary-rgb, 59, 130, 246), 0.06));
}

.fluxshop-comment__react-btn--active svg {
  fill: currentColor;
  fill-opacity: 0.2;
}

/* ===================
   댓글 더보기 토글 (3줄 클램프)
   =================== */
.fluxshop-comment__text--truncated .fluxshop-comment__text-inner {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.fluxshop-comment__text--expanded .fluxshop-comment__text-inner {
  display: block;
  -webkit-line-clamp: unset;
  overflow: visible;
}

.fluxshop-comment__more-btn {
  display: inline-block;
  margin-top: 4px;
  padding: 0;
  border: none;
  background: none;
  color: var(--fs-text-muted);
  font-size: 12px;
  cursor: pointer;
  text-decoration: underline;
}

.fluxshop-comment__more-btn:hover {
  color: var(--fs-primary);
}

/* ===================
   베스트 댓글
   =================== */
.fluxshop-comment__best {
  margin: 16px 0;
  border: 1px solid var(--fs-primary);
  border-radius: var(--fs-radius);
  overflow: hidden;
}

.fluxshop-comment__best-title {
  padding: 8px 14px;
  background: var(--fs-primary-bg, rgba(var(--fs-primary-rgb, 59, 130, 246), 0.06));
  color: var(--fs-primary);
  font-size: 13px;
  font-weight: 600;
}

.fluxshop-comment__best-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.fluxshop-comment__best-item {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 10px 14px;
  border-top: 1px solid var(--fs-border);
}

.fluxshop-comment__best-item:first-child {
  border-top: none;
}

.fluxshop-comment__best-meta {
  display: flex;
  align-items: center;
  gap: 8px;
}

.fluxshop-comment__best-badge {
  flex-shrink: 0;
  display: inline-block;
  padding: 2px 6px;
  border-radius: 3px;
  background: var(--fs-primary);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  line-height: 1.4;
}

.fluxshop-comment__best-author {
  flex-shrink: 0;
  font-size: 13px;
  font-weight: 500;
  color: var(--fs-text);
}

.fluxshop-comment__best-date {
  flex-shrink: 0;
  font-size: 12px;
  color: var(--fs-text-muted);
}

.fluxshop-comment__best-good {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  gap: 3px;
  margin-left: auto;
  color: var(--fs-primary);
  font-size: 12px;
}

.fluxshop-comment__best-text {
  font-size: 13px;
  color: var(--fs-text-muted);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  line-height: 1.5;
}

/* 본문 내 BEST 댓글 하이라이트 */
.fluxshop-comment__item--best {
  background: var(--fs-primary-bg, rgba(var(--fs-primary-rgb, 59, 130, 246), 0.03));
}

.fluxshop-comment__meta .fluxshop-comment__best-badge {
  font-size: 9px;
  padding: 1px 5px;
}

/* 빈 댓글 */
.fluxshop-comment__empty {
  padding: 32px 0;
  text-align: center;
  color: var(--fs-text-muted);
  font-size: var(--fs-font-sm);
  border-bottom: 1px solid var(--fs-border);
}

/* 댓글 작성 폼 */
.fluxshop-comment__form-wrap {
  margin-top: 24px;
}

.fluxshop-comment__form {
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius);
  overflow: hidden;
  background: var(--fs-bg);
}

.fluxshop-comment__reply-notice {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  background: var(--fs-bg-light);
  font-size: var(--fs-font-sm);
  font-weight: 500;
  color: var(--fs-text-sub);
  border-bottom: 1px solid var(--fs-border);
}

.fluxshop-comment__cancel-btn.fluxshop-comment__cancel-btn {
  background: none;
  border: none;
  font-size: var(--fs-font-sm);
  color: var(--fs-text-muted);
  cursor: pointer;
  font-family: var(--fs-font);
  margin-left: auto;
  padding: 0;
  box-shadow: none;
}

.fluxshop-comment__cancel-btn.fluxshop-comment__cancel-btn:hover {
  color: var(--fs-text);
}

.fluxshop-comment__guest-row {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--fs-border);
}

.fluxshop-comment__guest-input {
  flex: 1;
  padding: 10px 14px;
  border: none;
  border-right: 1px solid var(--fs-border);
  font-size: var(--fs-font-sm);
  font-family: var(--fs-font);
  outline: none;
  color: var(--fs-text);
}

.fluxshop-comment__guest-input::placeholder {
  color: var(--fs-text-muted);
}

.fluxshop-comment__guest-input:last-child {
  border-right: none;
}

.fluxshop-comment__guest-input:focus {
  background: var(--fs-bg-light);
}

.fluxshop-comment__editor-row {
  display: flex;
  align-items: stretch;
}

.fluxshop-comment__textarea {
  flex: 1;
  padding: 12px 14px;
  border: none;
  border-right: 1px solid var(--fs-border);
  font-size: var(--fs-font-base);
  font-family: var(--fs-font);
  line-height: 1.6;
  outline: none;
  resize: none;
  min-height: 84px;
  color: var(--fs-text);
}

.fluxshop-comment__textarea::placeholder {
  color: var(--fs-text-muted);
}

.fluxshop-comment__textarea:focus {
  background: var(--fs-bg-light);
}

.fluxshop-comment__form-side {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  padding: 12px;
  gap: 10px;
  background: var(--fs-bg-light);
  min-width: 84px;
}

.fluxshop-comment__secret-label {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  font-size: 11px;
  color: var(--fs-text-muted);
  cursor: pointer;
}

.fluxshop-comment__secret-label input[type="checkbox"] {
  accent-color: var(--fs-text);
}

.fluxshop-comment__submit-btn.fluxshop-comment__submit-btn {
  display: block;
  width: 100%;
  padding: 8px 12px;
  background: var(--fs-primary);
  color: #fff;
  border: none;
  border-radius: var(--fs-radius-sm);
  box-shadow: none;
  font-size: var(--fs-font-sm);
  font-weight: 600;
  font-family: var(--fs-font);
  cursor: pointer;
  transition: background var(--fs-transition);
  white-space: nowrap;
}

.fluxshop-comment__submit-btn.fluxshop-comment__submit-btn:hover {
  background: var(--fs-primary-hover);
  color: #fff;
}

/* 로그인 요청 */
.fluxshop-comment__login-notice {
  margin-top: 20px;
  padding: 16px;
  background: var(--fs-bg-light);
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius);
  text-align: center;
  color: var(--fs-text-sub);
  font-size: var(--fs-font-sm);
}

.fluxshop-comment__login-notice a {
  color: var(--fs-text);
  font-weight: 600;
  text-decoration: underline;
}

.fluxshop-comment__login-notice a:hover {
  text-decoration: underline;
}

/* ==========================================================================
   Gallery
   ========================================================================== */

.fluxshop-gallery {
  font-family: var(--fs-font);
  font-size: var(--fs-font-base);
  max-width: 960px;
  margin: 0 auto;
  box-sizing: border-box;
}

.fluxshop-gallery__header {
  margin-bottom: 16px;
  padding-bottom: 14px;
  border-bottom: 2px solid var(--fs-text);
}

.fluxshop-gallery__title {
  font-size: 20px;
  font-weight: 700;
  margin: 0;
  color: var(--fs-text);
  letter-spacing: -0.02em;
}

.fluxshop-gallery__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 16px;
  margin-bottom: 20px;
}

.fluxshop-gallery__item {
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius);
  overflow: hidden;
  transition: box-shadow 0.2s, transform 0.2s;
}

.fluxshop-gallery__item:hover {
  box-shadow: var(--fs-shadow);
  transform: translateY(-2px);
}

.fluxshop-gallery__item-link {
  text-decoration: none;
  color: var(--fs-text);
}

.fluxshop-gallery__thumb {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  display: block;
  background: var(--fs-bg-light);
}

.fluxshop-gallery__item-info {
  padding: 12px;
}

.fluxshop-gallery__item-title {
  font-size: var(--fs-font-base);
  font-weight: 600;
  margin: 0 0 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.fluxshop-gallery__item-meta {
  font-size: 12px;
  color: var(--fs-text-muted);
  display: flex;
  justify-content: space-between;
}

.fluxshop-gallery__empty {
  padding: 60px 20px;
  text-align: center;
  color: var(--fs-text-muted);
}

.fluxshop-gallery__footer {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  margin-top: 12px;
}

/* ==========================================================================
   Error / Loading
   ========================================================================== */

.fluxshop-error {
  padding: 16px 20px;
  background: #FEF2F2;
  border: 1px solid #FECACA;
  border-radius: var(--fs-radius);
  color: #991B1B;
  font-size: var(--fs-font-sm);
  margin: 10px 0;
}

.fluxshop-notice {
  padding: 14px 20px;
  border-radius: var(--fs-radius);
  font-size: var(--fs-font-sm);
  margin: 0 0 16px;
  line-height: 1.5;
}

.fluxshop-notice p {
  margin: 0;
}

.fluxshop-notice--error {
  background: #FEF2F2;
  border: 1px solid #FECACA;
  color: #991B1B;
}

.fluxshop-notice--success {
  background: #F0FDF4;
  border: 1px solid #BBF7D0;
  color: #166534;
}

.fluxshop-loader {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(255, 255, 255, 0.65);
  z-index: 99999;
  justify-content: center;
  align-items: center;
}

.fluxshop-loader__spinner {
  width: 36px;
  height: 36px;
  border: 3px solid var(--fs-border);
  border-top-color: var(--fs-primary);
  border-radius: 50%;
  animation: fluxshop-spin 0.7s linear infinite;
  position: absolute;
  top: 50%;
  left: 50%;
  margin: -18px 0 0 -18px;
}

@keyframes fluxshop-spin {
  to {
    transform: rotate(360deg);
  }
}

/* ==========================================================================
   Author Link & Popover
   ========================================================================== */

/* Author trigger (inline) */
.fluxshop-author {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font: inherit;
  color: var(--fs-text);
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  cursor: default;
  vertical-align: middle;
  line-height: 1.4;
}

.fluxshop-author--clickable {
  cursor: pointer;
}

.fluxshop-author--clickable:hover .fluxshop-author__name {
  color: var(--fs-primary);
  text-decoration: underline;
}

.fluxshop-author--clickable:focus-visible {
  outline: 2px solid var(--fs-primary);
  outline-offset: 2px;
  border-radius: var(--fs-radius-sm);
}

.fluxshop-author__name {
  font-size: inherit;
  white-space: nowrap;
}

/* 비회원 IP 표시 */
.fluxshop-board__guest-ip,
.fluxshop-board-view__guest-ip,
.fluxshop-comment__guest-ip {
  display: block;
  font-size: 11px;
  color: var(--fs-text-muted);
  line-height: 1.2;
}

.fluxshop-board-view__guest-ip {
  display: inline;
  margin-left: 4px;
  font-size: 12px;
}

.fluxshop-comment__guest-ip {
  display: inline;
  margin-left: 4px;
  font-size: 11px;
}

/* Popover card (desktop) */
.fluxshop-popover {
  position: absolute;
  z-index: 99999;
  width: 280px;
  background: var(--fs-bg);
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12), 0 2px 8px rgba(0, 0, 0, 0.08);
  font-family: var(--fs-font);
  font-size: var(--fs-font-base);
  color: var(--fs-text);
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 0.15s ease, transform 0.15s ease;
  pointer-events: none;
}

.fluxshop-popover--visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.fluxshop-popover__header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 16px 12px;
}

.fluxshop-popover__avatar {
  border-radius: 50%;
  flex-shrink: 0;
}

.fluxshop-popover__info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.fluxshop-popover__name {
  font-size: 15px;
  font-weight: 600;
  color: var(--fs-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.fluxshop-popover__level {
  font-size: 12px;
  color: var(--fs-text-muted);
}

.fluxshop-popover__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--fs-border);
  border-bottom: 1px solid var(--fs-border);
  margin: 0 16px;
  padding: 10px 0;
  text-align: center;
}

.fluxshop-popover__stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.fluxshop-popover__stat-value {
  font-size: 14px;
  font-weight: 600;
  color: var(--fs-text);
}

.fluxshop-popover__stat-label {
  font-size: 11px;
  color: var(--fs-text-muted);
}

.fluxshop-popover__actions {
  padding: 12px 16px;
}

.fluxshop-popover__btn {
  display: block;
  width: 100%;
  padding: 8px 0;
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius-sm);
  background: var(--fs-bg);
  color: var(--fs-text);
  font-size: 13px;
  font-weight: 500;
  text-align: center;
  text-decoration: none;
  transition: background var(--fs-transition), border-color var(--fs-transition);
  cursor: pointer;
}

.fluxshop-popover__actions {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.fluxshop-popover__btn--secondary {
  background: transparent;
  border-color: transparent;
  color: var(--fs-text-muted);
  font-size: 12px;
  padding: 6px 0;
}

.fluxshop-popover__btn:hover {
  background: var(--fs-bg-hover);
  border-color: var(--fs-border-dark);
  color: var(--fs-text);
  text-decoration: none;
}

/* Popover mobile — bottom sheet */
.fluxshop-popover__overlay {
  position: fixed;
  inset: 0;
  z-index: 99998;
  background: rgba(0, 0, 0, 0);
  transition: background 0.2s ease;
}

.fluxshop-popover__overlay--visible {
  background: rgba(0, 0, 0, 0.4);
}

.fluxshop-popover--mobile {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  max-width: 100%;
  border-radius: 16px 16px 0 0;
  transform: translateY(100%);
  transition: transform 0.25s ease, opacity 0.25s ease;
}

.fluxshop-popover--mobile.fluxshop-popover--visible {
  transform: translateY(0);
}

/* ==========================================================================
   Member Profile (profile-public.php)
   ========================================================================== */

.fluxshop-profile {
  max-width: 720px;
  margin: 0 auto;
  font-size: 14px;
  color: var(--fs-text);
}

/* Header */
.fluxshop-profile__header {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 20px;
  background: var(--fs-bg);
  border: 1px solid var(--fs-border);
  border-radius: 12px;
  margin-bottom: 0;
}

.fluxshop-profile__avatar .fluxshop-avatar,
.fluxshop-profile__avatar img {
  border-radius: 50%;
  flex-shrink: 0;
}

.fluxshop-profile__info {
  flex: 1;
  min-width: 0;
}

.fluxshop-profile__name {
  font-size: 16px;
  font-weight: 700;
  margin: 0 0 4px;
  line-height: 1.3;
  color: var(--fs-text);
}

.fluxshop-profile__meta {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--fs-text-muted);
}

.fluxshop-profile__meta-sep {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: var(--fs-text-muted);
  opacity: 0.4;
}

.fluxshop-profile__level {
  font-weight: 600;
  color: var(--fs-primary, #6B3FA0);
}

.fluxshop-profile__stats {
  display: flex;
  gap: 16px;
  flex-shrink: 0;
}

.fluxshop-profile__stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1px;
  min-width: 44px;
}

.fluxshop-profile__stat-value {
  font-size: 16px;
  font-weight: 700;
  color: var(--fs-text);
  line-height: 1.2;
}

.fluxshop-profile__stat-label {
  font-size: 11px;
  color: var(--fs-text-muted);
}

/* Tabs */
.fluxshop-profile__tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--fs-border);
  margin-top: 0;
}

.fluxshop-profile__tab {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 11px 16px;
  font-size: 13px;
  font-weight: 500;
  color: var(--fs-text-muted);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color 0.2s, border-color 0.2s;
}

.fluxshop-profile__tab:hover {
  color: var(--fs-text);
}

.fluxshop-profile__tab--active {
  color: var(--fs-text);
  border-bottom-color: var(--fs-text);
  font-weight: 600;
}

.fluxshop-profile__tab-count {
  font-size: 11px;
  font-weight: 500;
  color: var(--fs-text-muted);
  background: var(--fs-border-light, #f0f0f0);
  border-radius: 8px;
  padding: 1px 6px;
  line-height: 1.3;
}

.fluxshop-profile__tab--active .fluxshop-profile__tab-count {
  background: var(--fs-primary, #6B3FA0);
  color: #fff;
}

/* Content */
.fluxshop-profile__content {
  min-height: 200px;
}

/* Feed (카드형 리스트) */
.fluxshop-profile__feed {
  display: flex;
  flex-direction: column;
}

.fluxshop-profile__feed-item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 4px;
  border-bottom: 1px solid var(--fs-border-light, #f0f0f0);
  text-decoration: none;
  color: inherit;
  transition: background 0.15s;
}

.fluxshop-profile__feed-item:hover {
  background: var(--fs-border-light, #f8f8f8);
}

.fluxshop-profile__feed-main {
  flex: 1;
  min-width: 0;
}

.fluxshop-profile__feed-board {
  display: inline-block;
  font-size: 11px;
  color: var(--fs-primary, #6B3FA0);
  font-weight: 500;
  margin-bottom: 2px;
}

.fluxshop-profile__feed-title {
  font-size: 14px;
  font-weight: 500;
  color: var(--fs-text);
  margin: 0;
  line-height: 1.5;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.fluxshop-profile__feed-item:hover .fluxshop-profile__feed-title {
  color: var(--fs-primary, #6B3FA0);
}

.fluxshop-profile__feed-origin {
  font-size: 13px;
  font-weight: 500;
  color: var(--fs-text);
  margin-bottom: 2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.fluxshop-profile__feed-excerpt {
  font-size: 12px;
  color: var(--fs-text-muted);
  line-height: 1.5;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.fluxshop-profile__feed-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
  flex-shrink: 0;
  padding-top: 2px;
}

.fluxshop-profile__feed-date {
  font-size: 11px;
  color: var(--fs-text-muted);
  white-space: nowrap;
}

.fluxshop-profile__feed-hit {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 11px;
  color: var(--fs-text-muted);
}

.fluxshop-profile__feed-hit svg {
  opacity: 0.5;
}

/* Empty */
.fluxshop-profile__empty {
  padding: 48px 16px;
  text-align: center;
  color: var(--fs-text-muted);
}

.fluxshop-profile__empty svg {
  display: block;
  margin: 0 auto 10px;
  opacity: 0.2;
  color: var(--fs-text-muted);
  width: 36px;
  height: 36px;
}

.fluxshop-profile__empty p {
  margin: 0;
  font-size: 13px;
}

/* Profile responsive */
@media (max-width: 768px) {
  .fluxshop-profile__header {
    flex-wrap: wrap;
    gap: 12px;
    padding: 16px 14px;
    border-radius: 10px;
  }

  .fluxshop-profile__stats {
    width: 100%;
    justify-content: center;
    gap: 28px;
    padding-top: 12px;
    border-top: 1px solid var(--fs-border-light, #f0f0f0);
  }

  .fluxshop-profile__feed-item {
    padding: 11px 2px;
  }

  .fluxshop-profile__feed-title {
    white-space: normal;
    -webkit-line-clamp: 2;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
}

@media (max-width: 480px) {
  .fluxshop-profile__header {
    padding: 14px 12px;
    gap: 10px;
  }

  .fluxshop-profile__name {
    font-size: 15px;
  }

  .fluxshop-profile__tab {
    flex: 1;
    justify-content: center;
    padding: 10px 6px;
    font-size: 12px;
  }

  .fluxshop-profile__feed-item {
    flex-direction: column;
    gap: 4px;
  }

  .fluxshop-profile__feed-meta {
    flex-direction: row;
    align-items: center;
    gap: 10px;
  }
}

/* ==========================================================================
   Responsive
   ========================================================================== */

@media (max-width: 768px) {

  .fluxshop-board,
  .fluxshop-board-view,
  .fluxshop-board-write,
  .fluxshop-gallery,
  .fluxshop-comment {
    font-size: 13px;
    padding: 16px 12px 0;
  }

  /* Toolbar */
  .fluxshop-board__toolbar {
    flex-direction: column-reverse;
    align-items: stretch;
    gap: 10px;
  }

  .fluxshop-board__search-input {
    width: 100%;
    flex: 1;
  }

  .fluxshop-board__search-form {
    flex: 1;
  }

  /* 카테고리: 가로 스크롤 */
  .fluxshop-board__cats {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding-bottom: 4px;
    gap: 6px;
  }

  .fluxshop-board__cats::-webkit-scrollbar {
    display: none;
  }

  .fluxshop-board__cat {
    white-space: nowrap;
    flex-shrink: 0;
  }

  .fluxshop-board__subcats {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding-bottom: 4px;
    gap: 5px;
  }

  .fluxshop-board__subcats::-webkit-scrollbar {
    display: none;
  }

  .fluxshop-board__subcat {
    white-space: nowrap;
    flex-shrink: 0;
  }

  /* ── 모바일 카드형 변환: table → block ── */
  .fluxshop-board__table {
    border-top: none;
  }

  .fluxshop-board__table colgroup,
  .fluxshop-board__table thead {
    display: none;
  }

  .fluxshop-board__table,
  .fluxshop-board__table tbody {
    display: block;
    width: 100%;
  }

  /* 각 행 = 카드 (2줄 구조) */
  .fluxshop-board__row {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    padding: 14px 0;
    border-bottom: 1px solid var(--fs-border);
    row-gap: 6px;
    column-gap: 0;
  }

  /* 1행/2행 강제 줄바꿈: ::after를 order:4로 배치 */
  .fluxshop-board__row::after {
    content: "";
    flex-basis: 100%;
    height: 0;
    order: 4;
  }

  .fluxshop-board__row:first-child {
    border-top: 2px solid var(--fs-text);
  }

  .fluxshop-board__row td {
    display: block;
    padding: 0;
    border: none;
    background: none;
  }

  /* 1행: 배지/번호 + 카테고리 + 제목 */
  .fluxshop-board__num {
    order: 1;
    flex-shrink: 0;
    margin-right: 6px;
    font-size: 12px;
  }

  .fluxshop-board__cat-cell {
    order: 2;
    flex-shrink: 0;
    margin-right: 4px;
  }

  .fluxshop-board__cat-badge {
    font-size: 12px;
    padding: 1px 6px;
  }

  .fluxshop-board__subject-cell {
    order: 3;
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .fluxshop-board__subject-link {
    font-size: 14px;
  }

  /* 2행: 글쓴이 · 작성시간 · 조회수 · 좋아요 */
  .fluxshop-board__author-cell {
    order: 5;
  }

  .fluxshop-board__date-cell {
    order: 6;
  }

  .fluxshop-board__hit-cell {
    order: 7;
  }

  .fluxshop-board__good-cell {
    order: 8;
  }

  .fluxshop-board__author-cell,
  .fluxshop-board__date-cell,
  .fluxshop-board__hit-cell,
  .fluxshop-board__good-cell {
    font-size: 12px;
    color: var(--fs-text-muted);
    white-space: nowrap;
  }

  /* 구분자 (·) 추가 */
  .fluxshop-board__date-cell::before,
  .fluxshop-board__hit-cell::before,
  .fluxshop-board__good-cell::before {
    content: "·";
    margin: 0 5px;
    color: var(--fs-text-muted);
  }

  /* 조회/좋아요: "조회 123", "좋아요 5" 형태 */
  .fluxshop-board__hit-cell::before {
    content: "· 조회 ";
    margin-left: 5px;
    margin-right: 0;
  }

  .fluxshop-board__good-cell::before {
    content: "· 좋아요 ";
    margin-left: 5px;
    margin-right: 0;
  }

  /* 배지: 공지/인기 */
  .fluxshop-board__badge-notice,
  .fluxshop-board__badge-popular {
    font-size: 10px;
    padding: 1px 6px;
    vertical-align: middle;
  }

  /* 공지/인기 행 모바일 배경 */
  .fluxshop-board__row--notice {
    background: var(--fs-bg-light);
    padding: 14px 12px;
    margin: 0 -12px;
    border-radius: 0;
  }

  .fluxshop-board__row--popular {
    padding: 14px 12px;
    margin: 0 -12px;
  }

  /* View */
  .fluxshop-board-view__title {
    font-size: 20px;
  }

  .fluxshop-board-view__meta-bar {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }

  .fluxshop-board-view__post-actions {
    align-self: flex-end;
  }

  .fluxshop-board-view__toolbar-btn {
    padding: 5px 10px;
  }

  .fluxshop-board-view__reactions {
    gap: 8px;
  }

  .fluxshop-board-view__react-btn.fluxshop-board-view__react-btn {
    padding: 8px 14px;
  }

  /* Write form */
  .fluxshop-board-write__field {
    flex-direction: column;
  }

  .fluxshop-board-write__label.fluxshop-board-write__label {
    width: 100%;
    min-width: auto;
    border-right: none;
    border-bottom: 1px solid var(--fs-border);
    min-height: 38px;
    padding: 10px 14px;
  }

  .fluxshop-board-write__files {
    background: var(--fs-bg-light);
  }

  /* Comment form */
  .fluxshop-comment__editor-row {
    flex-direction: column;
  }

  .fluxshop-comment__textarea {
    border-right: none;
    border-bottom: 1px solid var(--fs-border);
  }

  .fluxshop-comment__form-side {
    flex-direction: row;
    justify-content: flex-end;
    min-width: auto;
    background: transparent;
    border-top: none;
  }

  .fluxshop-comment__submit-btn.fluxshop-comment__submit-btn {
    width: auto;
    padding: 8px 18px;
  }

  /* Gallery */
  .fluxshop-gallery__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }
}

@media (max-width: 480px) {
  .fluxshop-gallery__grid {
    grid-template-columns: 1fr;
  }

  .fluxshop-board-view__reactions {
    flex-wrap: wrap;
    justify-content: center;
  }

  /* 카드형에서 제목 줄바꿈 허용 (초소형 화면) */
  .fluxshop-board__subject-cell {
    white-space: normal;
  }
}

/* ==========================================================================
   Summernote Editor
   ========================================================================== */

/* ── 에디터 컨테이너 ── */
.fluxshop-summernote-editor + .note-editor.note-frame,
.note-editor.note-frame {
  border: 1px solid var(--fs-border, #E5E5E5);
  border-radius: var(--fs-radius-sm, 6px);
  font-family: 'Pretendard Variable', 'Pretendard', var(--fs-font, sans-serif);
  box-shadow: none;
}

/* ── 툴바 ── */
.note-editor.note-frame .note-toolbar {
  background: var(--fs-bg-light, #F9F9F9);
  border-bottom: 1px solid var(--fs-border, #E5E5E5);
  border-radius: var(--fs-radius-sm, 6px) var(--fs-radius-sm, 6px) 0 0;
  padding: 4px 6px;
  display: flex;
  flex-wrap: wrap;
  gap: 2px;
}

/* 툴바 버튼 그룹 */
.note-editor.note-frame .note-toolbar .note-btn-group {
  margin: 0;
}

.note-editor.note-frame .note-toolbar .note-btn {
  background: transparent;
  border: none;
  border-radius: 4px;
  color: var(--fs-text, #333);
  font-size: 13px;
  padding: 4px 7px;
  height: 30px;
  line-height: 1;
  transition: background 0.15s ease;
}

.note-editor.note-frame .note-toolbar .note-btn:hover,
.note-editor.note-frame .note-toolbar .note-btn:focus {
  background: var(--fs-bg-hover, #EBEBEB);
  color: var(--fs-text, #111);
}

.note-editor.note-frame .note-toolbar .note-btn.active {
  background: var(--fs-primary, #2563EB);
  color: #fff;
}

/* 폰트 선택기 드롭다운 */
.note-editor.note-frame .note-toolbar .note-fontname,
.note-editor.note-frame .note-toolbar .note-fontsize {
  font-size: 13px;
  height: 30px;
  padding: 0 6px;
  border: 1px solid var(--fs-border, #E5E5E5);
  border-radius: 4px;
  background: var(--fs-bg, #fff);
  color: var(--fs-text, #333);
}

/* ── 편집 영역 ── */
.note-editor.note-frame .note-editable {
  font-family: 'Pretendard Variable', 'Pretendard', 'Noto Sans KR', '나눔고딕', sans-serif;
  font-size: 15px;
  line-height: 1.75;
  color: var(--fs-text, #111);
  padding: 16px;
  min-height: 360px;
}

.note-editor.note-frame .note-editable p {
  margin: 0;
}

/* ── 플레이스홀더 ── */
.note-editor.note-frame .note-placeholder {
  color: var(--fs-text-muted, #9CA3AF);
  font-family: 'Pretendard Variable', 'Pretendard', sans-serif;
  font-size: 15px;
  padding: 16px;
}

/* ── 에디터 내 이미지 ── */
.note-editor.note-frame .note-editable img {
  max-width: 100%;
  height: auto;
}

/* ── 에디터 내 테이블 ── */
.note-editor.note-frame .note-editable table {
  border-collapse: collapse;
  width: auto;
}

.note-editor.note-frame .note-editable th,
.note-editor.note-frame .note-editable td {
  border: 1px solid var(--fs-border, #E5E5E5);
  padding: 6px 12px;
}

.note-editor.note-frame .note-editable th {
  background: var(--fs-bg-light, #F9F9F9);
  font-weight: 600;
}

/* ── 하단 상태바 ── */
.note-editor.note-frame .note-statusbar {
  background: var(--fs-bg-light, #F9F9F9);
  border-top: 1px solid var(--fs-border, #E5E5E5);
  border-radius: 0 0 var(--fs-radius-sm, 6px) var(--fs-radius-sm, 6px);
}

/* ── 드롭다운 메뉴 ── */
.note-dropdown-menu {
  border: 1px solid var(--fs-border, #E5E5E5);
  border-radius: var(--fs-radius-sm, 6px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.note-dropdown-menu .note-dropdown-item:hover {
  background: var(--fs-bg-hover, #F5F5F5);
}

/* ── 전체화면 모드 ── */
.note-editor.note-frame.fullscreen {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100vw !important;
  height: 100dvh !important;
  z-index: 9999 !important;
  border-radius: 0 !important;
  border: none !important;
  background: #fff !important;
  display: flex !important;
  flex-direction: column;
}

.note-editor.note-frame.fullscreen .note-toolbar {
  border-radius: 0 !important;
  flex-shrink: 0;
  position: sticky;
  top: 0;
  z-index: 10;
}

.note-editor.note-frame.fullscreen .note-editing-area {
  flex: 1;
  overflow-y: auto;
}

.note-editor.note-frame.fullscreen .note-editable {
  min-height: calc(100dvh - 120px) !important;
}

.note-editor.note-frame.fullscreen .note-statusbar {
  border-radius: 0 !important;
  flex-shrink: 0;
}

body.note-fullscreen-body {
  overflow: hidden;
}

/* ── Summernote 다이얼로그 모달 (링크·비디오 삽입 등) ── */

/* 백드롭 */
.note-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(10, 10, 15, 0.6);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: 10000;
}

/* 다이얼로그 컨테이너 */
.note-modal {
  position: fixed;
  inset: 0;
  z-index: 10001;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  pointer-events: none;
}

/* 전체화면 위 모달은 z-index 더 높여야 함 */
.note-editor.note-frame.fullscreen .note-modal {
  z-index: 19999;
}

.note-editor.note-frame.fullscreen .note-modal-backdrop {
  z-index: 19998;
}

/* 모달 콘텐츠 박스 */
.note-modal-content {
  background: #fff;
  border-radius: 14px;
  width: min(96vw, 460px);
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.04),
    0 8px 24px rgba(0, 0, 0, 0.08),
    0 20px 48px rgba(0, 0, 0, 0.12);
  overflow: hidden;
  pointer-events: auto;
  border: none;
}

/* 모달 헤더 */
.note-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid #F0F0F0;
  background: #FAFAFA;
}

.note-modal-title {
  font-size: 15px;
  font-weight: 600;
  color: #111;
  margin: 0;
  letter-spacing: -0.01em;
}

.note-modal-header .close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: none;
  border: none;
  border-radius: 6px;
  color: #888;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  opacity: 1;
  transition: background 0.15s, color 0.15s;
}

.note-modal-header .close:hover {
  background: #EBEBEB;
  color: #111;
  opacity: 1;
}

/* 모달 바디 */
.note-modal-body {
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.note-form-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin: 0;
}

.note-form-label {
  font-size: 13px;
  font-weight: 600;
  color: #222;
  letter-spacing: -0.01em;
}

/* 입력 필드 */
.note-form-control,
.note-input {
  display: block;
  width: 100%;
  height: 42px;
  padding: 0 14px;
  border: 1.5px solid #E0E0E0;
  border-radius: 8px;
  font-size: 14px;
  color: #111;
  background: #FAFAFA;
  transition: all 0.2s ease;
  outline: none;
  box-sizing: border-box;
  font-family: 'Pretendard Variable', 'Pretendard', sans-serif;
}

.note-form-control:hover,
.note-input:hover {
  border-color: #C0C0C0;
  background: #fff;
}

.note-form-control:focus,
.note-input:focus {
  border-color: var(--fs-primary, #2563EB);
  box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.08);
  background: #fff;
}

/* 새 창 열기 체크박스 */
.note-modal-body .checkbox {
  margin: 0;
  padding: 10px 0 4px;
}

.note-modal-body .checkbox label {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  font-size: 13px;
  color: #333;
  margin: 0;
  font-weight: 500;
  letter-spacing: -0.01em;
}

.note-modal-body .checkbox input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--fs-primary, #2563EB);
  cursor: pointer;
  flex-shrink: 0;
  border-radius: 4px;
}

/* Use default protocol 체크박스 숨기기 */
.note-link-protocal,
.note-modal-body .checkbox.note-link-protocal {
  display: none !important;
}

/* 모달 푸터 */
.note-modal-footer {
  padding: 16px 24px;
  border-top: 1px solid #EBEBEB;
  display: flex;
  justify-content: flex-end;
  background: #FAFAFA;
}

/* 삽입 버튼 */
.note-link-btn,
.note-image-btn,
.note-modal-footer .note-btn,
.note-modal-footer .btn {
  height: 40px;
  padding: 0 24px;
  background: var(--fs-primary, #2563EB);
  border: none;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 600;
  color: #fff;
  cursor: pointer;
  transition: all 0.2s ease;
  line-height: 40px;
  display: inline-flex;
  align-items: center;
  letter-spacing: -0.01em;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
}

.note-link-btn:hover:not([disabled]),
.note-image-btn:hover:not([disabled]),
.note-modal-footer .note-btn:hover:not([disabled]) {
  filter: brightness(1.1);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.12);
  transform: translateY(-1px);
}

.note-link-btn:active:not([disabled]),
.note-image-btn:active:not([disabled]),
.note-modal-footer .note-btn:active:not([disabled]) {
  transform: translateY(0);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
}

.note-link-btn[disabled],
.note-image-btn[disabled],
.note-modal-footer .note-btn[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
  filter: none;
  box-shadow: none;
  transform: none;
}

/* ── 크롭 모달 ── */
.fluxshop-crop-modal {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(10, 10, 15, 0.8);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: 100000;
  align-items: center;
  justify-content: center;
  padding: 16px;
}

.fluxshop-crop-modal--open {
  display: flex;
}

.fluxshop-crop-modal__inner {
  background: #fff;
  border-radius: 12px;
  width: min(96vw, 860px);
  max-height: 94vh;
  display: flex;
  flex-direction: column;
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.06),
    0 8px 24px rgba(0, 0, 0, 0.12),
    0 32px 64px rgba(0, 0, 0, 0.18);
  overflow: hidden;
}

/* 헤더 */
.fluxshop-crop-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid #F0F0F0;
  flex-shrink: 0;
  background: #FAFAFA;
}

.fluxshop-crop-modal__header-left {
  display: flex;
  align-items: center;
  gap: 8px;
}

.fluxshop-crop-modal__icon {
  color: var(--fs-primary, #2563EB);
  flex-shrink: 0;
}

.fluxshop-crop-modal__title {
  font-size: 15px;
  font-weight: 600;
  color: #111;
  margin: 0;
  letter-spacing: -0.01em;
}

.fluxshop-crop-modal__close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: none;
  border: none;
  border-radius: 6px;
  color: #888;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
  flex-shrink: 0;
}

.fluxshop-crop-modal__close:hover {
  background: #F0F0F0;
  color: #111;
}

/* 이미지 영역 (어두운 배경으로 편집 편의성 향상) */
.fluxshop-crop-modal__body {
  flex: 1;
  overflow: hidden;
  min-height: 280px;
  max-height: calc(94vh - 200px);
  background: #1C1C1E;
  position: relative;
}

.fluxshop-crop-modal__body img {
  display: block;
  max-width: 100%;
  max-height: 100%;
}

/* 비율 툴바 */
.fluxshop-crop-modal__toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  border-top: 1px solid #F0F0F0;
  border-bottom: 1px solid #F0F0F0;
  background: #FAFAFA;
  flex-shrink: 0;
  flex-wrap: wrap;
}

.fluxshop-crop-modal__toolbar-label {
  font-size: 12px;
  font-weight: 500;
  color: #666;
  margin-right: 2px;
  white-space: nowrap;
}

.fluxshop-crop-ratio-group {
  display: flex;
  gap: 4px;
}

.fluxshop-crop-ratio-btn {
  height: 28px;
  padding: 0 12px;
  background: #fff;
  border: 1px solid #E0E0E0;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 500;
  color: #555;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
  white-space: nowrap;
}

.fluxshop-crop-ratio-btn:hover {
  border-color: var(--fs-primary, #2563EB);
  color: var(--fs-primary, #2563EB);
}

.fluxshop-crop-ratio-btn.active {
  background: var(--fs-primary, #2563EB);
  border-color: var(--fs-primary, #2563EB);
  color: #fff;
}

.fluxshop-crop-modal__toolbar-hint {
  font-size: 11px;
  color: #AAA;
  margin-left: auto;
  white-space: nowrap;
}

/* 푸터 */
.fluxshop-crop-modal__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 12px 20px;
  flex-shrink: 0;
  background: #fff;
}

.fluxshop-crop-modal__footer-right {
  display: flex;
  gap: 8px;
}

/* 버튼 */
.fluxshop-crop-modal__btn {
  height: 36px;
  padding: 0 16px;
  border-radius: 7px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, opacity 0.15s;
  white-space: nowrap;
  border: 1px solid transparent;
  line-height: 1;
}

.fluxshop-crop-modal__btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.fluxshop-crop-modal__btn--ghost {
  background: none;
  border-color: transparent;
  color: #888;
}

.fluxshop-crop-modal__btn--ghost:hover {
  background: #F5F5F5;
  color: #333;
}

.fluxshop-crop-modal__btn--secondary {
  background: #fff;
  border-color: #D8D8D8;
  color: #333;
}

.fluxshop-crop-modal__btn--secondary:hover {
  background: #F5F5F5;
  border-color: #BDBDBD;
}

.fluxshop-crop-modal__btn--primary {
  background: var(--fs-primary, #2563EB);
  border-color: var(--fs-primary, #2563EB);
  color: #fff;
}

.fluxshop-crop-modal__btn--primary:hover:not(:disabled) {
  filter: brightness(1.08);
}

@media (max-width: 768px) {
  .fluxshop-crop-modal {
    padding: 0;
    align-items: flex-end;
  }

  .fluxshop-crop-modal__inner {
    width: 100vw;
    max-height: 95dvh;
    border-radius: 16px 16px 0 0;
  }

  .fluxshop-crop-modal__body {
    max-height: calc(95dvh - 180px);
  }

  .fluxshop-crop-modal__toolbar-hint {
    display: none;
  }
}

/* ── 업로드 중 로딩 ── */
.fluxshop-editor--uploading {
  position: relative;
  pointer-events: none;
  opacity: 0.7;
}

.fluxshop-editor--uploading::after {
  content: '업로드 중...';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: rgba(0, 0, 0, 0.7);
  color: #fff;
  padding: 8px 16px;
  border-radius: var(--fs-radius-sm, 6px);
  font-size: 14px;
  z-index: 100;
  pointer-events: none;
}

/* ── 반응형 ── */
@media (max-width: 768px) {
  .note-editor.note-frame {
    border-radius: 0;
    border-left: none;
    border-right: none;
  }

  .note-editor.note-frame .note-toolbar {
    border-radius: 0;
    padding: 3px 4px;
  }

  .note-editor.note-frame .note-toolbar .note-btn {
    padding: 4px 6px;
    height: 28px;
  }
}

/* ==========================================================================
   Toast Notification
   ========================================================================== */

.fluxshop-toast-container {
  position: fixed;
  top: 24px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 999999;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  pointer-events: none;
  width: max-content;
  max-width: 90vw;
}

.fluxshop-toast {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 20px;
  border-radius: 8px;
  font-family: var(--fs-font);
  font-size: 14px;
  font-weight: 500;
  line-height: 1.4;
  color: #fff;
  background: #2a2a2a;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.18), 0 1px 4px rgba(0, 0, 0, 0.1);
  pointer-events: auto;
  cursor: pointer;
  opacity: 0;
  transform: translateY(-12px);
  transition: opacity 0.25s ease, transform 0.25s ease;
  max-width: 90vw;
  word-break: keep-all;
}

.fluxshop-toast--visible {
  opacity: 1;
  transform: translateY(0);
}

.fluxshop-toast--hiding {
  opacity: 0;
  transform: translateY(-12px);
}

.fluxshop-toast--success {
  background: #2a2a2a;
}

.fluxshop-toast--error {
  background: #2a2a2a;
}

.fluxshop-toast--warning {
  background: #2a2a2a;
}

.fluxshop-toast--info {
  background: #2a2a2a;
}

.fluxshop-toast--success .fluxshop-toast__icon {
  color: #4ade80;
}

.fluxshop-toast--error .fluxshop-toast__icon {
  color: #f87171;
}

.fluxshop-toast--warning .fluxshop-toast__icon {
  color: #fbbf24;
}

.fluxshop-toast--info .fluxshop-toast__icon {
  color: #94a3b8;
}

.fluxshop-toast__icon {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

.fluxshop-toast__icon svg {
  display: block;
}

.fluxshop-toast__message {
  white-space: pre-line;
}

/* ==========================================================================
   Report Modal (신고)
   ========================================================================== */

.fluxshop-report-modal {
  position: fixed;
  inset: 0;
  z-index: 999998;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: fluxshop-report-fade-in 0.2s ease;
}

.fluxshop-report-modal__overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}

@keyframes fluxshop-report-fade-in {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.fluxshop-report-modal__dialog {
  position: relative;
  background: var(--fs-bg);
  border-radius: 16px;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.18), 0 8px 24px rgba(0, 0, 0, 0.08);
  width: 400px;
  max-width: calc(100vw - 32px);
  max-height: calc(100vh - 64px);
  overflow-y: auto;
  animation: fluxshop-report-slide-up 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

@keyframes fluxshop-report-slide-up {
  from {
    opacity: 0;
    transform: translateY(20px) scale(0.97);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* Header */
.fluxshop-report-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 22px 24px 0;
}

.fluxshop-report-modal__title {
  font-size: 18px;
  font-weight: 700;
  color: var(--fs-text);
  margin: 0;
  font-family: var(--fs-font);
  letter-spacing: -0.02em;
}

.fluxshop-report-modal__close.fluxshop-report-modal__close {
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  box-shadow: none;
  padding: 0;
  margin: 0;
  cursor: pointer;
  color: var(--fs-text-muted);
  width: 32px;
  height: 32px;
  min-height: 0;
  border-radius: 8px;
  transition: all var(--fs-transition);
}

.fluxshop-report-modal__close.fluxshop-report-modal__close:hover {
  color: var(--fs-text);
  background: var(--fs-bg-hover);
}

.fluxshop-report-modal__close svg {
  flex-shrink: 0;
}

/* Body */
.fluxshop-report-modal__body {
  padding: 16px 24px 24px;
}

.fluxshop-report-modal__desc {
  font-size: var(--fs-font-sm);
  color: var(--fs-text-sub);
  margin: 0 0 14px;
  font-family: var(--fs-font);
}

/* 사유 라디오 목록 */
.fluxshop-report-modal__reasons {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 16px;
}

.fluxshop-report-modal__reason {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border: 1.5px solid var(--fs-border);
  border-radius: 10px;
  background: var(--fs-bg);
  cursor: pointer;
  transition: all 0.2s ease;
  font-family: var(--fs-font);
}

.fluxshop-report-modal__reason:hover {
  border-color: var(--fs-border-dark);
  background: var(--fs-bg-light);
}

/* 선택된 사유 */
.fluxshop-report-modal__reason:has(input:checked) {
  border-color: var(--fs-primary);
  background: var(--fs-bg-light);
}

/* 네이티브 라디오 숨기기 */
.fluxshop-report-modal__reason.fluxshop-report-modal__reason input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  margin: 0;
  pointer-events: none;
}

/* 커스텀 라디오 */
.fluxshop-report-modal__reason-radio.fluxshop-report-modal__reason-radio {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  min-width: 18px;
  border: 2px solid var(--fs-border-dark);
  border-radius: 50%;
  flex-shrink: 0;
  transition: all 0.2s ease;
  box-sizing: border-box;
}

.fluxshop-report-modal__reason-radio::after {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--fs-primary);
  transform: scale(0);
  transition: transform 0.2s cubic-bezier(0.16, 1, 0.3, 1);
}

.fluxshop-report-modal__reason input:checked~.fluxshop-report-modal__reason-radio {
  border-color: var(--fs-primary);
}

.fluxshop-report-modal__reason input:checked~.fluxshop-report-modal__reason-radio::after {
  transform: scale(1);
}

/* 사유 아이콘 */
.fluxshop-report-modal__reason-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--fs-text-muted);
  flex-shrink: 0;
  transition: color 0.2s ease;
}

.fluxshop-report-modal__reason input:checked~.fluxshop-report-modal__reason-icon {
  color: var(--fs-text);
}

/* 사유 텍스트 */
.fluxshop-report-modal__reason-text.fluxshop-report-modal__reason-text {
  font-size: var(--fs-font-base);
  color: var(--fs-text);
  font-weight: 500;
  line-height: 1;
}

/* 기타 상세 입력 */
.fluxshop-report-modal__detail {
  margin-bottom: 16px;
}

.fluxshop-report-modal__detail.fluxshop-report-modal__detail textarea {
  width: 100%;
  padding: 12px 14px;
  border: 1.5px solid var(--fs-border);
  border-radius: 10px;
  font-size: var(--fs-font-sm);
  font-family: var(--fs-font);
  line-height: 1.6;
  resize: none;
  outline: none;
  box-shadow: none;
  color: var(--fs-text);
  background: var(--fs-bg);
  transition: border-color 0.2s ease;
  min-height: 80px;
  box-sizing: border-box;
}

.fluxshop-report-modal__detail.fluxshop-report-modal__detail textarea:focus {
  border-color: var(--fs-primary);
}

.fluxshop-report-modal__detail.fluxshop-report-modal__detail textarea::placeholder {
  color: var(--fs-text-muted);
}

/* 동의 체크박스 */
.fluxshop-report-modal__consent {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  background: var(--fs-bg-light);
  border: 1px solid var(--fs-border);
  border-radius: 10px;
  cursor: pointer;
  transition: border-color 0.2s ease;
}

.fluxshop-report-modal__consent:hover {
  border-color: var(--fs-border-dark);
}

/* 네이티브 체크박스 숨기기 */
.fluxshop-report-modal__consent.fluxshop-report-modal__consent input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  margin: 0;
  pointer-events: none;
}

/* 커스텀 체크박스 */
.fluxshop-report-modal__consent-check.fluxshop-report-modal__consent-check {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  min-width: 18px;
  border: 2px solid var(--fs-border-dark);
  border-radius: 5px;
  flex-shrink: 0;
  transition: all 0.2s ease;
  box-sizing: border-box;
}

.fluxshop-report-modal__consent-check::after {
  content: '';
  width: 10px;
  height: 10px;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 12 12' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M2.5 6L5 8.5L9.5 3.5' stroke='white' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
  opacity: 0;
  transform: scale(0.5);
  transition: all 0.2s cubic-bezier(0.16, 1, 0.3, 1);
}

.fluxshop-report-modal__consent input:checked~.fluxshop-report-modal__consent-check {
  background: var(--fs-primary);
  border-color: var(--fs-primary);
}

.fluxshop-report-modal__consent input:checked~.fluxshop-report-modal__consent-check::after {
  opacity: 1;
  transform: scale(1);
}

.fluxshop-report-modal__consent-text {
  font-size: var(--fs-font-sm);
  color: var(--fs-text-sub);
  line-height: 1.4;
  font-family: var(--fs-font);
}

/* 하단 버튼 */
.fluxshop-report-modal__footer {
  display: flex;
  gap: 8px;
  padding: 0 24px 24px;
}

.fluxshop-report-modal__cancel.fluxshop-report-modal__cancel {
  flex: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 11px 16px;
  font-size: var(--fs-font-base);
  font-weight: 500;
  font-family: var(--fs-font);
  border: 1.5px solid var(--fs-border);
  border-radius: 10px;
  background: var(--fs-bg);
  color: var(--fs-text-sub);
  cursor: pointer;
  transition: all 0.2s ease;
  box-shadow: none;
  min-height: 0;
}

.fluxshop-report-modal__cancel.fluxshop-report-modal__cancel:hover {
  border-color: var(--fs-border-dark);
  color: var(--fs-text);
  background: var(--fs-bg-hover);
}

.fluxshop-report-modal__submit.fluxshop-report-modal__submit {
  flex: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 11px 16px;
  font-size: var(--fs-font-base);
  font-weight: 600;
  font-family: var(--fs-font);
  border: 1.5px solid var(--fs-primary);
  border-radius: 10px;
  background: var(--fs-primary);
  color: #fff;
  cursor: pointer;
  transition: all 0.2s ease;
  box-shadow: none;
  min-height: 0;
}

.fluxshop-report-modal__submit.fluxshop-report-modal__submit:hover {
  background: var(--fs-primary-hover);
  border-color: var(--fs-primary-hover);
}

.fluxshop-report-modal__submit.fluxshop-report-modal__submit:disabled {
  background: var(--fs-border);
  border-color: var(--fs-border);
  color: var(--fs-text-muted);
  cursor: not-allowed;
}

/* 신고 버튼 - 게시글 toolbar (post-toolbar.php.php) */
.fluxshop-board-view__toolbar-btn--report:hover {
  border-color: var(--fs-accent);
  color: var(--fs-accent);
  background: #FEF2F2;
}

.fluxshop-board-view__toolbar-btn--report:hover .fluxshop-board-view__toolbar-icon {
  stroke: var(--fs-accent);
}

/* 신고 버튼 - 댓글 (comment.php.php) */
.fluxshop-comment__text-btn--report:hover {
  color: var(--fs-accent);
}

/* ==========================================================================
   구독 토글 버튼
   ========================================================================== */
.fluxshop-board-view__react-btn--subscribe {
  gap: 4px;
}

.fluxshop-board-view__react-btn--subscribe .fluxshop-board-view__react-label {
  font-size: 12px;
  font-weight: 500;
}

.fluxshop-board-view__react-btn--subscribe.fluxshop-board-view__react-btn--subscribe:hover {
  border-color: var(--fs-primary);
  color: var(--fs-primary);
  background: var(--fs-primary-bg);
}

.fluxshop-board-view__react-btn--subscribe.fluxshop-board-view__react-btn--subscribe.fluxshop-board-view__react-btn--active {
  border-color: var(--fs-primary);
  color: var(--fs-primary);
  background: var(--fs-primary-bg);
}

.fluxshop-board-view__react-btn--subscribe.fluxshop-board-view__react-btn--active svg {
  fill: var(--fs-primary);
  stroke: var(--fs-primary);
}

/* ==========================================================================
   알림 설정 페이지 (마이페이지)
   ========================================================================== */
.fluxshop-notif-settings {
  max-width: 640px;
}

.fluxshop-notif-settings__title {
  font-size: 20px;
  font-weight: 700;
  margin: 0 0 8px;
  color: var(--fs-text);
}

.fluxshop-notif-settings__desc {
  font-size: 14px;
  color: var(--fs-text-light);
  margin: 0 0 24px;
}

.fluxshop-notif-settings__group {
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius);
  overflow: hidden;
}

.fluxshop-notif-settings__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--fs-border);
}

.fluxshop-notif-settings__item:last-child {
  border-bottom: none;
}

.fluxshop-notif-settings__info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
  min-width: 0;
}

.fluxshop-notif-settings__label {
  font-size: 15px;
  font-weight: 600;
  color: var(--fs-text);
}

.fluxshop-notif-settings__hint {
  font-size: 13px;
  color: var(--fs-text-light);
}

@media (max-width: 480px) {
  .fluxshop-notif-settings__item {
    padding: 12px 16px;
  }

  .fluxshop-notif-settings__label {
    font-size: 14px;
  }

  .fluxshop-notif-settings__hint {
    font-size: 12px;
  }
}

/* ==========================================================================
   Report Modal — Responsive
   ========================================================================== */

@media (max-width: 480px) {
  .fluxshop-report-modal__dialog {
    width: 100%;
    max-width: calc(100vw - 24px);
    border-radius: 14px;
  }

  .fluxshop-report-modal__header {
    padding: 18px 18px 0;
  }

  .fluxshop-report-modal__body {
    padding: 14px 18px 20px;
  }

  .fluxshop-report-modal__footer {
    padding: 0 18px 20px;
  }

  .fluxshop-report-modal__reason {
    padding: 11px 12px;
    gap: 8px;
  }

  .fluxshop-report-modal__reason-icon {
    display: none;
  }
}

/* ==========================================================================
   Access Denied — Board Role Restriction
   ========================================================================== */

.fluxshop-access-denied {
  display: flex;
  justify-content: center;
  padding: 60px 16px 80px;
}

.fluxshop-access-denied__card {
  text-align: center;
  max-width: 420px;
  width: 100%;
}

.fluxshop-access-denied__icon-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: #FEF2F2;
  border: 1px solid #FECACA;
  margin-bottom: 20px;
  color: #DC2626;
}

.fluxshop-access-denied__title {
  font-size: 18px;
  font-weight: 600;
  color: var(--fs-text);
  margin: 0 0 6px;
  line-height: 1.4;
}

.fluxshop-access-denied__board-name {
  font-size: var(--fs-font-base);
  color: var(--fs-text-sub);
  margin: 0 0 20px;
  line-height: 1.6;
}

.fluxshop-access-denied__roles {
  background: var(--fs-bg-light);
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius);
  padding: 16px 20px;
  margin-bottom: 24px;
}

.fluxshop-access-denied__roles-label {
  font-size: var(--fs-font-sm);
  color: var(--fs-text-sub);
  margin: 0 0 10px;
  line-height: 1.5;
}

.fluxshop-access-denied__role-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: center;
}

.fluxshop-access-denied__role-tag {
  display: inline-block;
  padding: 4px 12px;
  font-size: var(--fs-font-sm);
  font-weight: 500;
  color: #1E40AF;
  background: #EFF6FF;
  border: 1px solid #BFDBFE;
  border-radius: var(--fs-radius-pill);
  line-height: 1.4;
}

.fluxshop-access-denied__actions {
  display: flex;
  gap: 8px;
  justify-content: center;
}

.fluxshop-access-denied__btn {
  display: inline-block;
  padding: 10px 28px;
  font-size: var(--fs-font-base);
  font-weight: 500;
  color: var(--fs-text);
  background: var(--fs-bg);
  border: 1px solid var(--fs-border-dark);
  border-radius: var(--fs-radius);
  text-decoration: none;
  transition: background var(--fs-transition), border-color var(--fs-transition);
}

.fluxshop-access-denied__btn:hover {
  background: var(--fs-bg-hover);
  border-color: var(--fs-text-muted);
  color: var(--fs-text);
  text-decoration: none;
}

.fluxshop-access-denied__btn--primary {
  color: #fff;
  background: var(--fs-primary);
  border-color: var(--fs-primary);
}

.fluxshop-access-denied__btn--primary:hover {
  background: var(--fs-primary-hover);
  border-color: var(--fs-primary-hover);
  color: #fff;
}

/* ==========================================================================
   Secret Post — Denied (Member Secret)
   ========================================================================== */

.fluxshop-secret-denied {
  display: flex;
  justify-content: center;
  padding: 60px 16px 80px;
}

.fluxshop-secret-denied__card {
  text-align: center;
  max-width: 400px;
  width: 100%;
}

.fluxshop-secret-denied__icon-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: var(--fs-bg-light);
  border: 1px solid var(--fs-border);
  margin-bottom: 20px;
  color: var(--fs-text-muted);
}

.fluxshop-secret-denied__title {
  font-size: 18px;
  font-weight: 600;
  color: var(--fs-text);
  margin: 0 0 8px;
  line-height: 1.4;
}

.fluxshop-secret-denied__desc {
  font-size: var(--fs-font-base);
  color: var(--fs-text-sub);
  margin: 0 0 28px;
  line-height: 1.6;
}

.fluxshop-secret-denied__btn {
  display: inline-block;
  padding: 10px 28px;
  font-size: var(--fs-font-base);
  font-weight: 500;
  color: var(--fs-text);
  background: var(--fs-bg);
  border: 1px solid var(--fs-border-dark);
  border-radius: var(--fs-radius);
  text-decoration: none;
  transition: background var(--fs-transition), border-color var(--fs-transition);
}

.fluxshop-secret-denied__btn:hover {
  background: var(--fs-bg-hover);
  border-color: var(--fs-text-muted);
  color: var(--fs-text);
  text-decoration: none;
}

/* ==========================================================================
   Secret Post — Password Form (Guest Secret)
   ========================================================================== */

.fluxshop-secret-password {
  display: flex;
  justify-content: center;
  padding: 60px 16px 80px;
}

.fluxshop-secret-password__card {
  text-align: center;
  max-width: 400px;
  width: 100%;
}

.fluxshop-secret-password__icon-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: var(--fs-bg-light);
  border: 1px solid var(--fs-border);
  margin-bottom: 20px;
  color: var(--fs-text-muted);
}

.fluxshop-secret-password__title {
  font-size: 18px;
  font-weight: 600;
  color: var(--fs-text);
  margin: 0 0 8px;
  line-height: 1.4;
}

.fluxshop-secret-password__desc {
  font-size: var(--fs-font-base);
  color: var(--fs-text-sub);
  margin: 0 0 20px;
  line-height: 1.6;
}

.fluxshop-secret-password__error {
  font-size: var(--fs-font-sm);
  color: var(--fs-accent);
  background: #FEF2F2;
  border: 1px solid #FECACA;
  border-radius: var(--fs-radius-sm);
  padding: 8px 14px;
  margin-bottom: 16px;
}

.fluxshop-secret-password__form {
  margin-bottom: 20px;
}

.fluxshop-secret-password__field {
  display: flex;
  gap: 8px;
  max-width: 320px;
  margin: 0 auto;
}

.fluxshop-secret-password__input {
  flex: 1;
  padding: 10px 14px;
  font-size: var(--fs-font-base);
  font-family: var(--fs-font);
  color: var(--fs-text);
  background: var(--fs-bg);
  border: 1px solid var(--fs-border-dark);
  border-radius: var(--fs-radius);
  outline: none;
  transition: border-color var(--fs-transition);
}

.fluxshop-secret-password__input:focus {
  border-color: var(--fs-primary);
}

.fluxshop-secret-password__input--error {
  border-color: var(--fs-accent);
}

.fluxshop-secret-password__submit {
  padding: 10px 20px;
  font-size: var(--fs-font-base);
  font-weight: 500;
  font-family: var(--fs-font);
  color: #fff;
  background: var(--fs-primary);
  border: 1px solid var(--fs-primary);
  border-radius: var(--fs-radius);
  cursor: pointer;
  white-space: nowrap;
  transition: background var(--fs-transition);
}

.fluxshop-secret-password__submit:hover {
  background: var(--fs-primary-hover);
}

.fluxshop-secret-password__back {
  font-size: var(--fs-font-sm);
  color: var(--fs-text-muted);
  text-decoration: none;
  transition: color var(--fs-transition);
}

.fluxshop-secret-password__back:hover {
  color: var(--fs-text-sub);
  text-decoration: none;
}

/* Access Denied & Secret Post — Responsive */

@media (max-width: 480px) {
  .fluxshop-access-denied {
    padding: 40px 16px 60px;
  }

  .fluxshop-access-denied__icon-wrap {
    width: 64px;
    height: 64px;
  }

  .fluxshop-access-denied__icon-wrap svg {
    width: 36px;
    height: 36px;
  }

  .fluxshop-access-denied__actions {
    flex-direction: column;
  }

  .fluxshop-access-denied__btn {
    width: 100%;
    text-align: center;
  }

  .fluxshop-secret-denied,
  .fluxshop-secret-password {
    padding: 40px 16px 60px;
  }

  .fluxshop-secret-denied__icon-wrap,
  .fluxshop-secret-password__icon-wrap {
    width: 64px;
    height: 64px;
  }

  .fluxshop-secret-denied__icon-wrap svg,
  .fluxshop-secret-password__icon-wrap svg {
    width: 36px;
    height: 36px;
  }

  .fluxshop-secret-password__field {
    flex-direction: column;
  }

  .fluxshop-secret-password__submit {
    width: 100%;
  }
}

/* ==========================================================================
   Integrated Search
   ========================================================================== */

.fluxshop-integrated-search {
  max-width: 960px;
  margin: 0 auto;
  font-family: var(--fs-font);
}

/* 검색 폼 */
.fluxshop-integrated-search__form {
  margin-bottom: 24px;
}

.fluxshop-integrated-search__form-fields {
  display: flex;
  gap: 0;
  border: 2px solid var(--fs-primary);
  border-radius: var(--fs-radius);
  overflow: hidden;
  background: var(--fs-bg);
}

.fluxshop-integrated-search__select {
  flex-shrink: 0;
  width: 100px;
  padding: 12px 12px;
  border: none;
  border-right: 1px solid var(--fs-border);
  background: var(--fs-bg-light);
  font-size: var(--fs-font-base);
  font-family: var(--fs-font);
  color: var(--fs-text);
  cursor: pointer;
  outline: none;
}

.fluxshop-integrated-search__input {
  flex: 1;
  padding: 12px 16px;
  border: none;
  font-size: var(--fs-font-lg);
  font-family: var(--fs-font);
  color: var(--fs-text);
  outline: none;
  background: transparent;
}

.fluxshop-integrated-search__input::placeholder {
  color: var(--fs-text-muted);
}

.fluxshop-integrated-search__btn {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 12px 24px;
  border: none;
  background: var(--fs-primary);
  color: #fff;
  font-size: var(--fs-font-base);
  font-weight: 600;
  font-family: var(--fs-font);
  cursor: pointer;
  transition: background var(--fs-transition);
}

.fluxshop-integrated-search__btn:hover {
  background: var(--fs-primary-hover);
}

/* 결과 헤더 */
.fluxshop-integrated-search__header {
  display: flex;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 24px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--fs-border);
}

.fluxshop-integrated-search__title {
  font-size: 18px;
  font-weight: 600;
  color: var(--fs-text);
  margin: 0;
}

.fluxshop-integrated-search__total-count {
  font-size: var(--fs-font-sm);
  color: var(--fs-text-muted);
}

/* 게시판 그룹 */
.fluxshop-integrated-search__groups {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.fluxshop-integrated-search__group {
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius);
  background: var(--fs-bg);
  overflow: hidden;
}

.fluxshop-integrated-search__group-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  background: var(--fs-bg-light);
  border-bottom: 1px solid var(--fs-border);
}

.fluxshop-integrated-search__group-title {
  font-size: var(--fs-font-lg);
  font-weight: 700;
  color: var(--fs-text);
  margin: 0;
}

.fluxshop-integrated-search__group-count {
  font-size: var(--fs-font-sm);
  color: var(--fs-text-muted);
  font-weight: 500;
}

/* 검색 결과 항목 */
.fluxshop-integrated-search__group-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.fluxshop-integrated-search__group-item {
  border-bottom: 1px solid var(--fs-border);
}

.fluxshop-integrated-search__group-item:last-child {
  border-bottom: none;
}

.fluxshop-integrated-search__item-link {
  display: block;
  padding: 14px 20px;
  text-decoration: none;
  color: var(--fs-text);
  transition: background var(--fs-transition);
}

.fluxshop-integrated-search__item-link:hover {
  background: var(--fs-bg-hover);
}

.fluxshop-integrated-search__item-title {
  font-size: var(--fs-font-base);
  font-weight: 600;
  color: var(--fs-text);
  margin-bottom: 4px;
  line-height: 1.5;
}

.fluxshop-integrated-search__item-comments {
  font-size: var(--fs-font-sm);
  color: var(--fs-accent);
  font-weight: 700;
  margin-left: 4px;
}

.fluxshop-integrated-search__item-meta {
  display: flex;
  gap: 12px;
  font-size: 12px;
  color: var(--fs-text-muted);
  margin-bottom: 6px;
}

.fluxshop-integrated-search__item-snippet {
  font-size: var(--fs-font-sm);
  color: var(--fs-text-sub);
  line-height: 1.6;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* 더보기 링크 */
.fluxshop-integrated-search__group-more {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 12px 20px;
  background: var(--fs-bg-light);
  border-top: 1px solid var(--fs-border);
  color: var(--fs-primary-light);
  font-size: var(--fs-font-sm);
  font-weight: 600;
  text-decoration: none;
  transition: background var(--fs-transition), color var(--fs-transition);
}

.fluxshop-integrated-search__group-more:hover {
  background: var(--fs-bg-hover);
  color: var(--fs-primary);
}

/* 결과 없음 */
.fluxshop-integrated-search__empty {
  text-align: center;
  padding: 60px 20px;
  color: var(--fs-text-muted);
}

.fluxshop-integrated-search__empty-icon {
  margin-bottom: 16px;
  color: var(--fs-border-dark);
}

.fluxshop-integrated-search__empty-title {
  font-size: var(--fs-font-lg);
  font-weight: 600;
  color: var(--fs-text-sub);
  margin: 0 0 8px;
}

.fluxshop-integrated-search__empty-desc {
  font-size: var(--fs-font-sm);
  color: var(--fs-text-muted);
  margin: 0;
}

/* 검색어 하이라이트 */
.fluxshop-search-highlight {
  background: #FEF3C7;
  color: var(--fs-text);
  padding: 1px 2px;
  border-radius: 2px;
}

/* ==========================================================================
   Popular Keywords
   ========================================================================== */

.fluxshop-popular-keywords {
  margin: 16px 0;
  font-family: var(--fs-font);
}

.fluxshop-popular-keywords__title {
  font-size: var(--fs-font-sm);
  font-weight: 700;
  color: var(--fs-text-sub);
  margin-right: 12px;
  white-space: nowrap;
}

.fluxshop-popular-keywords__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* Horizontal Style */
.fluxshop-popular-keywords--horizontal {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}

.fluxshop-popular-keywords--horizontal .fluxshop-popular-keywords__list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.fluxshop-popular-keywords--horizontal .fluxshop-popular-keywords__item {
  display: inline-flex;
}

.fluxshop-popular-keywords--horizontal .fluxshop-popular-keywords__link {
  display: inline-block;
  padding: 4px 12px;
  background: var(--fs-bg-light);
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius-pill);
  color: var(--fs-text-sub);
  font-size: var(--fs-font-sm);
  text-decoration: none;
  transition: all var(--fs-transition);
}

.fluxshop-popular-keywords--horizontal .fluxshop-popular-keywords__link:hover {
  background: var(--fs-primary);
  border-color: var(--fs-primary);
  color: #fff;
}

/* Vertical Style */
.fluxshop-popular-keywords--vertical {
  max-width: 300px;
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius);
  background: var(--fs-bg);
  overflow: hidden;
}

.fluxshop-popular-keywords--vertical .fluxshop-popular-keywords__title {
  display: block;
  padding: 12px 16px;
  border-bottom: 1px solid var(--fs-border);
  background: var(--fs-bg-light);
  margin: 0;
}

.fluxshop-popular-keywords--vertical .fluxshop-popular-keywords__item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border-bottom: 1px solid var(--fs-border);
  transition: background var(--fs-transition);
}

.fluxshop-popular-keywords--vertical .fluxshop-popular-keywords__item:last-child {
  border-bottom: none;
}

.fluxshop-popular-keywords--vertical .fluxshop-popular-keywords__item:hover {
  background: var(--fs-bg-hover);
}

.fluxshop-popular-keywords--vertical .fluxshop-popular-keywords__rank {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--fs-primary);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  border-radius: var(--fs-radius-sm);
}

.fluxshop-popular-keywords--vertical .fluxshop-popular-keywords__item:nth-child(n+4) .fluxshop-popular-keywords__rank {
  background: var(--fs-text-muted);
}

.fluxshop-popular-keywords--vertical .fluxshop-popular-keywords__link {
  flex: 1;
  color: var(--fs-text);
  font-size: var(--fs-font-base);
  text-decoration: none;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.fluxshop-popular-keywords--vertical .fluxshop-popular-keywords__count {
  flex-shrink: 0;
  font-size: 12px;
  color: var(--fs-text-muted);
}

/* Cloud Style */
.fluxshop-popular-keywords--cloud .fluxshop-popular-keywords__list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 8px 0;
}

.fluxshop-popular-keywords--cloud .fluxshop-popular-keywords__link {
  display: inline-block;
  padding: 6px 14px;
  background: var(--fs-bg-light);
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius-pill);
  color: var(--fs-text-sub);
  text-decoration: none;
  transition: all var(--fs-transition);
}

.fluxshop-popular-keywords--cloud .fluxshop-popular-keywords__link:hover {
  background: var(--fs-primary);
  border-color: var(--fs-primary);
  color: #fff;
  transform: translateY(-1px);
}

/* ==========================================================================
   Integrated Search & Popular Keywords — Responsive
   ========================================================================== */

@media (max-width: 768px) {
  .fluxshop-integrated-search__form-fields {
    flex-direction: column;
    border: none;
    gap: 8px;
    border-radius: 0;
  }

  .fluxshop-integrated-search__select {
    width: 100%;
    border-right: none;
    border: 1px solid var(--fs-border);
    border-radius: var(--fs-radius);
  }

  .fluxshop-integrated-search__input {
    border: 2px solid var(--fs-primary);
    border-radius: var(--fs-radius);
    padding: 12px 14px;
  }

  .fluxshop-integrated-search__btn {
    width: 100%;
    justify-content: center;
    border-radius: var(--fs-radius);
    padding: 14px;
  }

  .fluxshop-integrated-search__header {
    flex-direction: column;
    gap: 4px;
  }

  .fluxshop-integrated-search__group-header {
    padding: 12px 14px;
  }

  .fluxshop-integrated-search__item-link {
    padding: 12px 14px;
  }

  .fluxshop-integrated-search__item-meta {
    flex-wrap: wrap;
    gap: 8px;
  }

  .fluxshop-integrated-search__item-snippet {
    white-space: normal;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
  }

  .fluxshop-popular-keywords--horizontal {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* ==========================================================================
   Deny Card (접근 거부 / 비밀글 / 비밀번호)
   ========================================================================== */

.fluxshop-deny-card {
  display: flex;
  justify-content: center;
  padding: 48px 16px;
}

.fluxshop-deny-card__inner {
  max-width: 420px;
  width: 100%;
  text-align: center;
  background: var(--fs-bg);
  border: 1px solid var(--fs-border);
  border-radius: 12px;
  padding: 48px 32px 36px;
}

.fluxshop-deny-card__icon-wrap {
  display: flex;
  justify-content: center;
  margin-bottom: 20px;
  color: var(--fs-text-muted);
}

.fluxshop-deny-card__title {
  font-size: 20px;
  font-weight: 700;
  color: var(--fs-text);
  margin: 0 0 8px;
}

.fluxshop-deny-card__board-name {
  font-size: 14px;
  color: var(--fs-text-sub);
  margin: 0 0 16px;
}

.fluxshop-deny-card__desc {
  font-size: 14px;
  color: var(--fs-text-muted);
  margin: 0 0 24px;
  line-height: 1.6;
}

.fluxshop-deny-card__roles {
  margin-bottom: 24px;
}

.fluxshop-deny-card__roles-label {
  font-size: 13px;
  color: var(--fs-text-muted);
  margin: 0 0 8px;
}

.fluxshop-deny-card__role-tags {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 6px;
}

.fluxshop-deny-card__role-tag {
  display: inline-block;
  padding: 4px 12px;
  font-size: 12px;
  font-weight: 500;
  color: var(--fs-text-sub);
  background: var(--fs-bg-light);
  border: 1px solid var(--fs-border);
  border-radius: 20px;
}

.fluxshop-deny-card__error {
  font-size: 13px;
  color: var(--fs-accent);
  margin-bottom: 12px;
}

.fluxshop-deny-card__form {
  margin-bottom: 24px;
}

.fluxshop-deny-card__field {
  display: flex;
  gap: 8px;
  max-width: 320px;
  margin: 0 auto;
}

.fluxshop-deny-card__input {
  flex: 1;
  padding: 10px 14px;
  font-size: 14px;
  border: 1px solid var(--fs-border);
  border-radius: 6px;
  outline: none;
  transition: border-color 0.2s;
}

.fluxshop-deny-card__input:focus {
  border-color: var(--fs-primary);
}

.fluxshop-deny-card__input--error {
  border-color: var(--fs-accent);
}

.fluxshop-deny-card__submit {
  padding: 10px 20px;
  font-size: 14px;
  font-weight: 600;
  color: #fff;
  background: var(--fs-primary);
  border: none;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.2s;
  white-space: nowrap;
}

.fluxshop-deny-card__submit:hover {
  background: var(--fs-primary-hover);
}

.fluxshop-deny-card__actions {
  display: flex;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
}

.fluxshop-deny-card__btn {
  display: inline-flex;
  align-items: center;
  padding: 10px 20px;
  font-size: 14px;
  font-weight: 500;
  color: var(--fs-text-sub);
  background: var(--fs-bg-light);
  border: 1px solid var(--fs-border);
  border-radius: 6px;
  text-decoration: none;
  transition: background 0.2s, border-color 0.2s;
}

.fluxshop-deny-card__btn:hover {
  background: var(--fs-bg-hover);
  border-color: var(--fs-border-dark);
}

.fluxshop-deny-card__btn--primary {
  color: #fff;
  background: var(--fs-primary);
  border-color: var(--fs-primary);
}

.fluxshop-deny-card__btn--primary:hover {
  background: var(--fs-primary-hover);
  color: #fff;
}

@media (max-width: 480px) {
  .fluxshop-deny-card__inner {
    padding: 36px 20px 28px;
  }

  .fluxshop-deny-card__field {
    flex-direction: column;
  }
}
/* ===================
   Breadcrumb
   =================== */
.fluxshop-breadcrumb {
  margin-bottom: 12px;
}

.fluxshop-breadcrumb__list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 2px;
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: 13px;
  color: var(--fs-text-muted, #888);
}

.fluxshop-breadcrumb__link {
  color: var(--fs-text-muted, #888);
  text-decoration: none;
  transition: color 0.2s;
}

.fluxshop-breadcrumb__link:hover {
  color: var(--fs-primary, #2563eb);
  text-decoration: underline;
}

.fluxshop-breadcrumb__separator {
  color: var(--fs-border-dark, #ccc);
  font-size: 12px;
  user-select: none;
}

.fluxshop-breadcrumb__current {
  color: var(--fs-text-primary, #333);
  font-weight: 500;
}
