@charset "utf-8";
@import url(//fonts.googleapis.com/earlyaccess/notosanskr.css);
@import url('./style.foundation.css');
@import url('./style.list.css');
@import url('./style.view.css');
@import url('./style.buttons.css');

:root {
	--bbs-text: var(--content-font-color, #3d3d3d);
	--bbs-base: var(--card-bg-color, #f6f6f6);
	--bbs-base2: var(--container-bg-color, #e3e3e3);
	--bbs-point: var(--accent-color, #858585);
}

@font-face {
	font-family: 'Chosunilbo_myungjo';
	src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_one@1.0/Chosunilbo_myungjo.woff') format('woff');
	font-weight: normal;
	font-style: normal;
}

@font-face {
	font-family: 'BookkMyungjo-Bd';
	src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2302@1.0/BookkMyungjo-Bd.woff2') format('woff2');
	font-weight: var(--bbs-fw-bold, 700);
	font-style: normal;
}

@font-face {
	font-family: 'KBIZHanmaumMyungjo';
	src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_one@1.0/KBIZHanmaumMyungjo.woff') format('woff');
	font-weight: normal;
	font-style: normal;
}


@font-face {
	font-family: 'ChosunGu';
	src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_20-04@1.0/ChosunGu.woff') format('woff');
	font-weight: normal;
	font-style: normal;
}

@font-face {
	font-family: 'ChosunKg';
	src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_20-04@1.0/ChosunKg.woff') format('woff');
	font-weight: normal;
	font-style: normal;
}

@font-face {
	font-family: 'SUIT-Regular';
	src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_suit@1.0/SUIT-Regular.woff2') format('woff2');
	font-weight: normal;
	font-style: normal;
}

@font-face {
	font-family: 'Pretendard-Regular';
	src: url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Regular.woff') format('woff');
	font-weight: 400;
	font-style: normal;
}

@font-face {
	font-family: 'Freesentation9';
	src: url('https://fastly.jsdelivr.net/gh/projectnoonnu/2404@1.0/Freesentation-9Black.woff2') format('woff2');
	font-weight: var(--bbs-fw-heavy, 900);
	font-style: normal;
}

@font-face {
	font-family: 'Freesentation5';
	src: url('https://cdn.jsdelivr.net/gh/fontbee/font@main/Freesentation/Freesentation-5Medium.woff2') format('woff2');
	font-weight: normal;
	font-style: normal;
}

@font-face {
	font-family: 'Freesentation3';
	src: url('https://cdn.jsdelivr.net/gh/fontbee/font@main/Freesentation/Freesentation-3Light.woff2') format('woff2');
	font-weight: normal;
	font-style: normal;
}

@font-face {
	font-family: 'Paperlogy-8ExtraBold';
	src: url('https://fastly.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-8ExtraBold.woff2') format('woff2');
	font-weight: 800;
	font-style: normal;
}

@font-face {
	font-family: 'Paperlogy-5Medium';
	src: url('https://fastly.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-5Medium.woff2') format('woff2');
	font-weight: 500;
	font-style: normal;
}

.bbs-list {
	display: block;
	position: relative;
	margin: 0;
	padding: 0;
}

.bbs-list li {
	display: flex;
	position: relative;
	padding: 5px 0;
	margin-bottom: 5px;
	line-height: 20px;
	height: 24px;
	align-items: center;
	transition: height .22s ease;
	will-change: height;
}

.bbs-list li:hover {
	height: 34px;
}

.bbs-list li.bo_notice {}

.bbs-list li.no-data {
	text-align: center;
	line-height: 200px;
}

.bbs-list li .td_chk {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	display: inline-flex;
	align-items: center;
	padding-left: 12px;
	z-index: 10;
}

.bbs-list li a {
	display: flex;
	position: relative;
	padding: 0px 180px 0px 40px;
	line-height: 35px;
	justify-content: flex-start;
	align-items: center;
	width: -webkit-fill-available;
	width: -moz-fill-available;
	width: -o-fill-available;
	width: -ms-fill-available;
	z-index: 2;
}

.bbs-list li .bbs-list-subject {
	display: block;
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
	backface-visibility: hidden;
	max-width: calc(100% - 70px);
}

.bbs-list li .bbs-list-subject .highlight {
	font-weight: normal;
}

.bbs-list li .bbs-list-subject .cnt_cmt:before {
	content: "";
}

.bbs-list li .bbs-list-subject .cnt_cmt:after {
	content: "";
}

.bbs-list li .ico-cate {
	display: inline-block;
	position: relative;
	top: 0;
	padding-right: 10px;
	text-align: center;
	line-height: 9px;
	font-weight: bold;
	font-style: normal;
	margin-right: 10px;
	font-size: 12px;
	border-right: 3px double;
}

.bbs-tag-header {
	height: 40px;
	display: flex;
	justify-content: center;
	align-items: center;
}

.bbs-tag {
	display: inline-flex;
	padding: 4px 10px;
	background: var(--bbs-point);
	border-radius: 15px;
	height: 15px;
	align-items: center;
	margin: 0px 2px;
	font-size: 12px;
	/* inline-flex 기본 baseline 정렬은 padding 만큼 아래로 처져 제목 옆에서 가라앉아 보임. */
	vertical-align: middle;
}

/* `<i class="ico-cate">` `<i class="material-icons">` 등 의미상 아이콘인 `<i>` 안의 텍스트는 italic 가
   적용되면 안 됨. Material Icons CDN 미로드 fallback / 폰트 글리프 외 텍스트 사례에서 italic 새는 거 방지. */
.material-icons,
.ico-cate {
	font-style: normal !important;
}

.bbs-list .info {
	display: inline-flex;
	position: absolute;
	right: 20px;
	border-radius: 5px;
	line-height: 1em;
	padding: 5px 0px;
	align-items: center;
	height: 13px;
}

.bbs-list li .name {
	display: inline-block;
	width: 70px;
	text-align: center;
	opacity: 1;
	font-size: 11px;
	padding: 0px 10px;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.bbs-list li .date {
	display: inline-block;
	text-align: center;
	font-size: 11px;
	padding: 0px 10px;
	width: 75px;
	word-break: keep-all;
	white-space: nowrap;
}

.bbs-list li .hit {
	display: block;
	position: absolute;
	top: 0;
	right: 0;
	width: 50px;
	text-align: center;
	opacity: .6;
	font-size: 11px;
}



.bo_fx {
	position: relative;
	padding: 20px 0;
}

.bo_fx .chk_all {
	position: absolute;
	left: 5px;
	top: 20px;
}

.bbs-filter {
	display: inline-flex;
	gap: 4px;
	margin-right: 8px;
	align-items: center;
	flex-wrap: wrap;
}

.bo_fx .bbs-filter {
	display: flex;
	width: 100%;
	justify-content: flex-end;
	margin-right: 0;
	margin-left: auto;
}

/* 사각 칩 family — .bbs-filter-btn / .bbs-quick-btn / .bbs-quick-clear / .bo_fx > .bbs-list-back-btn.
   카테고리 칩 (.bbs-cat-chip) 만 pill 이고 나머지는 둥근 모서리 사각형으로 통일.
   단일 베이스 룰 — .bbs-filter 스코프 override 없이 어디서나 동일 모양. */
.bbs-filter-btn,
.bbs-quick-btn,
.bbs-quick-clear,
.bo_fx > .bbs-list-back-btn {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	box-sizing: border-box;
	height: var(--bbs-ui-btn-h, 30px) !important;
	padding: 0 0.75rem !important;
	margin: 0;
	border-radius: var(--bbs-ui-radius, 10px) !important;
	background: var(--bbs-ctrl-bg);
	color: var(--bbs-ui-fg-strong);
	border: 1px solid color-mix(in srgb, var(--container-border-color, #fff) 45%, transparent) !important;
	font-family: inherit;
	font-size: var(--bbs-ui-btn-fz, 12px) !important;
	font-weight: var(--bbs-fw-semi, 600) !important;
	line-height: normal !important;
	white-space: nowrap !important;
	cursor: pointer;
	text-decoration: none;
	appearance: none;
	-webkit-appearance: none;
	box-shadow: none !important;
	outline: 0;
	transition: background var(--bbs-anim-base, .15s) ease, color var(--bbs-anim-base, .15s) ease, border-color var(--bbs-anim-base, .15s) ease, transform var(--bbs-anim-fast, .12s) ease;
}

/* 리스트 하단 "목록" 버튼 — markup 에서 .bbs-filter-btn 클래스 부여로 칩 스타일 자동 상속.
   .bo_fx 를 flex 로 바꿔 .bbs-filter 와 같은 줄에 두고 order: -1 로 좌측 배치 (mobile media 에서 block fallback). */
.bo_fx {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
}
.bo_fx .bbs-filter {
	width: auto;
	flex: 1;
}
.bo_fx > .bbs-list-back-btn {
	order: -1;
}



.board-category {
	display: flex;
	position: relative;
	margin-bottom: 10px;
	align-items: center;
	flex: 1;
}

.board-category select {}

.bbs-category-row {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 8px;
}

.bbs-category-actions {
	display: inline-flex;
	gap: 4px;
	align-items: center;
	align-self: flex-end;
}

.bbs-cat-btn {
	width: 28px;
	height: 28px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	background: var(--bbs-point);
	color: #fff;
	border: 0;
}

/* 리스트 페이지 전용: 뷰포트 기준 세로 중앙 정렬 */
.bbs-list-wrap.bbs-list-vcenter {
	min-height: calc(100vh - var(--header-height, 0px));
	min-height: calc(100dvh - var(--header-height, 0px));
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding-block: clamp(12px, 3vh, 36px);
}

.bbs-list-wrap.bbs-list-vcenter > .board-skin-basic {
	width: 100%;
}

@media all and (max-width: 1000px) {
	#bo_v_con * {
		max-width: 100%;
	}

	.board-category {
		display: block;
		width: 100%;
		box-sizing: border-box;
		margin: 0;
	}

	.board-category select {
		width: 100%;
	}

	.bo_fx {
		display: block;
		width: 100%;
		box-sizing: border-box;
		padding: 10px 0;
	}

}

@media all and (max-width: 1000px) {
	.bbs-box {
		width: 100%;
	}

	.board-viewer.bbs-box {
		padding: 0px;
	}

	.board-viewer {
		max-width: none;
		width: 100%;
		--viewer-pad: 0px;
	}

}


#bo_w {
	--write-panel: var(--bbs-panel-bg, color-mix(in srgb, var(--card-bg-color, #ffffff) 96%, transparent));
	--write-panel-glass: color-mix(in srgb, var(--card-bg-color, #ffffff) 62%, transparent);
	--write-panel-soft: var(--bbs-field-bg, color-mix(in srgb, var(--container-bg-color, #f6f6f6) 88%, transparent));
	--write-field-bg: color-mix(in srgb, var(--container-bg-color, #ffffff) 84%, transparent);
	--write-field-bg-hover: color-mix(in srgb, var(--container-bg-color, #ffffff) 92%, transparent);
	--write-chip-bg: color-mix(in srgb, var(--card-bg-color, #ffffff) 72%, transparent);
	--write-chip-bg-hover: color-mix(in srgb, var(--card-bg-color, #ffffff) 90%, transparent);
	--write-chip-bg-checked: color-mix(in srgb, var(--write-accent, #858585) 14%, var(--write-chip-bg));
	--write-line: color-mix(in srgb, var(--container-border-color, var(--bbs-text, #3d3d3d)) 22%, transparent);
	--write-line-strong: color-mix(in srgb, var(--container-border-color, var(--bbs-text, #3d3d3d)) 38%, transparent);
	--write-text: var(--bbs-ui-fg, var(--content-font-color, var(--bbs-text, #3d3d3d)));
	--write-muted: var(--bbs-ui-fg-muted, color-mix(in srgb, var(--write-text) 60%, transparent));
	--write-accent: var(--bbs-ui-accent-bg, var(--accent-color, var(--bbs-point, #858585)));
	--write-accent-dark: color-mix(in srgb, var(--write-accent) 68%, var(--write-text) 32%);
	--write-focus: color-mix(in srgb, var(--write-accent) 22%, transparent);
	--write-shadow: 0 18px 44px color-mix(in srgb, var(--container-border-color, #000000) 14%, transparent);
	--write-shadow-soft: 0 6px 18px color-mix(in srgb, var(--container-border-color, #000000) 8%, transparent);
	--write-radius: 14px;
	--write-radius-field: 10px;
	color: var(--write-text);
}

#bo_w .board-write {
	display: grid;
	gap: 18px;
	max-width: 1040px;
	margin: 0 auto;
	padding: 24px 20px;
	border: 0;
	border-radius: var(--write-radius);
	background: transparent;
	box-shadow: none;
	box-sizing: border-box;
}

#bo_w .board-write * {
	box-sizing: border-box;
}

#bo_w .board-write h3 {
	margin: 0;
	padding: 0;
	font-size: 22px;
	line-height: 1.35;
	text-align: left;
}

#bo_w .board-write .write-group {
	display: grid;
	gap: 14px;
	padding: 22px 22px 20px;
	border: 0;
	border-radius: var(--write-radius);
	background: var(--write-panel-glass);
	box-shadow: var(--write-shadow);
	backdrop-filter: blur(14px) saturate(1.12);
	-webkit-backdrop-filter: blur(14px) saturate(1.12);
	transition: box-shadow var(--bbs-anim-slow, .25s) ease, transform var(--bbs-anim-slow, .25s) ease;
}

#bo_w .board-write .write-group:hover {
	box-shadow: 0 22px 52px color-mix(in srgb, var(--container-border-color, #000) 18%, transparent);
}

#bo_w .board-write .write-group-title {
	display: flex;
	align-items: center;
	gap: 10px;
	margin: 0 0 4px;
	padding-bottom: 10px;
	border-bottom: 1px solid var(--write-line);
	font-size: 13px;
	font-weight: var(--bbs-fw-bold, 700);
	line-height: 1.35;
	letter-spacing: 0.2px;
	color: var(--write-accent-dark);
	text-transform: uppercase;
}

#bo_w .board-write .write-group-title::before {
	content: "";
	width: 6px;
	height: 6px;
	border-radius: 999px;
	background: var(--write-accent);
	box-shadow: 0 0 0 4px color-mix(in srgb, var(--write-accent) 18%, transparent);
}

#bo_w .board-write dl {
	display: grid;
	grid-template-columns: 116px minmax(0, 1fr);
	gap: 12px;
	align-items: start;
	margin: 0;
	padding: 0;
	position: relative;
}

#bo_w .board-write dl>dt {
	position: static;
	width: auto;
	min-height: 40px;
	display: flex;
	align-items: center;
	justify-content: flex-start;
	text-align: left;
	line-height: 1.4;
	font-size: 12px;
	font-weight: var(--bbs-fw-bold, 700);
	letter-spacing: 0.04em;
	color: var(--write-muted);
	text-transform: uppercase;
}

#bo_w .board-write dl>dd {
	width: auto;
	min-width: 0;
	margin: 0;
	padding: 0;
	line-height: 1.5;
}

#bo_w .board-write input.frm_input,
#bo_w .board-write input.frm_file,
#bo_w .board-write select,
#bo_w .board-write textarea {
	width: 100%;
	min-height: 40px;
	margin: 0;
	padding: 9px 13px;
	border: 1px solid var(--write-line);
	border-radius: var(--write-radius-field);
	background: var(--write-field-bg);
	color: var(--write-text);
	font: inherit;
	line-height: 1.45;
	transition: border-color .18s ease, box-shadow .18s ease, background-color .18s ease;
}

#bo_w .board-write input.frm_input:hover:not(:focus),
#bo_w .board-write select:hover:not(:focus),
#bo_w .board-write textarea:hover:not(:focus) {
	border-color: var(--write-line-strong);
	background: var(--write-field-bg-hover);
}

#bo_w .board-write input.frm_input:focus,
#bo_w .board-write input.frm_file:focus,
#bo_w .board-write select:focus,
#bo_w .board-write textarea:focus,
#bo_w .board-write #wr_content_viewer:focus {
	outline: 0;
	border-color: var(--write-accent);
	box-shadow: 0 0 0 4px var(--write-focus);
	background: var(--write-field-bg-hover);
}

#bo_w .board-write input::placeholder,
#bo_w .board-write textarea::placeholder {
	color: color-mix(in srgb, var(--write-muted) 80%, transparent);
}

#bo_w .board-write input[type="file"].frm_input,
#bo_w .board-write input[type="file"].frm_file {
	padding: 7px 11px;
	background: var(--write-panel-soft);
	cursor: pointer;
}
#bo_w .board-write input[type="file"]::-webkit-file-upload-button {
	margin: -3px 10px -3px -8px;
	padding: 7px 12px;
	border: 0;
	border-radius: 8px;
	background: var(--write-accent);
	color: var(--bbs-ui-accent-fg, #fff);
	font: inherit;
	font-weight: var(--bbs-fw-semi, 600);
	font-size: 12px;
	cursor: pointer;
	transition: filter var(--bbs-anim-base, .15s) ease;
}
#bo_w .board-write input[type="file"]::-webkit-file-upload-button:hover {
	filter: brightness(1.08);
}
#bo_w .board-write input[type="file"]::file-selector-button {
	margin: -3px 10px -3px -8px;
	padding: 7px 12px;
	border: 0;
	border-radius: 8px;
	background: var(--write-accent);
	color: var(--bbs-ui-accent-fg, #fff);
	font: inherit;
	font-weight: var(--bbs-fw-semi, 600);
	font-size: 12px;
	cursor: pointer;
	transition: filter var(--bbs-anim-base, .15s) ease;
}
#bo_w .board-write input[type="file"]::file-selector-button:hover {
	filter: brightness(1.08);
}

/* 제목 필드 — 폼의 메인 입력이라 강조 */
#bo_w .board-write input#wr_subject {
	min-height: 46px;
	padding: 11px 14px;
	font-size: 15px;
	font-weight: var(--bbs-fw-semi, 600);
	letter-spacing: -0.01em;
}

#bo_w .board-write input[type="checkbox"] {
	width: 15px;
	height: 15px;
	margin: 0;
	accent-color: var(--write-accent);
	vertical-align: middle;
}

#bo_w .board-write select {
	max-width: 260px;
	padding-right: 30px;
}

#bo_w .board-write #ca_name,
#bo_w .board-write #set_secret,
#bo_w .board-write select[name="wr_2"],
#bo_w .board-write select[name="wr_9"] {
	width: auto;
	min-width: 150px;
}

#bo_w .board-write #write_category {
	display: inline-flex;
	align-items: center;
	min-width: 150px;
}

#bo_w .board-write #write_category select {
	max-width: none;
}

#bo_w .board-write .write-inline-options dd,
#bo_w .board-write .write-display-inline dd,
#bo_w .board-write .write-check-row {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: center;
}

#bo_w .board-write .write-inline-options label,
#bo_w .board-write .write-check-row label,
#bo_w .board-write .write-group dd input[type="checkbox"] + label {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	min-height: 32px;
	margin: 0;
	padding: 6px 12px;
	border: 1px solid var(--write-line);
	border-radius: 999px;
	background: var(--write-chip-bg);
	font-size: 12px;
	line-height: 1.2;
	color: var(--write-text);
	cursor: pointer;
	transition: background-color var(--bbs-anim-base, .15s) ease, border-color var(--bbs-anim-base, .15s) ease, color var(--bbs-anim-base, .15s) ease;
}

#bo_w .board-write .write-inline-options label:hover,
#bo_w .board-write .write-check-row label:hover,
#bo_w .board-write .write-group dd input[type="checkbox"] + label:hover {
	background: var(--write-chip-bg-hover);
	border-color: var(--write-line-strong);
}

#bo_w .board-write .write-inline-options label:has(input[type="checkbox"]:checked),
#bo_w .board-write .write-check-row label:has(input[type="checkbox"]:checked),
#bo_w .board-write .write-group dd input[type="checkbox"]:checked + label,
#bo_w .board-write label:has(> input[type="checkbox"]:checked) {
	background: var(--write-chip-bg-checked);
	border-color: var(--write-accent);
	color: var(--write-accent-dark);
	font-weight: var(--bbs-fw-semi, 600);
}

#bo_w .board-write #notice {
	margin-left: 0;
}

#bo_w .board-write .write-notice {
	padding: 14px 16px;
	border: 1px solid color-mix(in srgb, var(--write-accent) 26%, transparent);
	border-left: 3px solid var(--write-accent);
	border-radius: var(--write-radius-field);
	background: color-mix(in srgb, var(--write-accent) 8%, var(--write-panel) 92%);
	color: var(--write-text);
	font-size: 12.5px;
	line-height: 1.65;
}

#bo_w .board-write .wr_content {
	display: grid;
	gap: 10px;
}

#bo_w .board-write #wr_content {
	min-height: 420px !important;
	resize: vertical;
	font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
	font-size: 13px;
	line-height: 1.7;
	padding: 14px 16px;
	box-shadow: inset 0 1px 0 color-mix(in srgb, var(--write-line) 50%, transparent);
}

#bo_w .board-write #wr_content_viewer,
#bo_w .board-write .ra0-editor-wrapper,
#bo_w .board-write .ra0-editor-toolbar,
#bo_w .board-write .ra0-editor-footer {
	border-color: var(--write-line);
}

#bo_w .board-write .ra0-editor-wrapper {
	border-radius: var(--write-radius-field);
	overflow: hidden;
	box-shadow: var(--write-shadow-soft);
}

#bo_w .board-write #wr_content_viewer {
	min-height: 420px;
	padding: 16px;
	border-radius: var(--write-radius-field);
	background: var(--write-field-bg);
	box-shadow: inset 0 1px 0 color-mix(in srgb, var(--write-line) 50%, transparent);
}

#bo_w .board-write #char_count_desc,
#bo_w .board-write #char_count_wrap,
#bo_w .board-write .frm_desc,
#bo_w .board-write .media-desc {
	margin: 0;
	font-size: 12px;
	line-height: 1.55;
	color: var(--write-muted);
}

#bo_w .board-write .write-check-row + .frm_desc {
	display: block;
	max-width: 100%;
	margin-top: 8px;
}

#bo_w .board-write #char_count_wrap {
	justify-self: end;
	padding: 5px 11px;
	border-radius: 999px;
	background: var(--write-panel-soft);
	border: 1px solid var(--write-line);
	font-variant-numeric: tabular-nums;
}

#bo_w .board-write .media-row {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: 10px;
}

#bo_w .board-write .media-field {
	display: grid;
	gap: 7px;
	min-width: 0;
}

#bo_w .board-write .media-field .frm_input,
#bo_w .board-write .media-field .frm_file,
#bo_w .board-write .write-group-backup input.frm_input,
#bo_w .board-write .write-group-backup input.frm_input.full,
#bo_w .board-write .write-group-backup input[type="file"].frm_input.full {
	width: 100%;
	display: block;
}

#bo_w .board-write .write-group-backup dd {
	display: grid;
	gap: 7px;
}

#bo_w .board-write .txt-right {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	justify-content: flex-start;
	align-items: center;
	text-align: left;
}

