/* ─────────────────────────────────────────────────────────────
 * pages/notice.css — 공지사항 게시판 (scoped .nb-*)
 * Uses theme.css tokens. Enqueue on the 공지사항 목록/작성 페이지.
 * 한글 줄바꿈 규칙(CLAUDE.md): keep-all + .ln 블록 줄바꿈.
 *  - 목록 레이아웃 2종: 테이블형(.nb-board--table) / 카드형(.nb-board--cards)
 *  - 분류(태그) 5종: notice / new / ops / event / ship
 * ───────────────────────────────────────────────────────────── */

.nb-page, .nb-page * { word-break: keep-all; overflow-wrap: break-word; }
.nb-page .ln { display: block; }

/* ── PAGE HEAD ─────────────────────────────────────────────── */
.nb-head {
  background:
    radial-gradient(900px 480px at 80% -10%, rgba(255,255,255,0.10), transparent 60%),
    linear-gradient(160deg, #00366b 0%, var(--c-primary) 50%, #0a3f78 100%);
  color: #fff; padding: var(--s-12) 0 var(--s-12);
}
.nb-head-inner { display: flex; flex-direction: column; gap: var(--s-2); }
.nb-kicker {
  font-size: 13px; font-weight: 700; color: #9fc2ea;
  text-transform: uppercase; letter-spacing: 0.1em; margin: 0;
}
.nb-head h1 { color: #fff; font-size: 36px; line-height: 1.2; letter-spacing: -0.025em; margin: 0; }
.nb-head-lede { font-size: 16px; color: #cfe0f2; margin: var(--s-2) 0 0; max-width: 60ch; line-height: 1.7; }
.nb-breadcrumb { display: flex; align-items: center; gap: 8px; font-size: 13px; color: #9fc2ea; margin: 0 0 var(--s-3); }
.nb-breadcrumb a { color: #9fc2ea; }
.nb-breadcrumb a:hover { color: #fff; text-decoration: none; }
.nb-breadcrumb [data-lucide] { width: 14px; height: 14px; }

/* ── SECTION WRAP ──────────────────────────────────────────── */
.nb-section { padding: var(--s-12) 0 var(--s-16); }

/* ── TOOLBAR (검색 + 필터 + 시안 토글) ─────────────────────── */
.nb-toolbar { display: flex; flex-direction: column; gap: var(--s-5); margin-bottom: var(--s-6); }
.nb-toolbar-row { display: flex; align-items: center; justify-content: space-between; gap: var(--s-4); flex-wrap: wrap; }

.nb-filters { display: flex; flex-wrap: wrap; gap: 6px; }
.nb-filter {
  appearance: none; background: var(--c-surface); border: 1px solid var(--c-border);
  padding: 8px 15px; border-radius: var(--r-round); font-size: 14px; font-weight: 600;
  color: var(--c-fg-3); cursor: pointer; display: inline-flex; align-items: center; gap: 7px;
  transition: background .12s ease, color .12s ease, border-color .12s ease;
}
.nb-filter:hover { border-color: var(--c-primary-tint); color: var(--c-fg-1); text-decoration: none; }
.nb-filter.is-active { background: var(--c-primary); border-color: var(--c-primary); color: #fff; text-decoration: none; }
a.nb-filter:hover { text-decoration: none; }
.nb-filter-count { font-size: 12px; font-weight: 700; opacity: .75; }

.nb-search { position: relative; display: flex; align-items: center; min-width: 260px; }
.nb-search [data-lucide] { position: absolute; left: 13px; width: 17px; height: 17px; color: var(--c-fg-4); pointer-events: none; }
.nb-search input {
  width: 100%; padding: 10px 14px 10px 38px; border: 1px solid var(--c-border-strong);
  border-radius: var(--r-md); font-size: 14.5px; color: var(--c-fg-1); background: var(--c-surface);
}
.nb-search input:focus { outline: none; border-color: var(--c-primary); box-shadow: 0 0 0 3px var(--c-primary-softer); }

.nb-toolbar-right { display: flex; align-items: center; gap: var(--s-4); }
.nb-count { font-size: 14px; color: var(--c-fg-3); }
.nb-count strong { color: var(--c-fg-1); font-weight: 700; font-variant-numeric: tabular-nums; }

/* ── 반응형 레이아웃 자동 전환: >720px 테이블형 / ≤720px 카드형 ──
 * page-notice.php 가 두 마크업을 모두 렌더하고 여기서 토글한다. */
.nb-board--cards { display: none; }

/* ── 분류(태그) 배지 — 공통 ────────────────────────────────── */
.nb-tag {
  display: inline-flex; align-items: center; justify-content: center; white-space: nowrap;
  font-size: 12px; font-weight: 700; padding: 4px 11px; border-radius: var(--r-round);
  background: var(--c-primary-softer); color: var(--c-primary);
}
.nb-tag--new  { background: var(--c-success-bg); color: var(--c-success-text); }
.nb-tag--ops  { background: var(--c-warning-bg); color: var(--c-warning-text); }
.nb-tag--event{ background: var(--c-info-bg);    color: var(--c-info-text); }
.nb-tag--ship { background: var(--c-danger-bg);  color: var(--c-danger-text); }

.nb-pin { display: inline-flex; align-items: center; gap: 5px; font-size: 12px; font-weight: 700; color: var(--c-primary); }
.nb-pin [data-lucide] { width: 14px; height: 14px; }
.nb-attach-ic { display: inline-flex; align-items: center; color: var(--c-fg-4); margin-left: 6px; vertical-align: -2px; }
.nb-attach-ic [data-lucide] { width: 15px; height: 15px; }
.nb-new-dot {
  display: inline-flex; align-items: center; justify-content: center; margin-left: 7px;
  font-size: 10px; font-weight: 800; color: #fff; background: var(--c-danger);
  width: 16px; height: 16px; border-radius: var(--r-round); vertical-align: 1px;
}

/* ── 본문 아코디언 (테이블·카드 공통) ──────────────────────── */
.nb-body { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .24s ease; }
.nb-row.is-open .nb-body, .nb-card.is-open .nb-body { grid-template-rows: 1fr; }
.nb-body-inner { overflow: hidden; }
.nb-body-content {
  padding: var(--s-6); border-top: 1px dashed var(--c-border);
  font-size: 15px; color: var(--c-fg-2); line-height: 1.85;
}
.nb-body-content p { margin: 0 0 var(--s-4); }
.nb-body-content p:last-child { margin-bottom: 0; }
.nb-body-content strong { color: var(--c-fg-1); }
.nb-attach-list { margin-top: var(--s-5); display: flex; flex-direction: column; gap: 8px; }
.nb-attach-list-title { font-size: 12.5px; font-weight: 700; color: var(--c-fg-3); margin-bottom: 2px; letter-spacing: 0.02em; }
.nb-attach {
  display: inline-flex; align-items: center; gap: 9px; align-self: flex-start;
  padding: 9px 14px; border: 1px solid var(--c-border); border-radius: var(--r-md);
  background: var(--c-bg); font-size: 13.5px; color: var(--c-fg-1); font-weight: 600;
}
.nb-attach:hover { border-color: var(--c-primary-tint); background: var(--c-primary-softer); text-decoration: none; }
.nb-attach [data-lucide] { width: 16px; height: 16px; color: var(--c-primary); }
.nb-attach-size { color: var(--c-fg-4); font-weight: 500; font-size: 12.5px; }

/* ════════════════════════════════════════════════════════════
 * 시안 A — 테이블형 (.nb-board--table)
 * ════════════════════════════════════════════════════════════ */
.nb-board--table { border-top: 2px solid var(--c-fg-1); }
.nb-thead {
  display: grid; grid-template-columns: 72px 110px 1fr 92px 116px;
  align-items: center; gap: var(--s-4); padding: 13px var(--s-4);
  border-bottom: 1px solid var(--c-border); background: var(--c-bg);
  font-size: 13px; font-weight: 700; color: var(--c-fg-3); letter-spacing: 0.02em;
}
.nb-thead span:nth-child(1), .nb-thead span:nth-child(4), .nb-thead span:nth-child(5) { text-align: center; }

.nb-row { border-bottom: 1px solid var(--c-border); }
.nb-row-head {
  display: grid; grid-template-columns: 72px 110px 1fr 92px 116px;
  align-items: center; gap: var(--s-4); padding: var(--s-4); cursor: pointer;
  transition: background .12s ease; background: none; border: 0; width: 100%; text-align: left;
  font: inherit; color: inherit;
}
.nb-row-head:hover { background: var(--c-surface-alt); }
.nb-row.is-open > .nb-row-head { background: var(--c-primary-softer); }
.nb-col-no { text-align: center; font-size: 14px; color: var(--c-fg-4); font-variant-numeric: tabular-nums; }
.nb-col-cat { display: flex; justify-content: center; }
.nb-col-title { display: flex; align-items: center; gap: 4px; min-width: 0; }
.nb-col-title .nb-title-text { font-size: 15.5px; font-weight: 600; color: var(--c-fg-1); }
.nb-row-head:hover .nb-title-text { color: var(--c-primary); }
.nb-col-views { text-align: center; font-size: 14px; color: var(--c-fg-3); font-variant-numeric: tabular-nums; }
.nb-col-date { text-align: center; font-size: 13.5px; color: var(--c-fg-4); font-variant-numeric: tabular-nums; }

/* 고정공지 행 */
.nb-row--pinned { background: var(--c-primary-softer); }
.nb-row--pinned .nb-col-no { color: var(--c-primary); }
.nb-row--pinned .nb-title-text { font-weight: 700; }
.nb-row--pinned .nb-row-head:hover { background: #e4eef9; }

/* ════════════════════════════════════════════════════════════
 * 시안 B — 카드형 (.nb-board--cards)
 * ════════════════════════════════════════════════════════════ */
.nb-board--cards { display: flex; flex-direction: column; gap: var(--s-4); }
.nb-card {
  background: var(--c-surface); border: 1px solid var(--c-border); border-radius: var(--r-lg);
  overflow: hidden; transition: border-color .15s ease, box-shadow .15s ease;
}
.nb-card:hover { border-color: var(--c-primary-tint); box-shadow: var(--sh-md); }
.nb-card.is-open { border-color: var(--c-primary-tint); box-shadow: var(--sh-sm); }
.nb-card--pinned { border-color: var(--c-primary-tint); background: linear-gradient(180deg, var(--c-primary-softer), var(--c-surface) 64px); }
.nb-card-head {
  display: grid; grid-template-columns: 1fr auto; gap: var(--s-3) var(--s-5); align-items: center;
  padding: var(--s-5) var(--s-6); cursor: pointer; background: none; border: 0; width: 100%;
  text-align: left; font: inherit; color: inherit;
}
.nb-card-top { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; grid-column: 1; }
.nb-card-title { font-size: 17px; font-weight: 700; color: var(--c-fg-1); line-height: 1.4; grid-column: 1; margin: 0; display: flex; align-items: center; }
.nb-card-head:hover .nb-card-title { color: var(--c-primary); }
.nb-card-excerpt { grid-column: 1; font-size: 14px; color: var(--c-fg-3); line-height: 1.65; margin: 0;
  display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; overflow: hidden; }
.nb-card-meta { grid-column: 2; grid-row: 1 / span 3; align-self: start; display: flex; flex-direction: column; align-items: flex-end; gap: 6px; white-space: nowrap; }
.nb-card-date { font-size: 13.5px; color: var(--c-fg-3); font-variant-numeric: tabular-nums; }
.nb-card-views { font-size: 12.5px; color: var(--c-fg-4); display: inline-flex; align-items: center; gap: 5px; font-variant-numeric: tabular-nums; }
.nb-card-views [data-lucide] { width: 14px; height: 14px; }
.nb-card-chev { color: var(--c-fg-4); transition: transform .2s ease; }
.nb-card-chev [data-lucide] { width: 20px; height: 20px; }
.nb-card.is-open .nb-card-chev { transform: rotate(180deg); color: var(--c-primary); }

/* ── empty state ───────────────────────────────────────────── */
.nb-empty { text-align: center; padding: var(--s-16) var(--s-4); color: var(--c-fg-4); }
.nb-empty [data-lucide] { width: 40px; height: 40px; margin: 0 auto var(--s-3); color: var(--c-border-strong); }
.nb-empty p { font-size: 15px; margin: 0; }

/* ── 페이지네이션 ─────────────────────────────────────────── */
.nb-pagination { display: flex; justify-content: center; align-items: center; gap: 6px; margin-top: var(--s-10); }
.nb-page-btn {
  min-width: 38px; height: 38px; padding: 0 10px; display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--c-border); border-radius: var(--r-md); background: var(--c-surface);
  font-size: 14px; font-weight: 600; color: var(--c-fg-2); cursor: pointer; font-variant-numeric: tabular-nums;
  transition: background .12s, color .12s, border-color .12s;
}
.nb-page-btn:hover { border-color: var(--c-primary-tint); color: var(--c-primary); text-decoration: none; }
.nb-page-btn.is-active { background: var(--c-primary); border-color: var(--c-primary); color: #fff; }
.nb-page-btn[disabled] { opacity: .4; cursor: not-allowed; }
.nb-page-btn [data-lucide] { width: 17px; height: 17px; }

/* WordPress paginate_links( type=list ) 호환 — page-notice.php */
.nb-pagination .page-numbers { list-style: none; display: flex; justify-content: center; align-items: center; gap: 6px; margin: 0; padding: 0; }
.nb-pagination .page-numbers li { display: inline-flex; }
.nb-pagination .page-numbers li .page-numbers,
.nb-pagination a.page-numbers, .nb-pagination span.page-numbers {
  min-width: 38px; height: 38px; padding: 0 10px; display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--c-border); border-radius: var(--r-md); background: var(--c-surface);
  font-size: 14px; font-weight: 600; color: var(--c-fg-2); cursor: pointer; font-variant-numeric: tabular-nums;
  transition: background .12s, color .12s, border-color .12s; text-decoration: none;
}
.nb-pagination .page-numbers li a:hover { border-color: var(--c-primary-tint); color: var(--c-primary); text-decoration: none; }
.nb-pagination .page-numbers li span.current,
.nb-pagination .page-numbers .current { background: var(--c-primary); border-color: var(--c-primary); color: #fff; }
.nb-pagination .page-numbers .dots { border-color: transparent; background: transparent; }

/* ── 하단 CTA / 새 글 버튼 영역 ───────────────────────────── */
.nb-list-actions { display: flex; justify-content: flex-end; margin-top: var(--s-5); }

/* ════════════════════════════════════════════════════════════
 * 작성 / 편집 화면 (.nb-editor)
 * ════════════════════════════════════════════════════════════ */
.nb-editor-layout { display: grid; grid-template-columns: 1fr 300px; gap: var(--s-6); align-items: start; }
.nb-editor-main {
  background: var(--c-surface); border: 1px solid var(--c-border); border-radius: var(--r-lg);
  padding: var(--s-8);
}
.nb-field { margin-bottom: var(--s-6); }
.nb-field:last-child { margin-bottom: 0; }
.nb-label { display: block; font-size: 13.5px; font-weight: 700; color: var(--c-fg-2); margin-bottom: 8px; }
.nb-label .req { color: var(--c-danger); margin-left: 3px; }
.nb-input, .nb-textarea, .nb-select {
  width: 100%; border: 1px solid var(--c-border-strong); border-radius: var(--r-md);
  font-size: 15px; color: var(--c-fg-1); background: var(--c-surface); font-family: inherit;
}
.nb-input { padding: 12px 14px; }
.nb-select { padding: 11px 14px; appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 14px center; padding-right: 40px; }
.nb-textarea { padding: 14px; min-height: 320px; line-height: 1.8; resize: vertical; }
.nb-input:focus, .nb-textarea:focus, .nb-select:focus { outline: none; border-color: var(--c-primary); box-shadow: 0 0 0 3px var(--c-primary-softer); }
.nb-field-hint { font-size: 12.5px; color: var(--c-fg-4); margin-top: 6px; }

/* fake rich toolbar */
.nb-rte-bar { display: flex; gap: 2px; border: 1px solid var(--c-border-strong); border-bottom: 0; border-radius: var(--r-md) var(--r-md) 0 0; padding: 6px; background: var(--c-bg); flex-wrap: wrap; }
.nb-rte-bar button { appearance: none; background: none; border: 0; width: 32px; height: 32px; border-radius: var(--r-sm); color: var(--c-fg-3); cursor: pointer; display: inline-flex; align-items: center; justify-content: center; }
.nb-rte-bar button:hover { background: var(--c-surface-alt); color: var(--c-fg-1); }
.nb-rte-bar [data-lucide] { width: 17px; height: 17px; }
.nb-rte-sep { width: 1px; background: var(--c-border); margin: 4px 5px; }
.nb-rte-bar + .nb-textarea { border-radius: 0 0 var(--r-md) var(--r-md); }

/* upload dropzone */
.nb-dropzone {
  border: 2px dashed var(--c-border-strong); border-radius: var(--r-md); padding: var(--s-8);
  text-align: center; color: var(--c-fg-3); background: var(--c-bg); cursor: pointer;
  transition: border-color .12s, background .12s;
}
.nb-dropzone:hover { border-color: var(--c-primary); background: var(--c-primary-softer); }
.nb-dropzone [data-lucide] { width: 28px; height: 28px; margin: 0 auto 10px; color: var(--c-primary); }
.nb-dropzone-title { font-size: 14px; font-weight: 600; color: var(--c-fg-1); }
.nb-dropzone-sub { font-size: 12.5px; margin-top: 4px; }
.nb-uploaded { margin-top: var(--s-3); display: flex; flex-direction: column; gap: 8px; }
.nb-uploaded-item { display: flex; align-items: center; gap: 10px; padding: 10px 13px; border: 1px solid var(--c-border); border-radius: var(--r-md); background: var(--c-surface); font-size: 13.5px; }
.nb-uploaded-item [data-lucide] { width: 16px; height: 16px; color: var(--c-primary); flex: 0 0 auto; }
.nb-uploaded-name { font-weight: 600; color: var(--c-fg-1); flex: 1; }
.nb-uploaded-size { color: var(--c-fg-4); font-size: 12.5px; }
.nb-uploaded-x { color: var(--c-fg-4); cursor: pointer; display: inline-flex; }
.nb-uploaded-x:hover { color: var(--c-danger); }
.nb-uploaded-x [data-lucide] { width: 16px; height: 16px; }

/* sidebar (publish box) */
.nb-editor-side { display: flex; flex-direction: column; gap: var(--s-4); position: sticky; top: var(--s-6); }
.nb-side-card { background: var(--c-surface); border: 1px solid var(--c-border); border-radius: var(--r-lg); overflow: hidden; }
.nb-side-card-head { padding: 13px var(--s-5); border-bottom: 1px solid var(--c-border); font-size: 13.5px; font-weight: 700; color: var(--c-fg-1); background: var(--c-bg); }
.nb-side-card-body { padding: var(--s-5); display: flex; flex-direction: column; gap: var(--s-4); }
.nb-toggle-row { display: flex; align-items: center; justify-content: space-between; gap: var(--s-3); }
.nb-toggle-label { font-size: 14px; color: var(--c-fg-1); font-weight: 600; }
.nb-toggle-label .nb-toggle-sub { display: block; font-size: 12px; color: var(--c-fg-4); font-weight: 400; margin-top: 2px; }

/* switch */
.nb-switch { position: relative; width: 44px; height: 24px; flex: 0 0 auto; }
.nb-switch input { position: absolute; opacity: 0; width: 100%; height: 100%; margin: 0; cursor: pointer; }
.nb-switch-track { position: absolute; inset: 0; background: var(--c-border-strong); border-radius: var(--r-round); transition: background .15s; }
.nb-switch-track::after { content: ""; position: absolute; top: 3px; left: 3px; width: 18px; height: 18px; background: #fff; border-radius: var(--r-round); transition: transform .15s; box-shadow: var(--sh-sm); }
.nb-switch input:checked + .nb-switch-track { background: var(--c-primary); }
.nb-switch input:checked + .nb-switch-track::after { transform: translateX(20px); }

.nb-side-meta { font-size: 13px; color: var(--c-fg-3); display: flex; flex-direction: column; gap: 6px; }
.nb-side-meta div { display: flex; justify-content: space-between; }
.nb-side-meta dt { color: var(--c-fg-4); }
.nb-side-meta dd { margin: 0; color: var(--c-fg-1); font-weight: 600; }
.nb-side-actions { display: flex; flex-direction: column; gap: 8px; padding: var(--s-5); border-top: 1px solid var(--c-border); }
.nb-side-actions .btn { width: 100%; }

.nb-editor-titlebar { display: flex; align-items: center; justify-content: space-between; gap: var(--s-4); margin-bottom: var(--s-6); }
.nb-editor-titlebar h1 { font-size: 24px; margin: 0; }
.nb-back-link { display: inline-flex; align-items: center; gap: 6px; font-size: 14px; font-weight: 600; color: var(--c-fg-3); }
.nb-back-link:hover { color: var(--c-primary); text-decoration: none; }
.nb-back-link [data-lucide] { width: 16px; height: 16px; }

/* ── Responsive ───────────────────────────────────────────── */
@media (max-width: 960px) {
  .nb-head h1 { font-size: 28px; min-width: 0; }
  .nb-editor-layout { grid-template-columns: 1fr; }
  .nb-editor-side { position: static; }
  .nb-toolbar-row { align-items: flex-start; }
  .nb-search { width: 100%; min-width: 0; }
}
@media (max-width: 720px) {
  /* 모바일: 테이블 숨기고 카드형으로 전환 */
  .nb-board--table { display: none; }
  .nb-board--cards { display: flex; }
  .nb-editor-main { padding: var(--s-5); }
  .nb-card-meta { grid-row: auto; grid-column: 1; flex-direction: row; align-items: center; }
}
@media (max-width: 560px) {
  .nb-section { padding: var(--s-8) 0 var(--s-12); }
  .nb-head { padding: var(--s-10) 0; }
  .nb-card-head { grid-template-columns: 1fr; }
  .nb-card-meta { grid-column: 1; }
}