#bo_w .board-write .txt-right label {
	font-size: 12px;
	font-weight: var(--bbs-fw-bold, 700);
	color: var(--write-muted);
}

#bo_w .btn_confirm {
	display: flex;
	justify-content: center;
	gap: 10px;
	max-width: 1040px;
	margin: 4px auto 28px;
	padding: 0 20px;
}

#bo_w .btn_confirm .ui-btn,
#bo_w .btn_confirm input[type="submit"] {
	min-width: 124px;
	height: 46px;
	padding: 0 22px;
	border-radius: var(--write-radius-field);
	border: 1px solid var(--write-line-strong);
	font-size: 13px;
	font-weight: var(--bbs-fw-bold, 700);
	line-height: 44px;
	letter-spacing: 0.02em;
	cursor: pointer;
	transition: transform var(--bbs-anim-fast, .12s) ease, box-shadow .18s ease, background-color .18s ease, border-color .18s ease, color .18s ease;
}

#bo_w .btn_confirm .btn_submit,
#bo_w .btn_confirm .ui-btn.point {
	border-color: var(--write-accent);
	background: var(--write-accent);
	color: var(--bbs-ui-accent-fg, var(--btn-accent-text, #fff));
	box-shadow: 0 8px 22px color-mix(in srgb, var(--write-accent) 38%, transparent);
}

#bo_w .btn_confirm .btn_cancel {
	background: var(--write-field-bg);
	color: var(--write-muted);
}

#bo_w .btn_confirm .btn_submit:hover,
#bo_w .btn_confirm .btn_submit:focus-visible {
	background: var(--write-accent-dark);
	border-color: var(--write-accent-dark);
	transform: translateY(-1px);
	box-shadow: 0 12px 28px color-mix(in srgb, var(--write-accent) 44%, transparent);
}

#bo_w .btn_confirm .btn_submit:active {
	transform: translateY(0);
	box-shadow: 0 4px 12px color-mix(in srgb, var(--write-accent) 36%, transparent);
}

#bo_w .btn_confirm .btn_cancel:hover,
#bo_w .btn_confirm .btn_cancel:focus-visible {
	border-color: var(--write-accent);
	color: var(--write-accent-dark);
	background: var(--write-field-bg-hover);
}

@media all and (max-width: 760px) {
	#bo_w .board-write {
		padding: 14px;
		gap: 10px;
	}

	#bo_w .board-write .write-group {
		padding: 14px;
	}

	#bo_w .board-write dl {
		grid-template-columns: 1fr;
		gap: 6px;
	}

	#bo_w .board-write dl>dt {
		min-height: 0;
	}

	#bo_w .board-write select,
	#bo_w .board-write #ca_name,
	#bo_w .board-write #set_secret,
	#bo_w .board-write select[name="wr_2"],
	#bo_w .board-write select[name="wr_9"],
	#bo_w .board-write #write_category {
		width: 100%;
		max-width: none;
	}

	#bo_w .board-write .media-row {
		grid-template-columns: 1fr;
	}

	#bo_w .board-write #wr_content,
	#bo_w .board-write #wr_content_viewer {
		min-height: 340px !important;
	}

	#bo_w .btn_confirm {
		padding: 0 14px;
	}

	#bo_w .btn_confirm .ui-btn,
	#bo_w .btn_confirm input[type="submit"] {
		flex: 1 1 0;
		min-width: 0;
	}
}

.board-viewer.bbs-box {
	display: block;
	position: relative;
	padding: 20px;
}

/* 부모 테마 (라공) 의 #container_wr 가 padding-top: 30px — 뷰 페이지에선 hero-banner 가 카드 상단을 통째로 채우므로 그 위 공백 제거.
   :has(#bo_v_con) 로 GnuBoard 표준 view 컨테이너가 있는 페이지만 매치 (목록/작성/기타 페이지엔 #bo_v_con 없음 → 영향 없음). */
#container_wr:has(#bo_v_con) {
	padding-top: 0;
}

/* prefers-reduced-motion — 사용자가 OS/브라우저에서 모션 줄임을 켰을 때 전체 모션 (transition / transform / animation) 비활성화.
   접근성 (vestibular disorder 등) 및 배터리 절약. duration 0 + transform/animation: none. */
@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		transition-duration: 0s !important;
		animation-duration: 0s !important;
		animation-iteration-count: 1 !important;
		scroll-behavior: auto !important;
	}
	/* hover 시 박스가 튀는 효과 등 — transform 자체 무효화. */
	.bbs-btn:hover,
	.bbs-cat-btn:hover,
	.bbs-filter-btn:hover,
	.bbs-quick-btn:hover,
	#bo_v_con .reaction-btn:hover,
	#bo_v_con .reaction-emoji:hover,
	#bo_v_con .reaction-fab:hover {
		transform: none !important;
	}
}

/* 배경 이미지 명도 기반 자동 대비 (JS 가 평균 휘도 측정 → .chat-bg-dark/.chat-bg-light 토글).
   bubble 내부 텍스트는 PHP bbs_text_color_from_bg 가 이미 처리. 여기선 페이지 배경 위에 직접 놓이는 텍스트만 처리.
   date-sep 은 자체 pill 배경 (--bbs-date-bg) 위에 있어서 페이지 배경 명도와 무관 → 라공 기본 색 (--bbs-date-fg) 그대로 유지. */
body.chat-bg-dark #bo_v_con .chat-nickname,
body.chat-bg-dark .bubble-time,
body.chat-bg-dark .chat-system-text {
	color: rgba(255, 255, 255, 0.92);
	text-shadow: 0 1px 3px rgba(0, 0, 0, 0.6);
}
body.chat-bg-light #bo_v_con .chat-nickname,
body.chat-bg-light .bubble-time,
body.chat-bg-light .chat-system-text {
	color: rgba(0, 0, 0, 0.85);
	text-shadow: 0 1px 2px rgba(255, 255, 255, 0.5);
}

/* 하트 fab 도 배경 명도에 따라 색 변경. */
body.chat-bg-dark #bo_v_con .reaction-fab {
	color: rgba(255, 255, 255, 0.9);
	background: rgba(255, 255, 255, 0.15);
}
body.chat-bg-light #bo_v_con .reaction-fab {
	color: rgba(0, 0, 0, 0.85);
	background: rgba(0, 0, 0, 0.12);
}
.board-viewer {
	position: relative;
	/* 상하단 동일 여백 — viewer 위/아래 30px 균형. */
	margin-top: 30px;
	margin-bottom: 30px;
}

/* === 헤더 배너 (썸네일 hero) ============================================ */
/* .board-viewer.bbs-box는 padding:20px + border-radius:20px. 배너는 박스의 상/좌/우 패딩까지
   넘겨 받아 카드 상단을 통째로 채운다. 상단 두 모서리만 박스 곡률과 동일하게 둥글림. */
.bbs-hero-banner {
	position: relative;
	width: auto;
	margin: -20px -20px 18px -20px;
	aspect-ratio: 16 / 5;
	min-height: 180px;
	max-height: 360px;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	overflow: hidden;
	color: #ffffff;
	isolation: isolate;
	border-radius: 20px 20px 0 0;
	/* 게시글별 폰트 (wr_2) 상속. .bbs-box 안이라 자동 상속되지만 명시적으로 한 번 더 보장. */
	font-family: inherit;
}

.bbs-hero-banner::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(0, 0, 0, 0.2) 0%, rgba(0, 0, 0, 0.05) 45%, rgba(0, 0, 0, 0.55) 100%);
	z-index: 1;
	pointer-events: none;
}

.bbs-hero-text {
	position: absolute;
	left: 24px;
	right: 24px;
	bottom: 22px;
	z-index: 2;
	pointer-events: none;
	text-align: left;
	color: #ffffff;
	font-family: inherit;
}

.bbs-hero-title {
	margin: 0;
	font-size: 22px;
	line-height: 1.2;
	font-weight: var(--bbs-fw-bold, 700);
	letter-spacing: 0.02em;
	color: #ffffff;
	font-family: inherit;
	text-shadow: 0 2px 10px rgba(0, 0, 0, 0.65), 0 1px 3px rgba(0, 0, 0, 0.55);
}

.bbs-hero-subtitle {
	margin: 6px 0 0;
	font-size: 12px;
	line-height: 1.3;
	color: #ffffff;
	opacity: 0.92;
	font-family: inherit;
	text-shadow: 0 2px 6px rgba(0, 0, 0, 0.6);
}

/* 배너가 있으면 기존 제목/부제목 텍스트 라인은 시각적으로 중복이라 숨김 (편집모드에서는 다시 보이게) */
.board-viewer.has-banner-image > .subject .subject-view {
	display: none;
}
.board-viewer.has-banner-image > .info {
	display: none;
}
body.chat-edit-on .board-viewer.has-banner-image > .subject .subject-view,
body.chat-edit-on .board-viewer.has-banner-image > .info {
	display: block;
}
/* 배너 자체는 편집 모드에서 보조 정보로만 남기고 인풋이 본문이 되도록 살짝 흐리게 */
body.chat-edit-on .bbs-hero-banner {
	opacity: 0.55;
}

@media (max-width: 700px) {
	.bbs-hero-banner {
		/* 모바일에서는 .board-viewer.bbs-box의 padding이 0이므로 음수 마진도 0 */
		margin: 0 0 14px 0;
		aspect-ratio: 16 / 7;
		min-height: 150px;
		border-radius: 0;
	}
	.bbs-hero-text {
		left: 16px;
		right: 16px;
		bottom: 16px;
	}
}

/* 이미지 없는 케이스 — 데스크탑에선 hero-banner 숨기고 일반 .subject/.info 사용. */
.board-viewer.no-banner-image .bbs-hero-banner {
	display: none;
}

@media (max-width: 700px) {
	/* 모바일: 이미지 없어도 hero-banner 보이게 (fallback 배경) — 가시성 위해 강제.
	   테마 accent 색 + 어두운 베이스 합성 → 라이트/다크 테마 모두 흰 텍스트 contrast 유지하면서 톤이 테마 따라감.
	   --bbs-hero-fallback-tint 로 테마별 override 가능. */
	.board-viewer.no-banner-image .bbs-hero-banner {
		display: block;
		background-color: var(--p-color-sub, var(--bbs-base, #1a1a1a));
		background-image: linear-gradient(
			135deg,
			var(--bbs-hero-fallback-tint, color-mix(in srgb, var(--p-color-main, #1a1a1a) 55%, rgba(0,0,0,0.6))) 0%,
			color-mix(in srgb, var(--p-color-main, #000) 30%, rgba(0,0,0,0.85)) 100%
		);
	}
	/* hero-banner 보이니까 중복 표시 안 되게 일반 subject/info 숨김. */
	.board-viewer.no-banner-image > .subject .subject-view,
	.board-viewer.no-banner-image > .info {
		display: none;
	}
	/* 편집 모드는 입력 필드 보이게 다시 노출. */
	body.chat-edit-on .board-viewer.no-banner-image > .subject .subject-view,
	body.chat-edit-on .board-viewer.no-banner-image > .info {
		display: block;
	}
	body.chat-edit-on .board-viewer.no-banner-image .bbs-hero-banner {
		opacity: 0.55;
	}
}

.board-viewer .subject {
	text-align: center;
}

.board-viewer .subject em {
	display: block;
	position: relative;
	font-size: 14px;
	line-height: 1.2em;
	padding-bottom: 10px;
}

.board-viewer .subject strong {
	display: block;
	position: relative;
	font-size: 22px;
	line-height: 1.2em;
}

.board-viewer .info {
	margin-top: 10px;
	text-align: center;
	font-size: 11px;
}

.board-viewer .info span {
	display: inline-block;
	opacity: .8;
}

.board-viewer .info span+span:before {
	content: "";
	display: inline-block;
	width: 1px;
	height: 8px;
	vertical-align: middle;
	margin: 0 10px;
}

.board-viewer .contents {
	display: block;
	position: relative;
	margin: 20px 0;
	padding: 40px 15px;
	border-left-width: 0;
	border-right-width: 0;
}

@media all and (max-width: 1000px) {
	.board-viewer .contents {
		padding: 0;
	}
}

#bo_v_bot {
	padding: 20px 0 0;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: flex-start;
	justify-content: space-between;
}

.bo_v_nb {
	float: none;
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.bo_v_com {
	float: none;
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	justify-content: flex-end;
	margin-left: auto;
}

#bo_v_bot .ui-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: var(--bbs-ui-btn-h, 30px);
	padding: 0 12px;
	border-radius: var(--bbs-ui-radius, 10px);
	background: var(--bbs-ctrl-bg, var(--bbs-base2));
	color: var(--bbs-ui-fg-strong, var(--bbs-text));
}

#bo_v_bot .ui-btn:hover,
#bo_v_bot .ui-btn:focus-visible {
	background: var(--bbs-ctrl-bg-hover, var(--bbs-point));
	color: var(--bbs-ui-fg-strong, var(--bbs-text));
}


.board-comment-list {
	position: relative;
}

/* hr.co-line — 시각 구분은 .item 의 border-top 으로 대체 */
.board-comment-list .co-line {
	display: none;
}

.board-comment-list .item {
	position: relative;
	display: grid;
	grid-template-columns: 36px 1fr;
	grid-template-rows: auto auto;
	column-gap: 12px;
	row-gap: 2px;
	padding: 14px 4px;
	border-top: 1px solid color-mix(in srgb, var(--bbs-ui-fg, var(--bbs-text)) 12%, transparent);
}

.board-comment-list .item:first-of-type {
	border-top: none;
}

.board-comment-list .cmt-avatar {
	grid-column: 1;
	grid-row: 1;
	align-self: start;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-weight: var(--bbs-fw-bold, 700);
	font-size: 15px;
	line-height: 1;
	user-select: none;
	flex-shrink: 0;
	text-shadow: 0 1px 1px rgba(0, 0, 0, .15);
	overflow: hidden;
}

/* 라공 회원 프사 (실제 이미지) — 이니셜 배경/그림자 제거하고 이미지로 채움. */
.board-comment-list .cmt-avatar.cmt-avatar-img {
	background: transparent;
	text-shadow: none;
}

.board-comment-list .cmt-avatar.cmt-avatar-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	border-radius: 50%;
}

.board-comment-list .co-name {
	grid-column: 2;
	grid-row: 1;
	position: static;
	width: auto;
	padding: 0;
	font-size: 13px;
	font-weight: var(--bbs-fw-semi, 600);
	line-height: 1.2;
	align-self: center;
}

.board-comment-list .co-content {
	grid-column: 2;
	grid-row: 2;
}

.board-comment-list .co-name a {
	color: var(--bbs-point);
	text-decoration: none;
	transition: color var(--bbs-anim-base, .15s) ease;
}

.board-comment-list .co-name a:hover,
.board-comment-list .co-name a:focus-visible {
	text-decoration: underline;
}

.board-comment-list .co-inner {
	font-size: 14px;
	line-height: 1.45;
	color: var(--bbs-ui-fg-strong, var(--bbs-text));
	word-break: break-word;
	/* 줄바꿈은 gnuboard가 넣는 <br>가 담당. pre-wrap이면 PHP 템플릿 들여쓰기(줄바꿈/탭)와
	   본문의 raw \n까지 렌더돼 첫 줄이 밀리고 줄간격이 이중으로 벌어진다 → normal 로 정리. */
	white-space: normal;
}

.board-comment-list .co-inner .secret {
	display: inline-block;
	margin-right: 6px;
	padding: 1px 8px;
	font-size: 11px;
	font-weight: var(--bbs-fw-semi, 600);
	color: var(--bbs-base);
	background: var(--bbs-point);
	border-radius: var(--bbs-ui-radius-pill, 999px);
	vertical-align: middle;
	white-space: nowrap;
}

.board-comment-list .co-inner img.bubble-image {
	max-width: 100%;
	border-radius: 8px;
	margin: 4px 0;
	display: block;
}

.board-comment-list .co-info {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	flex-wrap: wrap;
	gap: 0;
	margin-top: 8px;
	padding-top: 0;
	font-size: 11px;
	color: var(--bbs-ui-fg-muted, color-mix(in srgb, var(--bbs-text) 60%, transparent));
	opacity: 1;
}

.board-comment-list .co-info span {
	display: inline-flex;
	align-items: center;
	opacity: 1;
}

.board-comment-list .co-info span + span:before {
	content: "·";
	display: inline-block;
	width: auto;
	height: auto;
	margin: 0 6px;
	opacity: .5;
	vertical-align: baseline;
}

.board-comment-list .co-info a {
	color: inherit;
	text-decoration: none;
	padding: 2px 6px;
	margin: 0 -2px;
	border-radius: 4px;
	transition: color var(--bbs-anim-base, .15s), background var(--bbs-anim-base, .15s);
}

.board-comment-list .co-info a:hover,
.board-comment-list .co-info a:focus-visible {
	color: var(--bbs-ui-fg-strong, var(--bbs-text));
	background: var(--bbs-ui-bg, rgba(255, 255, 255, .08));
	outline: none;
}

/* 답변/수정 버튼. <a> 였을 때와 시각/동작 동일 — 버튼이라 페이지 네비게이션 자체가 없음. */
.board-comment-list .co-info .cmt-action-btn {
	font: inherit;
	color: inherit;
	background: none;
	border: 0;
	padding: 2px 6px;
	margin: 0 -2px;
	border-radius: 4px;
	cursor: pointer;
	transition: color var(--bbs-anim-base, .15s), background var(--bbs-anim-base, .15s);
}

.board-comment-list .co-info .cmt-action-btn:hover,
.board-comment-list .co-info .cmt-action-btn:focus-visible {
	color: var(--bbs-ui-fg-strong, var(--bbs-text));
	background: var(--bbs-ui-bg, rgba(255, 255, 255, .08));
	outline: none;
}

/* 삭제 버튼 (POST 폼). 시각/동작은 .co-info a 와 동일하게. */
.board-comment-list .co-info .cmt-delete-form {
	display: inline;
	margin: 0;
	padding: 0;
	border: 0;
	background: none;
}

.board-comment-list .co-info .cmt-delete-btn {
	font: inherit;
	color: inherit;
	background: none;
	border: 0;
	padding: 2px 6px;
	margin: 0 -2px;
	border-radius: 4px;
	cursor: pointer;
	transition: color var(--bbs-anim-base, .15s), background var(--bbs-anim-base, .15s);
}

.board-comment-list .co-info .cmt-delete-btn:hover,
.board-comment-list .co-info .cmt-delete-btn:focus-visible {
	color: var(--bbs-ui-fg-strong, var(--bbs-text));
	background: var(--bbs-ui-bg, rgba(255, 255, 255, .08));
	outline: none;
}

.board-comment-list .item.reply {
	border-left: 2px solid var(--bbs-point);
	padding-left: 16px;
	background: color-mix(in srgb, var(--bbs-ui-fg, var(--bbs-text)) 3%, transparent);
}

.board-comment-list .item.reply .co-name {
	background: none;
}


.board-comment-list + .board-comment-write {
	margin-top: 16px;
}

.open_c,
.close_c {
	cursor: pointer;
	margin-top: 12px;
	padding: 10px 14px;
	text-align: center;
	border-radius: var(--bbs-ui-radius, 10px);
	background: var(--bbs-ui-bg, rgba(255, 255, 255, .05));
	font-size: 12px;
	color: var(--bbs-ui-fg-muted, color-mix(in srgb, var(--bbs-text) 60%, transparent));
	transition: background var(--bbs-anim-base, .15s), color var(--bbs-anim-base, .15s);
	user-select: none;
}

.open_c:hover,
.close_c:hover {
	background: var(--bbs-ui-bg-hover, rgba(255, 255, 255, .1));
	color: var(--bbs-ui-fg-strong, var(--bbs-text));
}

#bo_vc_w {
	margin-top: 12px;
}

.board-comment-form {
	position: relative;
	margin-top: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.board-comment-form #char_cnt {
	align-self: flex-end;
	font-size: 11px;
	font-weight: 400;
	color: var(--bbs-ui-fg-muted, color-mix(in srgb, var(--bbs-text) 60%, transparent));
}

.board-comment-form textarea {
	display: block;
	width: 100%;
	min-height: 90px;
	box-sizing: border-box;
	padding: 10px 12px;
	resize: vertical;
	border: 1px solid color-mix(in srgb, var(--bbs-ui-fg, var(--bbs-text)) 18%, transparent);
	border-radius: var(--bbs-ui-radius, 10px);
	background: var(--bbs-field-bg, rgba(0, 0, 0, .15));
	color: var(--bbs-ui-fg-strong, var(--bbs-text));
	font-size: 14px;
	line-height: 1.55;
	font-family: inherit;
}

.board-comment-form textarea:focus {
	outline: none;
	border-color: var(--bbs-point);
	box-shadow: 0 0 0 2px color-mix(in srgb, var(--bbs-point) 30%, transparent);
}

.board-comment-form p {
	margin: 0;
	padding: 0;
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	color: var(--bbs-ui-fg, var(--bbs-text));
}

.board-comment-form p label[for="wr_secret"] {
	cursor: pointer;
	user-select: none;
}

.board-comment-form .btn_confirm {
	position: relative;
	align-self: flex-end;
	margin: 0;
}

.board-comment-form .btn_confirm .ui-btn {
	width: auto;
	height: auto;
	margin: 0;
	padding: 9px 22px;
	background: var(--bbs-ui-accent-bg, var(--bbs-point));
	color: var(--bbs-ui-accent-fg, var(--bbs-base));
	border: none;
	border-radius: var(--bbs-ui-radius, 10px);
	font-size: 13px;
	font-weight: var(--bbs-fw-semi, 600);
	cursor: pointer;
	transition: opacity var(--bbs-anim-base, .15s), transform .1s;
}

.board-comment-form .btn_confirm .ui-btn:hover {
	opacity: .9;
}

.board-comment-form .btn_confirm .ui-btn:active {
	transform: translateY(1px);
}



@media all and (max-width: 1000px) {

	html.single:before,
	html.single::before,
	body.single:before,
	body.single::before,
	.single:before,
	.single::before {
		content: none !important;
		display: none !important;
		opacity: 0 !important;
		visibility: hidden !important;
		width: 0 !important;
		height: 0 !important;
	}

	html.single {
		transform: none !important;
	}

	.bbs-list-wrap {
		max-width: 100% !important;
		width: 100% !important;
		margin: 0 !important;
		padding: 0 10px;
		box-sizing: border-box;
	}

	.bbs-list {
		width: 100%;
	}

	.bbs-list li a {
		padding: 10px 14px;
		line-height: 1.3em;
		overflow: hidden;
		white-space: nowrap;
		text-overflow: ellipsis;
		flex-direction: row;
		align-items: center;
		gap: 8px;
		width: 100%;
		box-sizing: border-box;
	}

	.bbs-list li .ico-cate,
	.bbs-list li .name,
	.bbs-list li .date,
	.bbs-list li .hit {
		position: static;
		width: auto;
		left: auto;
		right: auto;
		bottom: auto;
		line-height: 1.2em;
	}


	.bbs-list li .ico-cate {
		display: inline;
	}

	.bbs-list li .ico-cate:before {
		content: "[ ";
	}

	.bbs-list li .ico-cate:after {
		content: " ]";
	}

		.bbs-list li .bbs-list-subject {
			display: inline-block;
			line-height: 1.3em;
			max-width: calc(100% - 120px);
			white-space: nowrap;
			overflow: hidden;
			text-overflow: ellipsis;
		}

	.bbs-list li .name,
	.bbs-list li .hit {
		display: inline-flex;
		padding: 0;
	}

	.bbs-list li .date {
		display: inline-flex;
		padding: 3px 6px;
	}

	.bbs-list li .hit {
		margin-left: 6px;
	}

	.bbs-list li {
		height: auto;
		padding: 8px 0;
	}

	/* 모바일: 썸네일 영역 확대 */
	.bbs-list-front,
	.bbs-list-back {
		background-size: 170% !important;
		background-position: center right !important;
	}

	/* 모바일: 체크박스 숨김 */
	.bbs-list .td_chk {
		display: none !important;
	}

	.bo_fx .chk_all {
		display: none !important;
	}

	.bbs-list li:hover {
		height: auto;
	}

	.bbs-list .info {
		position: absolute;
		right: 20px;
		padding: 5px 0;
		height: 13px;
		background: var(--bbs-text);
		color: var(--bbs-base);
		border-radius: 5px;
	}

	.bbs-filter {
		width: 100%;
		justify-content: center;
	}

	.bbs-filter-btn,
	.bbs-quick-btn,
	.bbs-quick-clear {
		height: 30px;
		font-size: 11px;
	}

	.board-category select {
		flex: 1;
		min-width: 0;
	}

	.bo_fx {
		order: -1;
	}

	#fboardlist {
		display: flex;
		flex-direction: column;
		gap: 10px;
	}

	.bbs-category-actions {
		justify-content: flex-end;
	}

	.board-comment-list .item {
		grid-template-columns: 30px 1fr;
		column-gap: 10px;
		padding: 12px 2px;
	}

	.board-comment-list .item.reply {
		padding-left: 12px;
	}

	.board-comment-list .cmt-avatar {
		width: 30px;
		height: 30px;
		font-size: 13px;
	}

	.board-comment-list .co-inner {
		word-break: break-all;
	}

	/* 모바일: 리스트 미리보기 숨김 */
	.bbs-list-preview {
		display: none !important;
	}

	.bbs-list-box.has-preview {
		overflow: hidden;
	}

}

.bbs_background {
	width: 100vw;
	height: 100vh;
	top: 0;
	left: 0;
	position: fixed;
	pointer-events: none;
	z-index: 0;
	opacity: 0;
	transition: opacity .35s ease;
}

html.opt-bg-blur .bbs_background {
	filter: blur(10px);
	transform: scale(1.02);
}

.bbs_background.is-loaded {
	opacity: 1;
}

html.opt-box-trans #pair_view_content {
	background: transparent !important;
	backdrop-filter: blur(6px);
}

html.opt-box-trans .board-viewer {
	background: color-mix(in srgb, var(--bbs-base) 75%, transparent);
}

html.opt-box-clear #pair_view_content {
	background: transparent !important;
	backdrop-filter: none !important;
}

html.opt-box-clear .board-viewer {
	background: transparent !important;
}

.bbs-list-box {
	overflow: hidden;
	box-sizing: content-box;
	content-visibility: auto;
	contain-intrinsic-size: 140px 600px;
	position: relative;
}

.bbs-list-box:hover,
.bbs-list-box.has-preview {
	content-visibility: visible;
}

.bbs-list-box.has-preview {
	overflow: visible;
}

.bbs-list-box.is-filtered-out {
	display: none !important;
}

.bbs-list-preview {
	position: absolute;
	left: calc(100% + 12px);
	right: auto;
	top: 50%;
	bottom: auto;
	background: rgba(25, 25, 25, 0.96);
	color: #f2f2f2;
	border-radius: 12px;
	padding: 10px;
	box-shadow: 0 12px 28px rgba(0, 0, 0, .35);
	display: flex;
	flex-direction: column;
	gap: 8px;
	opacity: 0;
	transform: translateY(-50%) translateX(6px);
	pointer-events: none;
	transition: opacity var(--bbs-anim-base, .15s) ease, transform var(--bbs-anim-base, .15s) ease;
	z-index: 3;
	width: 280px;
	max-width: 45vw;
}

.bbs-list-box:hover .bbs-list-preview,
.bbs-list-box>a:hover+.bbs-list-preview {
	opacity: 1;
	transform: translateY(-50%) translateX(0);
}

@media screen and (max-width: 1000px) {
	.bbs-list-preview {
		left: 12px;
		right: 12px;
		top: auto;
		bottom: calc(100% + 8px);
		width: auto;
		max-width: none;
		transform: translateY(6px);
	}

	.bbs-list-box:hover .bbs-list-preview,
	.bbs-list-box>a:hover+.bbs-list-preview {
		transform: translateY(0);
	}
}

.bbs-list-preview-thumb {
	width: 100%;
	height: 120px;
	border-radius: 10px;
	position: relative;
	overflow: hidden;
	background-size: cover;
	background-position: center;
	background-color: rgba(255, 255, 255, 0.08);
}

.bbs-list-preview-thumb.is-empty::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(120deg, transparent 0%, rgba(255, 255, 255, 0.12) 45%, rgba(255, 255, 255, 0.22) 50%, rgba(255, 255, 255, 0.12) 55%, transparent 100%);
	transform: translateX(-100%);
	animation: previewShimmer 1.4s ease-in-out infinite;
}

@keyframes previewShimmer {
	0% {
		transform: translateX(-100%);
	}

	100% {
		transform: translateX(100%);
	}
}

.bbs-list-preview-text {
	font-size: 12px;
	line-height: 1.35;
	opacity: .92;
	white-space: pre-wrap;
	word-break: break-word;
}

.bbs-filter-quick {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	align-items: center;
	margin: 0;
	pointer-events: auto;
	position: relative;
	z-index: 5;
}

/* .bbs-quick-btn / .bbs-quick-clear 베이스는 위 .bbs-filter-btn 단일 룰에서 통합 관리. 여기는 active 만. */


.bbs-list-box:hover .ico-cate {
	opacity: 0;
}


.bbs-box {
	width: calc(100% - 80px);
	border-radius: 20px;
}

.bbs-btn-header {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	flex-direction: column;
	gap: 10px;
	z-index: 3200;
	/* sticky + height 0 트릭: normal flow 자리 안 차지(viewer 안 빈 공간 해소).
	   width:0/height:0 wrapper처럼 동작하면서 overflow:visible로 자식 버튼들이 보임.
	   margin-left: -80px로 viewer 왼쪽 외부에 위치.
	   모바일 미디어쿼리(≤1000px)에서 fixed 좌표로 !important 오버라이드. */
	position: sticky;
	top: 84px;
	width: 0;
	height: 0;
	overflow: visible;
	margin-left: -80px;
	margin-right: 0;
	margin-top: 0;
	margin-bottom: 0;
	padding: 0;
	left: auto;
	right: auto;
	bottom: auto;
	transform: none;
	translate: 0 0;
}
/* width/height 0인 부모 안에서 flex 자식들이 visible로 부모 박스 밖에 그려짐 */
.bbs-btn-header > .bbs-btn {
	flex-shrink: 0;
}

.bbs-btn {
	width: 40px;
	height: 40px;
	min-height: 40px;
	margin: 0;
	padding: 0;
	text-align: center;
	border-radius: 12px;
	font-size: 16px;
	display: inline-flex;
	justify-content: center;
	align-items: center;
	background: rgba(255, 255, 255, 0.95);
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
	transition: background var(--bbs-anim-base, 0.15s) ease, transform var(--bbs-anim-base, 0.15s) ease, box-shadow var(--bbs-anim-base, 0.15s) ease;
}
.bbs-btn-header .bbs-btn:hover {
	transform: translateY(-1px);
	box-shadow: 0 3px 8px rgba(0, 0, 0, 0.12);
}

.bbs-btn-toggle {
	display: none;
}

.bbs-btn:hover {
	color: #e3e3e3;
	background: #686868;
}

.bbs-btn.incompletebtn {
	position: sticky;
	top: 12px;
	z-index: 5;
}

.bbs-btn.incompletebtn .fa-check {
	display: none !important;
}

.bbs-btn.incompletebtn .fa-flag {
	display: inline-block !important;
}

.bbs-btn.incompletebtn.active {
	background: var(--bbs-point);
	color: #111;
}

.bbs-btn.favoritebtn.active {
	background: var(--bbs-point);
	color: #111;
}

.bbs-btn.incompletebtn.active .fa-flag {
	display: none !important;
}

.bbs-btn.incompletebtn.active .fa-check {
	display: inline-block !important;
}

.edit-only {
	display: none;
}

.chat-edit-on .edit-only {
	display: inline-flex;
}

.chat-edit-on .subject-view,
.chat-edit-on .info-view {
	display: none;
}

.chat-edit-on .subject .subject-view {
	display: none;
}

body.chat-edit-on .info-view {
	display: none;
}

.subject-edit {
	width: min(560px, 78vw);
	padding: 6px 10px;
	border: 0;
	border-radius: 8px;
	background: var(--bbs-field-bg);
	color: inherit;
	font-size: 18px;
	font-weight: var(--bbs-fw-semi, 600);
	margin-left: 6px;
}

.subject-flag {
	margin-left: 0;
	font-size: 12px;
	align-items: center;
	gap: 6px;
}

.subject-flag input {
	accent-color: var(--bbs-ui-accent-bg);
}

.subject {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	flex-wrap: wrap;
}

.subject .subject-view {
	display: inline;
}

.subject-right {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

/* .bbs-square 테마 규칙은 themes/square.css에서 단일 관리 */

.info.info-empty {
	display: none;
}

.chat-edit-on .info.info-empty {
	display: block;
}

.info-edit {
	margin-top: 6px;
	width: min(420px, 72vw);
	padding: 6px 10px;
	border: 0;
	border-radius: 8px;
	background: var(--bbs-field-bg);
	color: inherit;
	font-size: 13px;
}

/* 편집 모드에서는 제목/부제목 입력칸을 컨테이너 폭 전체로 확장 */
body.chat-edit-on .subject {
	display: block;
	width: 100%;
}

body.chat-edit-on .subject-right {
	display: block;
	width: 100%;
}

body.chat-edit-on .subject-edit,
body.chat-edit-on .info-edit {
	display: block;
	width: 100%;
	max-width: none;
	margin-left: 0;
	box-sizing: border-box;
}

.bbs-search-panel {
	position: fixed;
	width: 260px;
	padding: 12px;
	border-radius: 16px;
	background: var(--bbs-panel-bg);
	color: var(--bbs-ui-fg);
	box-shadow: var(--bbs-ui-shadow);
	z-index: var(--z-topmost, 2147483647);
}

.bbs-settings-panel {
	position: fixed;
	width: 240px;
	padding: 12px 12px 8px;
	border-radius: 16px;
	background: var(--bbs-panel-bg);
	color: var(--bbs-ui-fg);
	box-shadow: var(--bbs-ui-shadow);
	z-index: var(--z-topmost, 2147483647);
	overflow: visible !important;
}

.pcr-app {
	position: fixed !important;
	z-index: var(--z-topmost-tooltip, 2147483648) !important;
}

.bbs-settings-title {
	font-size: 12px;
	letter-spacing: 0.5px;
	margin-bottom: 6px;
	opacity: 0.8;
}

.bbs-settings-row {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-top: 6px;
	font-size: 12px;
	cursor: pointer;
}

.bbs-settings-row input {
	accent-color: var(--bbs-ui-accent-bg);
}

.bbs-settings-note {
	margin-top: 6px;
	font-size: 11px;
	opacity: 0.7;
}

.bbs-settings-field {
	display: flex;
	flex-direction: column;
	gap: 4px;
	margin-top: 8px;
	font-size: 11px;
}

.bbs-bg-wrap {
	position: relative;
	display: inline-flex;
	align-items: center;
}

.bbs-media-row {
	display: flex;
	gap: 10px;
	align-items: center;
}

.bbs-thumb-wrap {
	position: relative;
	display: inline-flex;
	align-items: center;
}


.bbs-thumb-preview {
	width: 56px;
	height: 56px;
	border-radius: 10px;
	background: rgba(80, 80, 80, 0.9);
	background-size: cover;
	background-position: center;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	position: relative;
	overflow: hidden;
}

body.bbs-theme-square .bbs-thumb-preview,
body.bbs-theme-square .bbs-bg-preview,
.bbs-square .bbs-thumb-preview,
.bbs-square .bbs-bg-preview {
	border-radius: 0;
}

.bbs-thumb-preview .bbs-thumb-empty {
	font-size: 11px;
	opacity: 0.7;
}

.bbs-thumb-popover {
	position: absolute;
	left: calc(100% + 8px);
	top: 0;
	transform: none;
	min-width: 0;
	width: max-content;
	padding: 8px;
	border-radius: 10px;
	background: rgba(60, 60, 60, 0.96);
	color: #e3e3e3;
	box-shadow: 0 10px 24px rgba(0, 0, 0, 0.28);
	display: none;
	z-index: 20;
	gap: 6px;
	flex-wrap: wrap;
}

.bbs-thumb-url-row {
	display: flex;
	gap: 6px;
	width: 100%;
	align-items: center;
	margin-top: 6px;
}

.bbs-thumb-url-row input[type="text"] {
	background: rgba(80, 80, 80, 0.9);
	border: 0;
	border-radius: 10px;
	color: #e3e3e3;
	padding: 6px 8px;
	font-size: 12px;
	min-width: 0;
	width: 100%;
	box-sizing: border-box;
}

.bbs-thumb-popover button {
	border: 0;
	border-radius: 10px;
	background: rgba(80, 80, 80, 0.9);
	color: #e3e3e3;
	padding: 6px 10px;
	font-size: 12px;
	cursor: pointer;
	white-space: nowrap;
}

.bbs-thumb-popover button:hover {
	background: #686868;
}

.bbs-bg-row {
	display: flex;
	gap: 6px;
	align-items: center;
}

.bbs-bg-preview {
	width: 56px;
	height: 56px;
	border-radius: 10px;
	background: rgba(80, 80, 80, 0.9);
	background-size: cover;
	background-position: center;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	position: relative;
	overflow: hidden;
}

.bbs-bg-preview .bbs-bg-empty {
	font-size: 11px;
	opacity: 0.7;
}

.bbs-bg-popover {
	position: absolute;
	left: calc(25% + 8px);
	top: 0;
	transform: none;
	min-width: 0;
	width: max-content;
	padding: 8px;
	border-radius: 10px;
	background: rgba(60, 60, 60, 0.96);
	color: #e3e3e3;
	box-shadow: 0 10px 24px rgba(0, 0, 0, 0.28);
	display: none;
	z-index: 20;
	gap: 6px;
	flex-wrap: wrap;
}

.bbs-bg-url-row {
	display: flex;
	gap: 6px;
	width: 100%;
	align-items: center;
	margin-top: 6px;
}

.bbs-bg-url-row input[type="text"] {
	background: rgba(80, 80, 80, 0.9);
	border: 0;
	border-radius: 10px;
	color: #e3e3e3;
	padding: 6px 8px;
	font-size: 12px;
	min-width: 0;
	width: 100%;
	box-sizing: border-box;
}

.bbs-bg-popover button {
	border: 0;
	border-radius: 10px;
	background: rgba(80, 80, 80, 0.9);
	color: #e3e3e3;
	padding: 6px 10px;
	font-size: 12px;
	cursor: pointer;
	white-space: nowrap;
}

.bbs-bg-popover button:hover {
	background: #686868;
}

.bbs-settings-field label {
	opacity: 0.8;
}

/* 게시글 화자 치환 헤더 — 라벨 옆 + 아이콘으로 화자 추가 */
.post-speaker-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 6px;
	margin-bottom: 2px;
}
.post-speaker-head label {
	margin: 0;
	flex: 1;
}
.post-speaker-add-icon {
	background: transparent;
	border: 0;
	color: inherit;
	opacity: 0.6;
	cursor: pointer;
	padding: 2px 4px;
	border-radius: 6px;
	font-size: 13px;
	line-height: 1;
	transition: opacity var(--bbs-anim-base, .15s) ease, background-color var(--bbs-anim-base, .15s) ease;
}
.post-speaker-add-icon:hover,
.post-speaker-add-icon:focus-visible {
	opacity: 1;
	background: rgba(255, 255, 255, 0.1);
	outline: none;
}

.bbs-settings-field select,
.bbs-settings-field input[type="text"] {
	background: rgba(80, 80, 80, 0.9);
	border: 0;
	border-radius: 10px;
	color: #e3e3e3;
	padding: 6px 8px;
	font-size: 12px;
}

.post-speaker-list {
	display: flex;
	flex-direction: column;
	gap: 6px;
	min-width: 0;
}

.post-speaker-row {
	display: grid;
	grid-template-columns: auto minmax(0, 1fr) minmax(0, 1fr) auto auto;
	gap: 6px;
	align-items: center;
	min-width: 0;
	width: 100%;
}

.post-speaker-row input {
	background: rgba(80, 80, 80, 0.9);
	border: 0;
	border-radius: 10px;
	color: #e3e3e3;
	padding: 6px 8px;
	font-size: 12px;
	min-width: 0;
	width: 100%;
	box-sizing: border-box;
}

.bbs-settings-panel .speaker-preview {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	object-fit: cover;
	display: block;
	margin: 0 auto;
}

.bbs-settings-panel .speaker-empty {
	opacity: .6;
	font-size: 11px;
	color: #888;
}

.bbs-settings-panel .sp-avatar-wrap {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	border: 1px dashed #e0e0e0;
	background-color: #e0e0e0;
	cursor: pointer;
	overflow: hidden;
}

.bbs-settings-panel .sp-avatar-wrap.has-image {
	border: 0;
}

.bbs-settings-panel .sp-avatar-wrap .speaker-preview {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	margin: 0;
}

.bbs-settings-panel .post-sp-avatar-file {
	display: none;
}

.bbs-settings-panel .sp-avatar-cell {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.bbs-settings-panel .sp-avatar-popover {
	position: absolute;
	left: 50%;
	top: calc(100% + 6px);
	transform: translateX(-50%);
	min-width: 0;
	width: max-content;
	padding: 8px;
	display: none;
	z-index: 50;
	gap: 6px;
	flex-wrap: wrap;
}

.bbs-settings-panel .sp-avatar-url-row {
	display: none;
	gap: 6px;
	margin-top: 6px;
	width: 180px;
}

.bbs-settings-panel .sp-avatar-url-input {
	flex: 1;
	min-width: 0;
}

/* 게시글 화자(설정 패널) 컬러 버튼 기본 크기/형태 */
.bbs-settings-panel .sp-color-btn,
.bbs-settings-panel .sp-color-btn.pcr-button {
	width: 28px !important;
	height: 28px !important;
	min-width: 28px;
	min-height: 28px;
	padding: 0;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	position: relative;
	overflow: hidden;
	flex: 0 0 28px;
}

.bbs-settings-panel .sp-color-btn.sp-color-empty,
.bbs-settings-panel .sp-color-btn.sp-color-empty.pcr-button {
	border: 1px dashed var(--bbs-ui-fg-muted, #c9c9c9);
	background: transparent !important;
}

.bbs-settings-panel .sp-color-empty-icon {
	position: absolute;
	inset: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	pointer-events: none;
}


body.bbs-theme-square #bo_v_con .chat-avatar-img {
	border-radius: 0;
}

body.bbs-theme-square .bbs-settings-panel .sp-avatar-wrap,
body.bbs-theme-square .bbs-settings-panel .sp-avatar-wrap .speaker-preview {
	border-radius: 0;
}

.bbs-square .bbs-settings-panel .sp-avatar-wrap,
.bbs-square .bbs-settings-panel .sp-avatar-wrap .speaker-preview {
	border-radius: 0;
}

.post-sp-del {
	width: 26px;
	height: 26px;
	border: 0;
	border-radius: 8px;
	background: rgba(80, 80, 80, 0.9);
	color: #e3e3e3;
	cursor: pointer;
}

.post-sp-del:hover {
	background: #686868;
}

.bbs-settings-add {
	margin-top: 0;
	border: 0;
	border-radius: 10px;
	background: rgba(80, 80, 80, 0.9);
	color: #e3e3e3;
	padding: 6px 8px;
	font-size: 12px;
	cursor: pointer;
}

.bbs-settings-add:hover {
	background: #686868;
}

.post-speaker-actions {
	display: flex;
	gap: 6px;
	margin-top: 6px;
	width: 100%;
}

.post-speaker-actions .bbs-settings-add,
.post-speaker-actions .bbs-settings-save {
	height: 30px;
	padding: 6px 12px;
	min-width: 0;
	flex: 1;
}

.bbs-settings-save {
	border: 0;
	border-radius: 10px;
	background: #ffb84d;
	color: #111;
	font-size: 12px;
	cursor: pointer;
}

.bbs-settings-save:hover {
	filter: brightness(0.95);
}

.bbs-settings-hint {
	font-size: 10px;
	opacity: 0.7;
}

.board-viewer.theme-fade {
	transition: opacity .2s ease;
}

.board-viewer.theme-fade.theme-fading {
	opacity: 0.4;
}

.bbs-settings-status {
	margin-top: 6px;
	font-size: 11px;
	opacity: 0.8;
}
/* 내용이 비어있을 때는 자리도 차지하지 않게 — 패널 하단 여백 제거. */
.bbs-settings-status:empty {
	display: none;
}

.bbs-settings-status[data-ok="1"] {
	color: #b8f2b8;
}

.bbs-settings-status[data-ok="0"] {
	color: #ffb3b3;
}

.bbs-search-title {
	font-size: 12px;
	letter-spacing: 0.5px;
	margin-bottom: 8px;
	opacity: 0.8;
}

.bbs-search-row {
	display: flex;
	gap: 6px;
	align-items: center;
}

.bbs-search-case {
	display: flex;
	align-items: center;
	gap: 6px;
	margin-top: 6px;
	font-size: 11px;
	opacity: 0.8;
	cursor: pointer;
}

.bbs-search-case input {
	accent-color: #ffb84d;
}

.bbs-search-row input {
	flex: 1;
	min-width: 0;
	background: rgba(80, 80, 80, 0.9);
	border: 0;
	border-radius: 10px;
	color: #e3e3e3;
	padding: 6px 8px;
	font-size: 12px;
}

.bbs-search-row button {
	width: 28px;
	height: 28px;
	border: 0;
	border-radius: 8px;
	background: rgba(80, 80, 80, 0.9);
	color: #e3e3e3;
	cursor: pointer;
}

.bbs-search-row button:hover {
	background: #686868;
}

.bbs-search-count {
	margin-top: 6px;
	font-size: 11px;
	opacity: 0.7;
	text-align: right;
}

.bbs-search-empty {
	margin-top: 4px;
	font-size: 11px;
	opacity: 0.7;
}

.bbs-search-hit {
	background: #ffe08a;
	color: #222;
	padding: 0 2px;
	border-radius: 3px;
}

.bbs-search-hit-current {
	background: #ffb84d;
}

.bbs-backup-overlay {
	position: fixed;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: flex-start;
	background: rgba(0, 0, 0, 0);
	z-index: var(--z-topmost, 2147483647);
	pointer-events: auto;
}

.bbs-backup-panel {
	position: fixed;
	width: 260px;
	max-height: 70vh;
	padding: 12px;
	border-radius: 16px;
	background: rgb(from var(--card-bg-color) r g b / 96%);
	color: var(--content-font-color);
	border: 1px solid rgb(from var(--card-border-color) r g b / 70%);
	box-shadow: var(--shadow-lg, 0 12px 28px rgba(0, 0, 0, 0.3));
}

.bbs-backup-title {
	font-size: 12px;
	letter-spacing: 0.5px;
	margin-bottom: 8px;
	opacity: 0.8;
}

.bbs-backup-listbox {
	display: block;
	overflow-y: auto;
	max-height: calc(70vh - 36px);
	padding: 8px;
	border-radius: 12px;
	background: rgb(from var(--container-bg-color) r g b / 90%);
	padding-right: 4px;
}

.bbs-backup-item {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	position: relative;
	padding: 6px 8px;
	border-radius: 8px;
}

.bbs-backup-item+.bbs-backup-item {
	margin-top: 4px;
}

.bbs-backup-meta {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

.bbs-backup-time {
	display: block;
	font-size: 11px;
	opacity: 0.7;
}

.bbs-backup-listbox a {
	display: block;
	border-radius: 8px;
	color: inherit;
	text-decoration: none;
	font-size: 12px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.bbs-backup-item:hover {
	background: rgb(from var(--btn-secondary-bg) r g b / 45%);
}

.bbs-backup-item a {
	flex: 1;
}

.bbs-backup-diff {
	position: fixed;
	left: 0;
	top: 0;
	width: 260px;
	max-height: 180px;
	overflow: auto;
	padding: 8px;
	border-radius: 10px;
	background: rgba(25, 25, 25, 0.98);
	color: #e6e6e6;
	font-size: 11px;
	line-height: 1.35;
	box-shadow: 0 12px 28px rgba(0, 0, 0, 0.35);
	opacity: 0;
	transform: translateY(-6px);
	pointer-events: none;
	transition: opacity var(--bbs-anim-base, .15s) ease, transform var(--bbs-anim-base, .15s) ease;
	z-index: var(--z-topmost-tooltip, 2147483648);
}

.bbs-backup-diff.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.bbs-backup-diff .diff-line {
	white-space: pre-wrap;
	word-break: break-word;
}

.bbs-backup-diff .diff-add {
	color: #bbf7d0;
}

.bbs-backup-diff .diff-del {
	color: #fecaca;
}

.bbs-backup-diff .diff-empty {
	opacity: .6;
}

.bbs-backup-actions {
	display: inline-flex;
	align-items: center;
	flex-shrink: 0;
	gap: 4px;
}

.bbs-backup-preview-overlay {
	position: fixed;
	inset: 0;
	display: none;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, 0.6);
	z-index: var(--z-topmost, 2147483647);
}

.bbs-backup-preview-panel {
	width: min(720px, 90vw);
	max-height: 80vh;
	background: var(--card-bg-color);
	color: var(--content-font-color);
	border-radius: 12px;
	border: 1px solid rgb(from var(--card-border-color) r g b / 80%);
	box-shadow: var(--shadow-lg, 0 20px 60px rgba(0, 0, 0, .5));
	display: flex;
	flex-direction: column;
	overflow: hidden;
}

.bbs-backup-preview-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 10px 12px;
	background: rgb(from var(--container-bg-color) r g b / 45%);
}

.bbs-backup-preview-close {
	border: 0;
	border-radius: var(--btn-secondary-radius, var(--form-border-radius));
	padding: 4px 8px;
	background: var(--btn-secondary-bg);
	color: var(--btn-secondary-text);
	cursor: pointer;
}

.bbs-backup-preview-body {
	padding: 12px;
	margin: 0;
	font-size: 12px;
	line-height: 1.4;
	white-space: pre-wrap;
	overflow: auto;
	flex: 1;
}

.bbs-backup-preview-actions {
	padding: 10px 12px;
	display: flex;
	justify-content: flex-end;
	gap: 8px;
	background: rgb(from var(--container-bg-color) r g b / 35%);
}

.bbs-backup-preview-apply {
	border: 0;
	border-radius: var(--btn-primary-radius, var(--form-border-radius));
	padding: 6px 10px;
	background: var(--btn-primary-bg);
	color: var(--btn-primary-text);
	cursor: pointer;
}

.bbs-backup-preview,
.bbs-backup-restore,
.bbs-backup-delete {
	width: 28px;
	height: 28px;
	border-radius: var(--btn-secondary-radius, var(--form-border-radius));
	background: var(--btn-secondary-bg);
	color: var(--btn-secondary-text);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.bbs-backup-delete {
	background: var(--btn-accent-bg);
	color: var(--btn-accent-text);
}

.bbs-backup-preview:hover,
.bbs-backup-restore:hover,
.bbs-backup-delete:hover,
.bbs-backup-preview-close:hover,
.bbs-backup-preview-apply:hover {
	filter: brightness(0.94);
}

.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}


.bbs-btn.savebtn {
	display: none;
}

.active .bbs-btn.savebtn,
body.chat-edit-on .bbs-btn.savebtn {
	display: inline-flex;
}

.active .bbs-btn.savebtn.active,
body.chat-edit-on .bbs-btn.savebtn.active {
	color: #e3e3e3;
	background: #686868;
}

.active .bbs-btn.modbtn,
body.chat-edit-on .bbs-btn.modbtn {
	display: none;
}

.con_cont button {
	border: none;
	padding: 5px 10px;
	border-radius: 5px;
	display: inline-block;
	margin-right: 5px;
}

#bo_vc_w {
	display: none;
}

.open_c,
.close_c {
	display: block;
	text-align: center;
	padding: 4px 0px;
	border-radius: 10px;
	margin-top: 20px;
}

.bbs-list-front {
	width: 100%;
	height: 100%;
	background-size: cover;
	top: 0;
	left: 0;
	position: absolute;
	background-position: center center;
	z-index: 1;
	transition-duration: 0.5s;
	border-radius: 5px;
}

.bbs-list-box:hover .bbs-list-front {
	filter: brightness(1.06) saturate(1.06);
}

.bbs-list-back {
	width: 100%;
	height: 100%;
	background-image: linear-gradient(to right, var(--bbs-point, #858585), var(--bbs-point, #858585));
	background-color: var(--bbs-point, #858585);
	background-repeat: no-repeat;
	background-size: cover;
	top: 0;
	left: 0;
	position: absolute;
	background-position: center right;
	border-radius: 5px;
}

.bbs-list-back.is-bg-loaded {
	filter: none;
	opacity: 1;
}

.bbs-list-back[data-bg] {
	background-color: rgba(0, 0, 0, 0.04);
	opacity: 0.9;
	transition: opacity .35s ease;
}

.bbs-highlight {
	display: inline-block;
	padding: 0px 5px;
	line-height: 20px;
	border-radius: 5px;
	margin-right: 5px;
	font-size: 11px;
	width: 10px;
	text-align: center;
}

.bo_notice .info {
	display: none;
}

.bbs-subtitle {
	position: absolute;
	display: block;
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
	transform: rotate3d(1, 0, 0, 180deg);
	backface-visibility: hidden;
	max-width: calc(100% - 250px);
}

.bbs-list-box:hover .bbs-subtitle {
	transform: rotate3d(1, 0, 0, 0deg);
}

/* 구글 시트 바로가기 — 다른 액션 버튼과 동일한 크기/색(중립 컨트롤색), 초록 아이콘. 호버는 빛 스윽+화살표만(떠오름 없음) */
.bbs-gsheet-link {
	position: relative;
	overflow: hidden;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	height: var(--bbs-ui-btn-h);
	padding: 0 13px;
	border-radius: 999px;
	background: var(--bbs-ctrl-bg);
	color: var(--bbs-ui-fg-strong);
	font-weight: var(--bbs-fw-semi, 600);
	font-size: var(--bbs-ui-btn-fz, 0.8rem);
	text-decoration: none;
	white-space: nowrap;
	transition: background .16s ease;
}
.bbs-gsheet-link:hover {
	background: var(--bbs-ctrl-bg-hover);
	color: var(--bbs-ui-fg-strong);
}
/* 호버 시 빛이 한 번 스윽 지나감 */
.bbs-gsheet-link::after {
	content: '';
	position: absolute;
	inset: 0;
	border-radius: inherit;
	background: linear-gradient(120deg, transparent 28%, rgba(255, 255, 255, .28) 50%, transparent 72%);
	transform: translateX(-130%);
	pointer-events: none;
}
.bbs-gsheet-link:hover::after {
	transform: translateX(130%);
	transition: transform .65s ease;
}
/* 구글 시트 그린 아이콘 — 색 유지 (배지 없이 직접) */
.bbs-gsheet-ic {
	position: relative;
	z-index: 1;
	color: #0f9d58;
	font-size: 0.95em;
}
.bbs-gsheet-tx {
	position: relative;
	z-index: 1;
}
.bbs-gsheet-arrow {
	position: relative;
	z-index: 1;
	font-size: 0.68em;
	opacity: .7;
	transition: transform .16s ease;
}
.bbs-gsheet-link:hover .bbs-gsheet-arrow {
	transform: translateX(3px);
}

/* 시트 부제 — 호버 시 CP 옆에 함께 노출 */
/* 시트 검색·필터 (현재 페이지 즉시 필터) */
.bbs-sheet-search {
	position: relative;
	display: flex;
	align-items: center;
	margin: 0 0 12px;
}
.bbs-sheet-search > .fa-magnifying-glass {
	position: absolute;
	left: 15px;
	color: var(--bbs-text3, #9aa0a6);
	font-size: 0.85rem;
	pointer-events: none;
}
.bbs-sheet-search input {
	width: 100%;
	padding: 10px 38px;
	border: 1px solid var(--bbs-base2, #dcdcdc);
	border-radius: 9999px;
	background: var(--bbs-base, #fff);
	color: var(--bbs-text, #333);
	font: inherit;
	font-size: 0.9rem;
}
.bbs-sheet-search input:focus { outline: none; border-color: var(--bbs-point, #4f7cff); }
.bbs-sheet-search-x { position: absolute; right: 14px; cursor: pointer; color: var(--bbs-text3, #9aa0a6); font-size: 0.85rem; line-height: 1; padding: 4px; }

.bbs-sheet-sub {
	opacity: .7;
	font-size: .94em;
}

.bbs-sheet-sub::before {
	content: " — ";
	opacity: .55;
}

.bbs-list-box:hover .bbs-list-subject {
	transform: rotate3d(1, 0, 0, 180deg);
}

.bbs-list-box:hover .fa-music {
	opacity: 0;
}

.bbs-meta-count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 4px;
	min-width: 20px;
	margin-left: 6px;
	padding: 2px 6px;
	border-radius: 999px;
	font-size: 11px;
	line-height: 1;
	background: rgba(0, 0, 0, .08);
	color: inherit;
	/* inline-flex 기본 vertical-align: baseline 이라 padding 만큼 아래로 처져 보임.
	   `middle` 은 x-height 중심 (baseline 위 0.25em) 에 정렬하는데, 한글은 글리프 시각 중심이 그보다 위라
	   칩이 글자 보다 아래로 보임. baseline 위 0.4em 부근으로 끌어올려 한글 시각 중심 맞춤. */
	vertical-align: 0.15em;
}

.bbs-meta-count i {
	font-size: 10px;
	opacity: .85;
	font-family: "Font Awesome 6 Free" !important;
	font-weight: var(--bbs-fw-heavy, 900);
	font-style: normal;
	line-height: 1;
}

.bbs-meta-count span {
	line-height: 1;
}

.bbs-meta-music {
	margin-left: 10px;
	font-size: 11px;
	font-style: normal;
	vertical-align: middle;
}

.bbs-meta-comment {
	background: rgba(0, 0, 0, .1);
}

.bbs-meta-react {
	background: rgba(0, 0, 0, .08);
}

.bbs-reaction-emojis {
	margin-left: 6px;
	font-size: 11px;
	opacity: .8;
	display: inline-flex;
}

.bbs-reaction-emoji {
	margin-right: 4px;
}

.bbs-reaction-emoji:last-child {
	margin-right: 0;
}

.bbs-list-box,
.bbs-list-box .bbs-list-subject,
.bbs-list-box .bbs-subtitle,
.bbs-list-box .info {
	transition: 0.5s;
	transition-timing-function: cubic-bezier(0, 0.79, 0.62, 1.14);
}

.bbs-list-box:hover .ico-cate,
.bbs-list-box:hover .fa-music {
	transition: 0.2s;
}

.changeBackground:before {
	background-image: none !important;
	background-color: none !important;
	background: none !important;
}

.con_message {
	padding: 12px 16px;
	margin: 8px 2px;
	display: flex;
	width: fit-content;
	position: relative;
	max-width: 80%;
	font-size: 14px;
	box-shadow: 0px 0px 3px rgba(0, 0, 0, 0.1);
	border: 1px solid;
	--bubble-radius: 10px;
}

.con_message.first {
	border-radius: var(--bubble-radius) var(--bubble-radius) var(--bubble-radius) 0px;
}

.con_message.second {
	border-radius: var(--bubble-radius) var(--bubble-radius) 0px var(--bubble-radius);
	align-self: flex-end;
}

/* 말풍선 꼬리는 기본/스퀘어/tp에서 숨기고, 그리드 테마에서만 표시 */
#bo_v_con .con_message.first::after,
#bo_v_con .con_message.first:after,
#bo_v_con .con_message.second::after,
#bo_v_con .con_message.second:after {
	display: none;
}

#bo_v_con {
	position: relative;
	display: flex;
	flex-direction: column;
}

/* 말풍선 그림자/외곽이 잘리지 않도록 paint containment를 해제 + flex 레이아웃 */
#bo_v_con .bubble-wrap {
	content-visibility: visible;
	contain: none;
	display: flex;
	align-items: flex-end;
}

.first .con_message_btn {
	right: -45px;
}

.second .con_message_btn {
	left: -60px;
}

.con_message_btn {
	position: absolute;
	width: 40px;
	bottom: 16px;
	display: none;
}

.active .con_message_btn,
body.chat-edit-on .con_message_btn {
	display: flex;
	opacity: 0.7;
}

.con_message:hover .con_message_btn {
	opacity: 1;
}

.con_message_btn .material-icons {
	font-size: 16px;
	border-radius: 100%;
	padding: 1px;
	cursor: pointer;
	background: transparent;
	color: rgba(0, 0, 0, 0.45);
}

.bbs_date_box {
	display: flex;
	padding: 2px 20px;
	border-radius: 12px;
	margin: 0 auto;
	justify-content: center;
}

.con_message_btn.inactive {
	opacity: 0.1 !important;
	pointer-events: none;
}

/* 글자 서식 */
.bbs_bold {
	font-weight: bold;
}

.bbs_italic {
	font-style: italic;
}

.bbs_italic_bold {
	font-weight: bold;
	font-style: italic;
}

.bbs-box .con_cont textarea {
	border-radius: 5px;
	padding: 10px;
	min-height: 80px;
	min-width: 200px;
	margin-bottom: 5px;
}

/* 테마: themes/ 폴더로 분리됨 */

/* 말풍선 이미지 공통 */
.bubble-image {
	display: block;
	max-width: 100%;
	height: auto;
	border-radius: 12px;
}

/* URL만 있는 말풍선을 링크 카드로 표시 */
.bubble-link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: inherit;
	text-decoration: none;
	padding: 4px 8px;
	border-radius: 8px;
	background: rgba(0, 0, 0, 0.06);
	font-size: 0.95em;
	max-width: 100%;
	overflow: hidden;
}
.bubble-link:hover {
	background: rgba(0, 0, 0, 0.12);
	text-decoration: underline;
}
.bubble-link i {
	flex: 0 0 auto;
	opacity: 0.8;
}
.bubble-link-host {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	max-width: 320px;
}

/* 혹시 기존 말풍선 내부 이미지가 튀어나오는 걸 방지 */
.con_cont img {
	max-width: 100%;
	height: auto;
	border-radius: 12px;
}

/* 날짜 구분선 박스 */
/* 시스템 알림 메시지 (삭제·입장·퇴장 등) — 말풍선 밖, 가운데 정렬 라인 */
.chat-system-notice {
	display: flex;
	width: fit-content;
	max-width: 90%;
	margin: 8px auto;
	padding: 5px 12px;
	align-items: center;
	gap: 8px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--bbs-text, #777) 8%, transparent);
	color: color-mix(in srgb, var(--bbs-text, #777) 70%, transparent);
	font-size: 12px;
	line-height: 1.3;
	font-style: italic;
	user-select: none;
}
.chat-system-notice .fa-eye-slash {
	font-size: 10px;
	opacity: 0.7;
}
.chat-system-text {
	font-style: italic;
}
.chat-system-time {
	font-size: 10px;
	opacity: 0.6;
	font-style: normal;
	margin-left: 4px;
}

.date-sep {
	display: block;
	width: fit-content;
	margin: 12px auto;
	padding: 6px 10px;
	border: 1px solid var(--bbs-date-border);
	border-radius: 8px;
	background: var(--bbs-date-bg);
	font-size: 12px;
	/* 글자 작게 */
	line-height: 1.2;
	color: var(--bbs-date-fg);
	text-align: center;
	box-shadow: var(--bbs-date-shadow);
	position: relative;
	background: linear-gradient(180deg, color-mix(in srgb, var(--bbs-date-bg) 88%, white 12%), var(--bbs-date-bg) 20%);

	/* 더 분명하게 보이도록 */
	padding: 7px 12px;
	transition: box-shadow var(--bbs-anim-slow, .25s) ease, transform var(--bbs-anim-slow, .25s) ease;
	transform: translateY(12px);
	opacity: .75;
}

.date-sep.is-jump {
	box-shadow: var(--bbs-date-shadow-jump);
	background: var(--bbs-date-bg);
}


.date-sep.is-sticky {
	position: sticky;
	top: 32px;
	z-index: 30;
	box-shadow: var(--bbs-date-shadow-sticky);
	background: color-mix(in srgb, var(--bbs-date-bg) 95%, transparent);
	transform: translateY(0);
	opacity: 1;
}

.date-sep.is-leaving {
	transform: translateY(-12px);
	opacity: .6;
}

.bbs-theme-grid .date-sep {
	border-radius: 999px;
	padding: 8px 18px;
	background: color-mix(in srgb, var(--bbs-date-bg) 95%, transparent);
	border: 1px solid color-mix(in srgb, var(--bbs-date-border) 85%, transparent);
	box-shadow: var(--bbs-date-shadow-jump);
	text-transform: uppercase;
	font-weight: var(--bbs-fw-semi, 600);
	letter-spacing: .4px;
	color: var(--bbs-date-fg);
}

/* 말풍선+시간 한 줄 래퍼 */
.bubble-wrap {
	display: flex;
	align-items: flex-end;
	gap: 6px;
	margin: 2px 0;
	/* reaction-stack(position:absolute) 의 offsetParent 보장 — heart 좌표를 wrap 기준으로 측정. */
	position: relative;
}

/* 왼쪽 말풍선 라인 */
.bubble-wrap.first {
	justify-content: flex-start;
}

/* 오른쪽 말풍선 라인 */
.bubble-wrap.second {
	justify-content: flex-end;
}

/* 시간 표시 */
.bubble-time {
	font-size: 11px;
	color: var(--bbs-ui-fg-muted);
	white-space: nowrap;
	line-height: 3;
	margin: 0 2px;
	position: relative;
}

/* placeholder 접근 폐기: 시간 없는 글의 하트 위치는 view_reaction.js positionStack 의
   TIME_HEIGHT_EST(33) fallback 으로 처리. placeholder 가 layout 에 영향을 줘서 .second 버블
   우측 공백 / 짧은 버블 하트 위로 박힘 등 부작용 더 큼. */

/* 공통 유틸 — 인라인 style="display:none" 대체. JS toggle 도 .is-hidden 클래스 추가/제거로 통일. */
.is-hidden {
	display: none !important;
}

/* iOS Safari 의 회색 tap 플래시 제거 — 커스텀 :active transform/배경 변화로 피드백 제공하므로
   기본 하이라이트는 시각적으로 거슬림. */
.board-viewer a,
.board-viewer button,
.board-viewer [role="button"],
.bbs-list a,
.bbs-list button,
.bbs-btn,
.bbs-cat-btn,
.bbs-filter-btn,
.bbs-quick-btn,
.bbs-tag,
.reaction-btn,
.reaction-fab {
	-webkit-tap-highlight-color: transparent;
}

/* 정렬: 오른쪽 말풍선이면 시간→말풍선, 왼쪽 말풍선이면 말풍선→시간 */
.bubble-wrap.second .bubble-time {
	order: 0;
}

/* 시간 왼쪽 */
.bubble-wrap.second .con_message {
	order: 1;
}

.bubble-wrap.first .con_message {
	order: 0;
}

/* 시간 오른쪽 */
.bubble-wrap.first .bubble-time {
	order: 1;
}

/* 연속 화자: 꼬리 제거 + 간격 축소 */
.bubble-wrap.repeat-speaker {
	margin-top: 0;
}

.bubble-wrap.repeat-speaker .con_message {
	border-radius: var(--bubble-radius) !important;
}

.bubble-wrap.repeat-speaker .con_message:after {
	display: none !important;
}

#chat-toc {
	position: fixed;
	right: 18px;
	top: 50%;
	transform: translateY(-50%);
	display: flex;
	flex-direction: column;
	gap: 10px;
	z-index: var(--z-chat-toc, 2000);
	pointer-events: auto;
	align-items: flex-start;
}

@keyframes pulseDotHover {
	0% {
		box-shadow: var(--p-color-charaname, var(--bbs-point, #4a8cff)) 0 0 0 0;
	}

	75% {
		box-shadow: transparent 0 0 0 12px;
	}
}

#chat-toc .toc-dot {
	--chat-dot: 12px;
	position: relative;
	width: var(--chat-dot);
	height: var(--chat-dot);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: none;
	border-radius: 50%;
	background: transparent;
	cursor: pointer;
	padding: 0;
	pointer-events: auto;
	outline: none;
	box-shadow: none;
}

#chat-toc .toc-dot::before {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: 50%;
	background: var(--bbs-toc-dot-bg);
	border: 1px solid var(--bbs-toc-dot-bg);
	transform-origin: center center;
	will-change: box-shadow;
	transition: box-shadow var(--bbs-anim-base, .15s) ease, border-color var(--bbs-anim-base, .15s) ease, background var(--bbs-anim-base, .15s) ease;
}

#chat-toc .toc-dot::after {
	content: attr(aria-label);
	position: absolute;
	left: calc(100% + 6px);
	top: 50%;
	transform: translateY(-50%);
	white-space: nowrap;
	padding: 4px 8px;
	border-radius: 6px;
	background: var(--bbs-toc-tooltip-bg);
	color: var(--bbs-toc-tooltip-fg);
	font-size: 12px;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	box-shadow: var(--bbs-ui-shadow);
}

#chat-toc .toc-dot[data-has-url="1"]::before,
#chat-toc .toc-dot.active::before {
	background: var(--p-color-charaname, var(--bbs-point, #4a8cff));
	border-color: var(--p-color-charaname, var(--bbs-point, #4a8cff));
}

#chat-toc .toc-dot:hover::before,
#chat-toc .toc-dot:focus-visible::before,
#chat-toc .toc-dot:active::before {
	animation: pulseDotHover 1s cubic-bezier(.25, .1, .25, 1) infinite;
	background: var(--p-color-charaname, var(--bbs-point, #4a8cff));
	border-color: var(--p-color-charaname, var(--bbs-point, #4a8cff));
}

#chat-toc .toc-dot:hover::after,
#chat-toc .toc-dot:focus-visible::after,
#chat-toc .toc-dot:active::after {
	opacity: 1;
	visibility: visible;
}

@media (max-width: 1000px) {
	html,
	body {
		width: 100%;
		max-width: 100%;
		overflow-x: hidden;
	}
	.fix-layout {
		padding: 0;
		width: 100% !important;
	}

	#chat-toc {
		right: 10px;
		gap: 8px;
	}

	#chat-date-indicator {
		right: 10px;
	}

	/* 모바일: 뷰 UI 최적화 */
	#bo_v {
		--view-mg: 0;
	}

	#pair_view_content {
		margin: 0;
		padding: 10px;
		/* iOS Safari URL 바 변화에 따라 100vh 가 잘리는 문제 — dvh 로 교체. */
		height: 100dvh;
		min-height: 0;
		border-radius: 0;
		background: transparent !important;
		box-shadow: none !important;
	}

	#bo_v,
	#bo_v_con {
		width: 100vw;
		max-width: 100vw;
		overflow-x: hidden;
	}

	#pair_view_content .board-content {
		padding: 8px 10px;
	}

	.board-viewer,
	.board-viewer.bbs-box,
	.bbs-box {
		width: 100%;
		margin: 0 !important;
		border-radius: 0;
		background: transparent !important;
		box-shadow: none !important;
		padding: 0;
	}

	.board-viewer {
		max-width: 100% !important;
		width: 100% !important;
	}

	#bo_v_con .bubble-wrap.first {
		justify-content: flex-start;
		padding-left: 4px;
	}

	#bo_v_con .bubble-wrap.second {
		justify-content: flex-end;
		padding-right: 4px;
	}

	#bo_v_con .chat-profile-left {
		margin-right: 4px;
	}

	#bo_v_con .chat-profile-right {
		margin-left: 4px;
	}

	#bo_v_con .chat-avatar-img {
		width: 24px;
		height: 24px;
	}

	#bo_v_con .chat-profile {
		font-size: 10px;
	}

	#bo_v_con .chat-nickname {
		max-width: 54px;
		font-size: 11px;
	}

	#bo_v_con .con_message.first,
	#bo_v_con .con_message.second {
		max-width: calc(100% - 40px);
	}

	#bo_v_con .bubble-wrap {
		gap: 6px;
		align-items: flex-end;
	}

	.bbs-grid #bo_v_con .bubble-wrap.second {
		padding-right: 0;
	}

	#bo_v_con .bubble-time {
		font-size: 10px;
		opacity: .7;
	}

	.bbs-btn-header {
		/* 모바일: fixed로 viewport 좌측 8px */
		position: fixed !important;
		translate: 0 0 !important;
		left: 8px !important;
		top: calc(8px + env(safe-area-inset-top, 0px)) !important;
		bottom: auto !important;
		right: auto !important;
		margin-right: 0 !important;
		transform: none !important;
		flex-direction: column;
		align-items: flex-start;
		gap: 8px;
		z-index: var(--z-floating-header, 3000);
	}

	.bbs-btn {
		width: 34px;
		height: 34px;
		margin: 0;
	}

	#chat-toc {
		display: none !important;
	}

	#chat-toc .toc-dot::after {
		display: none !important;
	}

	#goto_top {
		display: none !important;
	}

	#bo_v_bot {
		display: none !important;
	}

	.bbs-btn-header .bbs-btn:not(.bbs-btn-toggle) {
		display: none;
		opacity: 0;
		pointer-events: none;
		transform: translateY(6px);
		transition: opacity .2s ease, transform .2s ease;
	}

	.bbs-btn-header.is-open .bbs-btn:not(.bbs-btn-toggle) {
		display: inline-flex;
		opacity: 1;
		pointer-events: auto;
		transform: translateY(0);
	}

	.bbs-btn-toggle {
		display: inline-flex;
		order: 0;
		background: var(--bbs-point);
		color: #fff;
		opacity: 1;
		pointer-events: auto;
	}

}

@media (max-width: 1000px) and (min-width: 701px) {
	#chat-toc {
		display: flex !important;
	}
}

.bubble-insert-slot {
	position: relative;
	height: 0;
	margin: 0;
	pointer-events: none;
}

/* --- 말풍선 사이 삽입 슬롯 UI는 비활성 --- */
.bubble-insert-slot,
body.chat-edit-on .bubble-insert-slot {
	display: none !important;
}

/* 간단 모달 스타일 (기존 JS가 id로 만들어요) */
#chat-insert-modal-backdrop {
	position: fixed;
	inset: 0;
	background: var(--bbs-overlay-bg);
	display: none;
	z-index: var(--z-chat-insert-backdrop, 9998);
}

#chat-insert-modal {
	position: fixed;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	display: none;
	z-index: var(--z-chat-insert, 9999);
	background: var(--bbs-modal-bg);
	color: var(--bbs-modal-fg);
	border-radius: 12px;
	width: min(420px, 92vw);
	padding: 16px;
	box-shadow: var(--bbs-date-shadow-jump);
}

#chat-insert-modal header {
	font-weight: var(--bbs-fw-bold, 700);
	margin-bottom: 10px;
}

#chat-insert-modal .row {
	margin: 8px 0;
	color: var(--p-color-sub, currentColor);
}

#chat-insert-modal textarea {
	width: 100%;
	min-height: 120px;
}

#chat-insert-modal .actions {
	display: flex;
	gap: 8px;
	justify-content: flex-end;
	margin-top: 10px;
}

#chat-insert-modal .btn-ghost {
	padding: 8px 12px;
	border: 1px solid var(--bbs-modal-border);
	border-radius: 8px;
	background: var(--bbs-modal-btn-ghost-bg);
	color: var(--bbs-modal-fg);
}

#chat-insert-modal .btn-primary {
	padding: 8px 12px;
	border-radius: 8px;
	border: 1px solid var(--bbs-ui-accent-bg);
	background: var(--bbs-ui-accent-bg);
	color: var(--bbs-ui-accent-fg);
}

/* 날짜 + 미완 라벨 줄을 한 줄로 딱 붙게 */
.bbs-list .bbs-list-box .info {
	display: flex;
	align-items: center;
	/* 세로 가운데 정렬 */
	gap: 6px;
	/* 날짜와 미완 사이 간격 */
}

/* 기본 상태: 미완 태그는 살짝 납작하게 */
/* 미완 뱃지 — `.info` pill 안에 들어가는 작은 칩.
   배경 투명 + 색은 `<a>` 링크에서 상속(=라공 테마 링크 색). 부모 `.info` 의 0.5s transition 이 색을 보간하면
   "파랗게→회색" 깜빡임이 되므로 transition 만 차단. */
.bbs-list .info .bbs-tag-incomplete {
	padding: 0 6px;
	margin-right: 2px;
	line-height: 1.2;
	font-size: 10px;
	height: auto;
	min-height: 0;
	background: transparent;
	color: inherit;
	border: 0;
	border-radius: 3px;
	transition: none;
}

/* === 카톡식 프로필 + 닉네임 =================================== */

#bo_v_con .chat-profile {
	display: flex;
	flex-direction: column;
	align-items: center;
	font-size: 11px;
	color: rgba(0, 0, 0, 0.7);
}

#bo_v_con .chat-profile-left {
	margin-right: 6px;
}

#bo_v_con .chat-profile-right {
	margin-left: 6px;
}

#bo_v_con .chat-avatar-img {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	object-fit: cover;
	margin-bottom: 2px;
}

#bo_v_con .chat-nickname {
	max-width: 72px;
	text-align: center;
	word-break: keep-all;
	color: var(--title-font-color);
}

#bo_v_con .con_message.first,
#bo_v_con .con_message.second {
	max-width: calc(100% - 64px);
}

/* === 카톡식 프로필 + 정렬 보정 ======================= */

/* 기본 flex 세팅 */
#bo_v_con .bubble-wrap.first,
#bo_v_con .bubble-wrap.second {
	display: flex;
	align-items: flex-end;
	flex-direction: row;
	/* 혹시 기존에 row-reverse 걸려 있어도 여기서 강제 */
}

/* --- 왼쪽 말풍선(first): [프로필][말풍선][시간] 순 --- */
#bo_v_con .bubble-wrap.first {
	justify-content: flex-start;
}

#bo_v_con .bubble-wrap.first .chat-profile-left {
	order: 0;
	/* 맨 왼쪽 */
}

#bo_v_con .bubble-wrap.first .con_message.first {
	order: 1;
}

#bo_v_con .bubble-wrap.first .bubble-time {
	order: 2;
	margin-left: 2px;
}

/* --- 오른쪽 말풍선(second): [말풍선][프로필][시간] 순 --- */
#bo_v_con .bubble-wrap.second {
	justify-content: flex-end;
}

#bo_v_con .bubble-wrap.second .con_message.second {
	order: 0;
	/* 가장 왼쪽(오른쪽 정렬 기준에서 맨 앞 = 버블) */
}

#bo_v_con .bubble-wrap.second .chat-profile-right {
	order: 1;
	/* 버블 오른쪽에 딱 붙음 */
	margin-left: 6px;
	/* 살짝 간격 */
}

#bo_v_con .bubble-wrap.second .bubble-time {
	order: 2;
	margin-right: 2px;
	/* 프로필 오른쪽에 시간 */
}


/* Avatar placeholder when no profile image is set */
#bo_v_con .chat-avatar-img.avatar-placeholder {
	width: 32px;
	height: 32px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #eee;
	color: #6b7280;
	/* gray-500 */
	border: 2px dotted #9ca3af;
	/* gray-400 */
	border-radius: 50%;
	margin-bottom: 2px;
	font-weight: var(--bbs-fw-bold, 700);
	font-size: 16px;
	line-height: 1;
	display: flex !important;
}

#bo_v_con .chat-avatar-img.avatar-placeholder::before {
	content: "?";
}

/* 아바타가 말풍선 길이에 의해 찌그러지지 않게 고정 */
#bo_v_con .chat-avatar-img,
#bo_v_con .chat-avatar-img.avatar-placeholder {
	width: 32px;
	height: 32px;
	min-width: 32px;
	/* 핵심: flex에서 가로 최소값 고정 */
	flex: 0 0 32px;
	/* 핵심: grow 0, shrink 0, basis 32px */
	aspect-ratio: 1 / 1;
	/* 안전장치: 항상 정사각 */
}

/* 실제 이미지가 늘어나지 않게 */
#bo_v_con img.chat-avatar-img {
	display: block;
	object-fit: cover;
	-webkit-user-drag: none;
	user-select: none;
	pointer-events: none;
}

/* ---------- Unified UI Layer ---------- */
:root {
	--bbs-ui-radius: 10px;
	--bbs-ui-radius-pill: 999px;
	--bbs-ui-btn-h: 30px;
	--bbs-ui-btn-fz: 12px;
	--bbs-ui-fg: var(--content-font-color, var(--bbs-text, #e8e8e8));
	--bbs-ui-fg-strong: var(--content-font-color, var(--bbs-text, #ffffff));
	--bbs-ui-fg-muted: color-mix(in srgb, var(--content-font-color, var(--bbs-text, #ffffff)) 62%, transparent);
	--bbs-ui-bg: color-mix(in srgb, var(--container-bg-color, #3a3a3a) 88%, transparent);
	--bbs-ui-bg-hover: color-mix(in srgb, var(--container-bg-color, #3a3a3a) 70%, var(--accent-color, #137bea) 30%);
	--bbs-ui-border: 1px solid color-mix(in srgb, var(--container-border-color, #ffffff) 45%, transparent);
	--bbs-ui-accent-bg: var(--accent-color, var(--bbs-point, #ffb84d));
	--bbs-ui-accent-fg: var(--btn-accent-text, var(--content-font-color, #111));
	--bbs-ctrl-bg: color-mix(in srgb, var(--card-bg-color, #111827) 85%, transparent);
	--bbs-ctrl-bg-hover: color-mix(in srgb, var(--card-bg-color, #111827) 65%, var(--accent-color, #137bea) 35%);
	--bbs-ctrl-border: 1px solid color-mix(in srgb, var(--container-border-color, #ffffff) 55%, transparent);
	--bbs-panel-bg: color-mix(in srgb, var(--card-bg-color, #3c3c3c) 96%, transparent);
	--bbs-field-bg: color-mix(in srgb, var(--container-bg-color, #3a3a3a) 88%, transparent);
	--bbs-ui-shadow: 0 12px 28px color-mix(in srgb, var(--container-border-color, #000) 30%, transparent);
	--bbs-focus-outline: 2px solid color-mix(in srgb, var(--accent-color, #ffcc6e) 88%, white 12%);
	--bbs-date-bg: color-mix(in srgb, var(--card-bg-color, #ffffff) 94%, white 6%);
	--bbs-date-fg: var(--content-font-color, #333);
	--bbs-date-border: color-mix(in srgb, var(--container-border-color, #000) 35%, transparent);
	--bbs-date-shadow: 0 1px 2px color-mix(in srgb, var(--container-border-color, #000) 12%, transparent);
	--bbs-date-shadow-sticky: 0 10px 24px color-mix(in srgb, var(--container-border-color, #000) 20%, transparent);
	--bbs-date-shadow-jump: 0 14px 30px color-mix(in srgb, var(--container-border-color, #000) 26%, transparent);
	--bbs-toc-dot-bg: color-mix(in srgb, var(--card-bg-color, #000) 35%, transparent);
	--bbs-toc-tooltip-bg: color-mix(in srgb, var(--card-bg-color, #0f172a) 92%, black 8%);
	--bbs-toc-tooltip-fg: var(--content-font-color, #fff);
	--bbs-overlay-bg: color-mix(in srgb, var(--container-border-color, #000) 35%, transparent);
	--bbs-modal-bg: color-mix(in srgb, var(--card-bg-color, #fff) 96%, white 4%);
	--bbs-modal-fg: var(--content-font-color, #111);
	--bbs-modal-border: color-mix(in srgb, var(--container-border-color, #000) 18%, transparent);
	--bbs-modal-btn-ghost-bg: color-mix(in srgb, var(--card-bg-color, #f8fafc) 92%, white 8%);
	--bbs-modal-muted-fg: color-mix(in srgb, var(--bbs-modal-fg) 60%, transparent);
	--bbs-modal-row-bg: color-mix(in srgb, var(--card-bg-color, #fff) 88%, transparent);
	--bbs-modal-row-bg-hover: color-mix(in srgb, var(--card-bg-color, #fff) 95%, transparent);

	/* split/export 색상 — Google blue 하드코딩 대체. accent 기반으로 일관성 유지. */
	--split-accent: var(--accent-color, var(--bbs-point, #1a73e8));
	--split-upper: color-mix(in srgb, var(--split-accent) 56%, #34a853 44%);
	--split-lower: color-mix(in srgb, var(--split-accent) 50%, #fbbc04 50%);
	--split-overlap: #f29900;

	/* diff line 색상 — Material-light 하드코딩 대체. */
	--diff-bg-add: color-mix(in srgb, #34a853 14%, var(--bbs-modal-bg) 86%);
	--diff-bg-del: color-mix(in srgb, #ea4335 14%, var(--bbs-modal-bg) 86%);
	--diff-fg-add: color-mix(in srgb, #1b5e20 80%, var(--bbs-modal-fg));
	--diff-fg-del: color-mix(in srgb, #b71c1c 80%, var(--bbs-modal-fg));
	--diff-dot-match: color-mix(in srgb, var(--bbs-modal-fg) 22%, transparent);
	--diff-dot-add: color-mix(in srgb, #34a853 70%, transparent);
	--diff-dot-del: color-mix(in srgb, #ea4335 70%, transparent);

	/* z-index 토큰 — 모달 layering 일관성. */
	--z-modal-base: 10000;
	--z-modal-stacked: 10100;
	--z-modal-foreground: 10200;
	/* reaction 모듈 z-index 토큰 — backdrop 은 picker-host stacking 컨텍스트 내부에서 picker 보다 낮게.
	   picker-host (20) 는 다른 wrap (z-auto) 보다 위에 있어야 picker 가 다른 메시지에 가려지지 않음. */
	--z-reaction-backdrop: 1;
	--z-reaction-tooltip: 4;
	--z-reaction-stack: 6;
	--z-reaction-picker: 10;
	--z-reaction-picker-host: 20;
	--z-reaction-picker-mobile: 4000;
	/* 채팅 UI 보조 요소 z-index. */
	--z-chat-toc: 2000;
	--z-floating-header: 3000;
	/* chat-insert-modal — 본문 안 삽입 슬롯 모달 (mod--modal-base 미만에서 자체 backdrop+modal). */
	--z-chat-insert-backdrop: 9998;
	--z-chat-insert: 9999;
	/* 최상단 floating UI — 라공 테마/3자 위젯/모달 위에 무조건 떠야 하는 패널. INT_MAX 사용. */
	--z-topmost: 2147483647;
	--z-topmost-tooltip: 2147483648;
	/* 애니메이션 duration — 역할별 정의. 추가 outlier 값 (.18s/.2s/.3s/.35s 등) 은 raw 유지. */
	--bbs-anim-fast: .12s;
	--bbs-anim-base: .15s;
	--bbs-anim-slow: .25s;
	/* font-weight — 역할별 정의. */
	--bbs-fw-semi: 600;
	--bbs-fw-bold: 700;
	--bbs-fw-heavy: 900;
}

/* ============ 공용 토스트 ============
   bbsToast() 가 main 모듈 (view_split_export 등) 에서 호출. 비차단 알림 — alert 대체.
   list_orphan_backups 의 orphan-toast 와 동일 구조이나, view 페이지용 별도 컨테이너. */
#bbs-toast-container {
	position: fixed;
	bottom: 20px;
	right: 20px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	z-index: calc(var(--z-modal-foreground, 10200) + 100);
	pointer-events: none;
	max-width: calc(100vw - 40px);
}
.bbs-toast {
	pointer-events: auto;
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 12px 14px;
	border-radius: 10px;
	background: var(--bbs-modal-bg, #1f2937);
	color: var(--bbs-modal-fg, #f5f5f5);
	border: 1px solid var(--bbs-modal-border, transparent);
	box-shadow: 0 14px 36px rgba(0, 0, 0, 0.32);
	font-size: 13px;
	line-height: 1.4;
	animation: bbs-toast-in 0.18s ease-out;
}
.bbs-toast.is-error {
	border-color: var(--diff-fg-del, #c62828);
}
.bbs-toast-msg { flex: 1; min-width: 0; }
.bbs-toast-close {
	background: none;
	border: 0;
	color: inherit;
	opacity: 0.7;
	cursor: pointer;
	padding: 2px 6px;
	font-size: 14px;
}
.bbs-toast-close:hover { opacity: 1; }

/* 공용 모달 backdrop 베이스 — orphan/split/speaker 등 다양한 모달이 공유.
   z-index 레이어는 추가 클래스 (.is-base/.is-stacked/.is-foreground) 또는 직접 override. */
.bbs-modal-backdrop {
	position: fixed;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 20px;
	background: var(--bbs-overlay-bg, rgba(0, 0, 0, 0.45));
	z-index: var(--z-modal-base, 10000);
}
.bbs-modal-backdrop.is-stacked { z-index: var(--z-modal-stacked, 10100); }
.bbs-modal-backdrop.is-foreground { z-index: var(--z-modal-foreground, 10200); }

.bbs-toast-link {
	color: var(--write-accent, var(--accent-color, #6ea8ff));
	font-weight: var(--bbs-fw-semi, 600);
	text-decoration: none;
	white-space: nowrap;
}
.bbs-toast-link:hover { text-decoration: underline; }
@keyframes bbs-toast-in {
	from { transform: translateY(8px); opacity: 0; }
	to { transform: translateY(0); opacity: 1; }
}
@media (max-width: 600px) {
	#bbs-toast-container {
		left: 12px;
		right: 12px;
		bottom: 12px;
	}
}

.bbs-search-panel,
.bbs-settings-panel,
.bbs-thumb-popover,
.bbs-bg-popover,
.bbs-settings-panel .sp-avatar-popover {
	background: var(--bbs-panel-bg);
	color: var(--bbs-ui-fg);
	border: var(--bbs-ui-border);
	border-radius: 14px;
	box-shadow: var(--bbs-ui-shadow);
}

.bbs-btn,
.bbs-search-row button,
.bbs-settings-add,
.bbs-settings-save,
.post-sp-del,
.bbs-thumb-popover button,
.bbs-bg-popover button,
.bbs-settings-panel .sp-avatar-popover button {
	height: var(--bbs-ui-btn-h);
	border-radius: var(--bbs-ui-radius);
	border: var(--bbs-ui-border);
	background: var(--bbs-ui-bg);
	color: var(--bbs-ui-fg);
	font-size: var(--bbs-ui-btn-fz);
	font-weight: var(--bbs-fw-semi, 600);
	line-height: 1;
	transition: background-color var(--bbs-anim-base, .15s) ease, color var(--bbs-anim-base, .15s) ease, border-color var(--bbs-anim-base, .15s) ease, transform var(--bbs-anim-fast, .12s) ease;
}

/* .bbs-cat-btn 만 pill (icon 원형 버튼). filter/quick 류는 위 단일 룰에서 둥근 사각형. */
.bbs-cat-btn {
	border-radius: var(--bbs-ui-radius-pill);
}

.bbs-btn:hover,
.bbs-cat-btn:hover,
.bbs-filter-btn:hover,
.bbs-quick-btn:hover,
.bbs-quick-clear:hover,
.bbs-search-row button:hover,
.bbs-settings-add:hover,
.bbs-settings-save:hover,
.post-sp-del:hover,
.bbs-thumb-popover button:hover,
.bbs-bg-popover button:hover,
.bbs-settings-panel .sp-avatar-popover button:hover {
	background: var(--bbs-ui-bg-hover);
	color: var(--bbs-ui-fg-strong);
	border-color: color-mix(in srgb, var(--container-border-color, #fff) 55%, transparent);
}

.bbs-btn:active,
.bbs-cat-btn:active,
.bbs-filter-btn:active,
.bbs-quick-btn:active,
.bbs-quick-clear:active,
.bbs-search-row button:active,
.bbs-settings-add:active,
.bbs-settings-save:active,
.post-sp-del:active {
	transform: translateY(1px);
}

.bbs-btn:focus-visible,
.bbs-cat-btn:focus-visible,
.bbs-filter-btn:focus-visible,
.bbs-quick-btn:focus-visible,
.bbs-quick-clear:focus-visible,
.bbs-search-row button:focus-visible,
.bbs-settings-add:focus-visible,
.bbs-settings-save:focus-visible,
.post-sp-del:focus-visible,
.bbs-thumb-popover button:focus-visible,
.bbs-bg-popover button:focus-visible,
.bbs-settings-panel .sp-avatar-popover button:focus-visible {
	outline: var(--bbs-focus-outline);
	outline-offset: 2px;
}

.bbs-settings-panel .sp-avatar-popover .sp-avatar-upload,
.bbs-settings-panel .sp-avatar-popover .sp-avatar-url-btn {
	background: var(--btn-accent-bg);
	color: var(--btn-accent-text);
	border: 0;
	border-radius: var(--btn-accent-radius, var(--form-border-radius));
	padding-left: 10px;
	padding-right: 10px;
}

.bbs-settings-panel .sp-avatar-popover .sp-avatar-upload:hover,
.bbs-settings-panel .sp-avatar-popover .sp-avatar-url-btn:hover {
	filter: brightness(0.92);
}

.bbs-settings-panel .sp-avatar-popover .sp-avatar-clear {
	background: var(--btn-accent-bg);
	color: var(--btn-accent-text);
	border: 0;
	border-radius: var(--btn-accent-radius, var(--form-border-radius));
	padding-left: 10px;
	padding-right: 10px;
}

.bbs-settings-panel .sp-avatar-popover .sp-avatar-clear:hover {
	filter: brightness(0.92);
}

.bbs-settings-panel .sp-avatar-popover .sp-avatar-url-apply {
	background: var(--btn-primary-bg);
	color: var(--btn-primary-text);
	border: 0;
	border-radius: var(--btn-primary-radius, var(--form-border-radius));
	padding-left: 10px;
	padding-right: 10px;
}

.bbs-settings-save,
.bbs-btn.incompletebtn.active,
.bbs-btn.favoritebtn.active {
	background: var(--bbs-ui-accent-bg);
	color: var(--bbs-ui-accent-fg);
	border-color: transparent;
}

.bbs-filter-btn.active,
.bbs-quick-btn.active {
	background: var(--bbs-ctrl-bg-hover);
	color: var(--bbs-ui-fg-strong);
	border-color: color-mix(in srgb, var(--container-border-color, #fff) 58%, transparent);
	box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--container-border-color, #fff) 42%, transparent);
}

.bbs-search-row input,
.bbs-settings-field select,
.bbs-settings-field input[type="text"],
.post-speaker-row input,
.bbs-settings-panel .sp-avatar-url-input,
.bbs-thumb-url-row input[type="text"],
.bbs-bg-url-row input[type="text"] {
	border: var(--bbs-ui-border);
	border-radius: var(--bbs-ui-radius);
	background: var(--bbs-field-bg);
	color: var(--bbs-ui-fg);
}

/* List Controls Tone */
.bbs-category-actions .bbs-cat-btn {
	width: var(--bbs-ui-btn-h);
	min-width: var(--bbs-ui-btn-h);
	height: var(--bbs-ui-btn-h);
	min-height: var(--bbs-ui-btn-h);
	padding: 0 !important;
	border-radius: 999px !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	line-height: 1;
	white-space: nowrap;
	margin-top: 0 !important;
	text-decoration: none;
}

.bbs-cat-btn,
.bbs-filter-btn,
.bbs-quick-btn,
.bbs-quick-clear,
#bo_sch form[name="fsearch"] button,
#bbs_pages .pg_page,
#bbs_pages .pg_current,
#bbs_pages .pg_start,
#bbs_pages .pg_prev,
#bbs_pages .pg_next,
#bbs_pages .pg_end,
.bbs-pages .pg_page,
.bbs-pages .pg_current,
.bbs-pages .pg_start,
.bbs-pages .pg_prev,
.bbs-pages .pg_next,
.bbs-pages .pg_end {
	background: var(--bbs-ctrl-bg);
	color: var(--bbs-ui-fg-strong);
}

.bbs-cat-btn:hover,
.bbs-filter-btn:hover,
.bbs-quick-btn:hover,
.bbs-quick-clear:hover,
#bo_sch form[name="fsearch"] button:hover,
#bbs_pages .pg_page:hover,
#bbs_pages .pg_start:hover,
#bbs_pages .pg_prev:hover,
#bbs_pages .pg_next:hover,
#bbs_pages .pg_end:hover,
.bbs-pages .pg_page:hover,
.bbs-pages .pg_start:hover,
.bbs-pages .pg_prev:hover,
.bbs-pages .pg_next:hover,
.bbs-pages .pg_end:hover {
	background: var(--bbs-ctrl-bg-hover);
	color: var(--bbs-ui-fg-strong);
}

.bbs-sort-select {
	height: var(--bbs-ui-btn-h);
	background: var(--bbs-ctrl-bg);
	color: var(--bbs-ui-fg-strong);
	border: var(--bbs-ctrl-border) !important;
	font-size: var(--bbs-ui-btn-fz);
	font-weight: var(--bbs-fw-semi, 600);
}

.board-category .tw-select {
	min-width: 120px;
	width: clamp(120px, 18vw, 180px);
}

.board-category .tw-select>button {
	width: 100% !important;
	min-width: 120px !important;
	height: var(--bbs-ui-btn-h) !important;
	border-radius: 0.5rem !important;
	background: var(--bbs-ctrl-bg) !important;
	color: var(--bbs-ui-fg-strong) !important;
	padding: 0 2rem 0 0.75rem !important;
}

.board-category .tw-select>button .tw-truncate,
.board-category .tw-select>button span {
	color: var(--bbs-ui-fg-strong) !important;
}

.board-category .tw-select>span {
	color: var(--bbs-ui-fg-muted) !important;
}

.board-category select,
.board-category #sca {
	height: var(--bbs-ui-btn-h);
	min-width: 92px;
	width: clamp(92px, 12vw, 132px);
	background: var(--bbs-ctrl-bg);
	color: var(--bbs-ui-fg-strong);
	border: var(--bbs-ctrl-border) !important;
	border-radius: 0.5rem;
	font-size: var(--bbs-ui-btn-fz);
	font-weight: var(--bbs-fw-semi, 600);
	padding: 0 2rem 0 0.75rem;
	line-height: 1;
	appearance: none;
	-webkit-appearance: none;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' fill='none' stroke='%23475569' stroke-width='1.1' stroke-linecap='round' stroke-linejoin='round'/></svg>");
	background-repeat: no-repeat;
	background-position: right 0.65rem center;
	background-size: 10px 6px;
}

.board-category select:hover,
.board-category #sca:hover,
.board-category select:focus,
.board-category #sca:focus {
	background-color: var(--bbs-ctrl-bg-hover);
	color: var(--bbs-ui-fg-strong);
}

/* .bbs-filter 스코프 칩 모양/배경/hover 룰은 베이스 (.bbs-filter-btn, .bbs-quick-btn, .bbs-quick-clear, .bo_fx > .bbs-list-back-btn) 단일 룰로 통합 — 여기서 제거.
   .bbs-filter .tw-select>button (select dropdown) 만 라공 tw-select 기본 디자인 덮어쓰기로 유지. */
.bbs-filter .tw-select>button {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: auto !important;
	min-width: 88px !important;
	height: var(--bbs-ui-btn-h) !important;
	padding: 0 2rem 0 0.75rem !important;
	border-radius: var(--bbs-ui-radius, 10px) !important;
	background: var(--bbs-ctrl-bg) !important;
	color: var(--bbs-ui-fg-strong) !important;
	font-size: var(--bbs-ui-btn-fz) !important;
	font-weight: var(--bbs-fw-semi, 600) !important;
	line-height: normal !important;
	white-space: nowrap !important;
	box-shadow: none !important;
	margin-top: 0 !important;
	transition: background var(--bbs-anim-base, .15s) ease, color var(--bbs-anim-base, .15s) ease, border-color var(--bbs-anim-base, .15s) ease !important;
}

.bbs-filter .tw-select>button:hover {
	background: var(--bbs-ctrl-bg-hover) !important;
	color: var(--bbs-ui-fg-strong) !important;
}

.bbs-filter .tw-select>button .tw-truncate,
.bbs-filter .tw-select>button span {
	color: var(--bbs-ui-fg-strong) !important;
}

.bbs-filter .tw-select>span {
	color: var(--bbs-ui-fg-muted) !important;
}

#bo_sch {
	margin-top: 10px;
	text-align: center;
}

#bo_sch form[name="fsearch"] {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	flex-wrap: wrap;
}

#bo_sch form[name="fsearch"] #sfl,
#bo_sch form[name="fsearch"] #stx {
	height: var(--bbs-ui-btn-h);
	background: var(--bbs-field-bg);
	color: var(--bbs-ui-fg);
	border: var(--bbs-ui-border);
	padding: 0 10px;
	font-size: var(--bbs-ui-btn-fz);
	font-weight: var(--bbs-fw-semi, 600);
}

#bo_sch form[name="fsearch"] button {
	height: var(--bbs-ui-btn-h);
	padding: 0 12px;
	background: var(--bbs-ctrl-bg);
	color: var(--bbs-ui-fg-strong);
	font-size: var(--bbs-ui-btn-fz);
	font-weight: var(--bbs-fw-semi, 600);
}

#bo_sch form[name="fsearch"] button:hover {
	background: var(--bbs-ctrl-bg-hover);
	color: var(--bbs-ui-fg-strong);
}

#bbs_pages,
.bbs-pages {
	margin-top: 10px;
	display: flex;
	justify-content: center;
	text-align: center;
}

#bbs_pages .pg,
.bbs-pages .pg {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	flex-wrap: wrap;
}

#bbs_pages .pg_page,
#bbs_pages .pg_current,
#bbs_pages .pg_start,
#bbs_pages .pg_prev,
#bbs_pages .pg_next,
#bbs_pages .pg_end,
.bbs-pages .pg_page,
.bbs-pages .pg_current,
.bbs-pages .pg_start,
.bbs-pages .pg_prev,
.bbs-pages .pg_next,
.bbs-pages .pg_end {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: var(--bbs-ui-btn-h);
	height: var(--bbs-ui-btn-h);
	padding: 0 10px;
	border-radius: var(--bbs-ui-radius-pill);
	background: var(--bbs-ctrl-bg);
	color: var(--bbs-ui-fg-strong);
	font-size: var(--bbs-ui-btn-fz);
	line-height: 1;
	font-weight: var(--bbs-fw-semi, 600);
	text-decoration: none;
	border: none;
}

#bbs_pages .pg_current,
.bbs-pages .pg_current {
	background: var(--bbs-ctrl-bg-hover);
	color: var(--bbs-ui-fg-strong);
	border: none;
	box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--container-border-color, #fff) 42%, transparent);
}

#bbs_pages a.pg_page.pg_control,
.bbs-pages a.pg_page.pg_control {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	line-height: var(--bbs-ui-btn-h) !important;
	padding-top: 0 !important;
	padding-bottom: 0 !important;
	vertical-align: middle !important;
}

@media all and (max-width: 1000px) {
	.bbs-btn {
		/* 모바일 권장 터치 타깃 44×44px (Apple HIG / Android Material). 기존 36px → 44px. */
		width: 44px;
		height: 44px;
		min-height: 44px;
		border-radius: 999px;
	}
	.bbs-cat-btn {
		/* 28x28 → 36x36(모바일), 시각 균형상 44 까지는 안 키움. 대신 hit area 확장. */
		min-width: 36px;
		min-height: 36px;
	}
}

/* 버튼 보더 제거 (보드 스킨 영역 한정). 칩 family (.bbs-filter-btn / .bbs-quick-btn / .bbs-quick-clear) 는 보더 디자인 있으므로 :not() 제외. */
.board-viewer button:not(.bbs-filter-btn):not(.bbs-quick-btn):not(.bbs-quick-clear),
.bbs-list button:not(.bbs-filter-btn):not(.bbs-quick-btn):not(.bbs-quick-clear),
.board-viewer input[type="button"],
.bbs-list input[type="button"],
.board-viewer input[type="submit"],
.bbs-list input[type="submit"],
.board-viewer input[type="reset"],
.bbs-list input[type="reset"],
.board-viewer .bbs-btn,
.bbs-list .bbs-btn,
.board-viewer .bbs-search-row button,
.bbs-list .bbs-search-row button,
.board-viewer .bbs-settings-add,
.board-viewer .bbs-settings-save,
.board-viewer .post-sp-del,
.board-viewer .bbs-thumb-popover button,
.board-viewer .bbs-bg-popover button,
.board-viewer .sp-avatar-popover button,
.board-viewer .bbs-backup-preview,
.board-viewer .bbs-backup-restore,
.board-viewer .bbs-backup-delete,
.board-viewer .bbs-backup-preview-close,
.board-viewer .bbs-backup-preview-apply,
.board-viewer .reaction-btn,
.board-viewer .reaction-emoji,
.board-viewer .reaction-fab,
.board-viewer .reaction-tab,
.board-viewer .reaction-fav-toggle,
.bbs-list .reaction-btn,
.bbs-list .reaction-emoji,
.bbs-list .reaction-fab,
.bbs-list .reaction-tab,
.bbs-list .reaction-fav-toggle {
	border: 0 !important;
	border-color: transparent !important;
	box-shadow: none !important;
	outline: 0 !important;
}

.board-viewer i,
.board-viewer .fa,
.board-viewer .fas,
.board-viewer .far,
.board-viewer .fab,
.board-viewer .fa-solid,
.board-viewer .fa-regular,
.board-viewer .fa-classic,
.bbs-list i,
.bbs-list .fa,
.bbs-list .fas,
.bbs-list .far,
.bbs-list .fab,
.bbs-list .fa-solid,
.bbs-list .fa-regular,
.bbs-list .fa-classic {
	border: 0 !important;
	outline: 0 !important;
	box-shadow: none !important;
}

/* Pickr: CMYK 타입 버튼 숨김 */
.pcr-app .pcr-interaction .pcr-type[data-type="CMYK"] {
	display: none !important;
}

/* 요청사항: 버튼 보더 전역 제거 */
button,
input[type="button"],
input[type="submit"],
input[type="reset"] {
	border: 0 !important;
	border-color: transparent !important;
	box-shadow: none !important;
	outline: 0 !important;
}
