/**
 * feed.css — 13.Seohyeon 피드 페이지
 * 위치: /var/www/test_seohyeon/public/assets/css/feed.css
 * 의존성: theme.css (--blade, --bladeL, --bg, --surface, --text, --muted,
 *          --border, --hd-drawer-border, --surface-strong, --surface-soft,
 *          --shadow, --transition, --radius-md, --radius-sm 등)
 * 수정이력:
 *   2026-03-16 최초 작성 (WBS 1-08)
 *   2026-03-27 CFS 탭별 입력폼 분리, 댓글 입력폼, 피드백 삭제 버튼, 라이트테마 추가
 *   2026-03-27 최적화: STEP7·8 구버전 태깅/피드백 UI 제거 (-427줄)
 *   2026-03-28 최적화: 중복 선언 제거, CFS 전용 색상 변수화
 *   2026-03-29 최적화: [data-theme="light"] 중복 블록 통합, 빈 주석 제거,
 *              CFS 영역 하드코딩 색상 → var(--cfs-*) 변수 활용
 */

/* ══════════════════════════════════════════════
   페이지 래퍼
══════════════════════════════════════════════ */
.page-body:has(.feed-page) {
	padding: 0;
	max-width: none !important;
}

/* ══════════════════════════════════════════════
   피드 페이지
══════════════════════════════════════════════ */
.feed-page {
	display: flex;
	flex-direction: column;
	width: 100%;
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 12px 80px;
	min-height: calc(100dvh - 58px);
}

/* ══════════════════════════════════════════════
   탭 바
══════════════════════════════════════════════ */
.feed-tab-bar {
	display: flex;
	align-items: center;
	gap: 5px;
	padding: 10px 8px;
	margin: 12px 0 4px;
	position: sticky;
	top: 58px;
	z-index: 100;
	background: rgba(255,255,255,.72);
	border: 1px solid rgba(15,23,42,.06);
	border-radius: 18px;
	box-shadow: 0 10px 30px rgba(15,23,42,.05);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
}
[data-theme="dark"] .feed-tab-bar {
	background: rgba(9,19,33,.78);
	border-color: rgba(255,255,255,.08);
}

@media (max-width: 767px) {
	.feed-page { padding-top: 10px; }
	.feed-tab-bar {
		top: 52px;
		margin-top: 0;
		border-radius: 0 0 18px 18px;
	}
}
@media (min-width: 768px) {
	.feed-page { padding-bottom: 40px; }
	.feed-tab-bar { top: 58px; }
}

.feed-tab {
	flex-shrink: 0;
	height: 40px;
	padding: 0 10px;
	font-size: 13px;
	font-weight: 700;
	color: var(--muted);
	background: transparent;
	border: none;
	border-radius: 12px;
	cursor: pointer;
	transition: color .18s, background .18s;
	white-space: nowrap;
}
.feed-tab:hover  { color: var(--text); background: rgba(34,145,255,.08); }
.feed-tab.is-active { color: var(--blade); background: rgba(34,145,255,.12); }

/* 정렬 드롭다운 */
.feed-sort-wrap {
	position: relative;
	margin-left: auto;
	flex-shrink: 0;
	display: flex;
	align-items: center;
}
.feed-sort-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 40px;
	gap: 4px;
	padding: 0 6px;
	font-size: 12px;
	font-weight: 700;
	color: var(--muted);
	background: rgba(255,255,255,.72);
	border: 1px solid rgba(15,23,42,.08);
	border-radius: 12px;
	cursor: pointer;
	transition: color .18s, border-color .18s, background .18s;
	white-space: nowrap;
}
.feed-sort-btn:hover {
	color: var(--blade);
	border-color: rgba(34,145,255,.28);
	background: rgba(34,145,255,.06);
}
[data-theme="dark"] .feed-sort-btn {
	background: rgba(255,255,255,.04);
	border-color: rgba(255,255,255,.08);
}
.feed-sort-arrow {
	font-size: 10px;
	transition: transform .2s;
}
.feed-sort-panel.is-open ~ .feed-sort-btn .feed-sort-arrow,
.feed-sort-btn[aria-expanded="true"] .feed-sort-arrow { transform: rotate(180deg); }

.feed-sort-panel {
	display: none;
	position: absolute;
	top: calc(100% + 6px);
	right: 0;
	min-width: 100px;
	background: var(--surface-strong, #fff);
	border: 1px solid var(--hd-drawer-border);
	border-radius: 12px;
	box-shadow: var(--shadow);
	padding: 6px 4px;
	z-index: 200;
	flex-direction: column;
}
[data-theme="dark"] .feed-sort-panel { background: rgba(9,19,33,.97); }
.feed-sort-panel.is-open { display: flex; }

.feed-sort-item {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 8px 12px;
	font-size: 12px;
	font-weight: 500;
	color: var(--text);
	cursor: pointer;
	border-radius: 8px;
	white-space: nowrap;
	transition: background .12s;
}
.feed-sort-item:hover { background: var(--bladeL); }
.feed-sort-item input { accent-color: var(--blade); cursor: pointer; }

/* 글쓰기 버튼 */
.feed-write-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 12px;
	background: linear-gradient(135deg, #2ea8ff 0%, #1d8fff 100%);
	color: #fff;
	font-size: 15px;
	flex-shrink: 0;
	box-shadow: 0 10px 20px rgba(34,145,255,.22);
	transition: transform .18s, box-shadow .18s;
}
.feed-write-btn:hover {
	transform: translateY(-1px);
	box-shadow: 0 14px 24px rgba(34,145,255,.28);
}

/* ══════════════════════════════════════════════
   피드 목록
══════════════════════════════════════════════ */
.feed-list-wrap { padding: 16px 0; }

.feed-list {
	list-style: none;
	display: grid;
	grid-template-columns: 1fr;
	gap: 14px;
}
@media (min-width: 620px) { .feed-list { grid-template-columns: repeat(2,1fr); } }
@media (min-width: 900px) { .feed-list { grid-template-columns: repeat(3,1fr); } }

.feed-list-loading {
	grid-column: 1 / -1;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	min-height: 260px;
	padding: 48px 0;
	font-size: 24px;
	color: var(--blade);
}

.feed-empty {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
	padding: 64px 24px;
	color: var(--muted);
	font-size: 14px;
}
.feed-empty i { font-size: 36px; opacity: .5; }

/* 더보기 버튼 */
.feed-more-wrap { padding: 16px 24px; text-align: center; }
.feed-more-btn {
	padding: 10px 32px;
	font-size: 13px;
	font-weight: 600;
	color: var(--blade);
	background: transparent;
	border: 1.5px solid var(--blade);
	border-radius: 20px;
	cursor: pointer;
	transition: background var(--transition), color var(--transition);
}
.feed-more-btn:hover { background: var(--blade); color: #fff; }

/* ══════════════════════════════════════════════
   피드 카드
══════════════════════════════════════════════ */
.feed-card {
	background: var(--surface);
	border: 1px solid rgba(15,23,42,.06);
	border-radius: 18px;
	padding: 14px 14px 12px;
	cursor: pointer;
	transition: box-shadow .2s, transform .2s, border-color .2s;
	box-shadow: 0 10px 28px rgba(15,23,42,.06);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	height: 100%;
	position: relative;
}
.feed-card.is-action-open { transform: none !important; }
.feed-card:hover {
	box-shadow: 0 6px 20px rgba(0,0,0,.11);
	transform: translateY(-2px);
}
[data-theme="dark"] .feed-card {
	background: rgba(255,255,255,.04);
	border-color: rgba(255,255,255,.08);
}
[data-theme="dark"] .feed-card:hover { background: rgba(30,167,255,.06); }

.feed-card-header {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 8px;
}
.feed-card-avatar {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
}
.feed-card-avatar--empty {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--bladeL);
	color: var(--blade);
	font-size: 16px;
}
.feed-card-author-info {
	flex: 1;
	display: flex;
	align-items: center;
	gap: 5px;
	min-width: 0;
	overflow: hidden;
}
.feed-card-nick {
	font-size: 13px;
	font-weight: 700;
	color: var(--text);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.feed-card-header-right {
	display: flex;
	align-items: center;
	gap: 4px;
	flex-shrink: 0;
}
.feed-card-date {
	font-size: 11px;
	color: var(--muted);
	white-space: nowrap;
	flex-shrink: 0;
}
.feed-card-more-btn {
	flex-shrink: 0;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	border: none;
	background: transparent;
	color: var(--muted);
	font-size: 14px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background var(--transition), color var(--transition);
}
.feed-card-more-btn:hover { background: var(--bladeL); color: var(--blade); }

.feed-badge {
	display: inline-block;
	padding: 1px 6px;
	border-radius: 4px;
	font-size: 10px;
	font-weight: 700;
	line-height: 1.6;
	margin-left: 4px;
}
.feed-badge--blind { background: rgba(139,92,246,.12); color: #8b5cf6; }

.feed-card-body {
	font-size: 13.5px;
	color: var(--text);
	line-height: 1.55;
	margin: 8px 0 6px;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	min-height: calc(13.5px * 1.55 * 2);
}
.feed-card-body--empty { color: transparent; user-select: none; }

/* 썸네일 */
.feed-card-thumb {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 10;
	border-radius: 14px;
	overflow: hidden;
	margin-bottom: 10px;
	background: #eef4fa;
}
.feed-card-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.feed-card-thumb--empty .feed-card-thumb-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	padding: 18px 20px;
	box-sizing: border-box;
	overflow: hidden;
}
.feed-card-thumb--empty .feed-card-thumb-text {
	font-size: 14px;
	line-height: 1.6;
	color: var(--text);
	opacity: .55;
	display: -webkit-box;
	-webkit-line-clamp: 4;
	-webkit-box-orient: vertical;
	overflow: hidden;
	text-align: left;
	word-break: break-all;
}

/* 텍스트 전용 카드 — 컬러 배경 6종 */
.feed-card-thumb--empty-1 { background: linear-gradient(135deg, rgba(30,167,255,.13) 0%, rgba(120,228,255,.08) 100%); }
.feed-card-thumb--empty-2 { background: linear-gradient(135deg, rgba(45,226,255,.11) 0%, rgba(30,167,255,.07) 100%); }
.feed-card-thumb--empty-3 { background: linear-gradient(135deg, rgba(99,179,237,.13) 0%, rgba(186,230,253,.10) 100%); }
.feed-card-thumb--empty-4 { background: linear-gradient(135deg, rgba(255,122,61,.10) 0%, rgba(255,167,100,.07) 100%); }
.feed-card-thumb--empty-5 { background: linear-gradient(135deg, rgba(16,185,129,.10) 0%, rgba(110,231,183,.07) 100%); }
.feed-card-thumb--empty-6 { background: linear-gradient(135deg, rgba(139,92,246,.10) 0%, rgba(196,181,253,.07) 100%); }
[data-theme="dark"] .feed-card-thumb--empty-1 { background: linear-gradient(135deg, rgba(30,167,255,.20) 0%, rgba(120,228,255,.10) 100%); }
[data-theme="dark"] .feed-card-thumb--empty-2 { background: linear-gradient(135deg, rgba(45,226,255,.17) 0%, rgba(30,167,255,.10) 100%); }
[data-theme="dark"] .feed-card-thumb--empty-3 { background: linear-gradient(135deg, rgba(99,179,237,.20) 0%, rgba(186,230,253,.12) 100%); }
[data-theme="dark"] .feed-card-thumb--empty-4 { background: linear-gradient(135deg, rgba(255,122,61,.17) 0%, rgba(255,167,100,.10) 100%); }
[data-theme="dark"] .feed-card-thumb--empty-5 { background: linear-gradient(135deg, rgba(16,185,129,.17) 0%, rgba(110,231,183,.10) 100%); }
[data-theme="dark"] .feed-card-thumb--empty-6 { background: linear-gradient(135deg, rgba(139,92,246,.17) 0%, rgba(196,181,253,.10) 100%); }

.feed-card-thumb--yt { background: #000; }
.feed-card-yt-icon {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 40px;
	color: rgba(255,255,255,.85);
	pointer-events: none;
}

.feed-card-pending-badge {
	position: absolute;
	left: 10px;
	bottom: 10px;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 10px;
	border-radius: 999px;
	background: rgba(17,24,39,.74);
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	backdrop-filter: blur(8px);
}
.feed-pending-spinner {
	display: inline-block;
	width: 10px;
	height: 10px;
	border: 2px solid rgba(255,255,255,.3);
	border-top-color: #fff;
	border-radius: 50%;
	animation: feedPendingSpin .8s linear infinite;
	flex-shrink: 0;
}
@keyframes feedPendingSpin { to { transform: rotate(360deg); } }

.feed-card-media-badge-wrap { margin-bottom: 6px; }
.feed-card-media-count { font-size: 11px; color: var(--muted); }

.feed-card-footer {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-top: auto;
	padding-top: 8px;
}
.feed-card-like-btn,
.feed-card-bookmark-btn {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: 13px;
	color: var(--muted);
	background: transparent;
	border: none;
	cursor: pointer;
	padding: 4px 2px;
	transition: color var(--transition), transform .15s;
}
.feed-card-like-btn:hover     { color: #ef4444; transform: scale(1.1); }
.feed-card-bookmark-btn:hover { color: var(--blade); transform: scale(1.1); }
.feed-card-like-btn.is-liked         { color: #ef4444; }
.feed-card-bookmark-btn.is-bookmarked { color: var(--blade); }

.feed-card-comment-count {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: 13px;
	color: var(--muted);
}

/* ══════════════════════════════════════════════
   카드 인라인 액션 패널
══════════════════════════════════════════════ */
.feed-card-action-panel {
	position: absolute;
	inset: 0;
	border-radius: 18px;
	background: rgba(0,0,0,.48);
	backdrop-filter: blur(1px);
	-webkit-backdrop-filter: blur(1px);
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	opacity: 0;
	pointer-events: none;
	transition: opacity .2s ease;
	z-index: 3;
}
.feed-card-action-panel.is-open { opacity: 1; pointer-events: auto; }

.feed-card-action-row {
	display: flex;
	flex-direction: column;
	gap: 6px;
	padding: 10px;
	transform: translateY(10px);
	transition: transform .22s cubic-bezier(.4,0,.2,1);
}
.feed-card-action-panel.is-open .feed-card-action-row { transform: translateY(0); }

.feed-card-action-btn {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 11px 0;
	font-size: 14px;
	font-weight: 700;
	border: none;
	border-radius: 12px;
	cursor: pointer;
	transition: opacity .15s;
	font-family: inherit;
}
.feed-card-action-btn:active { opacity: .75; }
.feed-card-action-btn--edit   { background: rgba(255,255,255,.92); color: var(--blade); }
.feed-card-action-btn--delete { background: rgba(255,255,255,.92); color: #ef4444; }
.feed-card-action-btn--cancel { background: rgba(255,255,255,.92); color: var(--muted); }
[data-theme="dark"] .feed-card-action-btn--edit   { background: rgba(30,167,255,.8);  color: #7dd3fc; }
[data-theme="dark"] .feed-card-action-btn--delete { background: rgba(239,68,68,.8);   color: #fca5a5; }
[data-theme="dark"] .feed-card-action-btn--cancel { background: rgba(255,255,255,.8); color: rgba(255,255,255,.55); }

/* ══════════════════════════════════════════════
   피드 상세 레이어
══════════════════════════════════════════════ */
/* ══════════════════════════════════════════════
   피드 상세 레이어 — 전체화면 좌/우 분할
   모바일(~767px): 세로 스택 (fd-left 숨김)
   PC(768px~)    : 전체화면, fd-left(미디어) + fd-right(480px)
   미디어 없을 때 PC: fd-left 숨김, fd-right 480px 우측 고정
══════════════════════════════════════════════ */
#feed-detail {
	position: fixed;
	inset: 0;
	z-index: 300;
	background: var(--bg);
	display: flex;
	flex-direction: column;
	overflow: hidden;
	transform: translateX(100%);
	visibility: hidden;
	transition: transform .3s cubic-bezier(.32,1,.6,1), visibility 0s linear .3s;
}
#feed-detail.is-open {
	transform: translateX(0);
	visibility: visible;
	transition: transform .3s cubic-bezier(.32,1,.6,1), visibility 0s linear 0s;
}

/* ── 모바일 기본: fd-left 숨김, fd-right 전체 ── */
.fd-left  { display: none; }
.fd-right {
	display: flex;
	flex-direction: column;
	flex: 1;
	min-height: 0;
	overflow: hidden;
}

/* ── PC(768px~): 좌/우 가로 분할 ── */
@media (min-width: 768px) {
	#feed-detail { flex-direction: row; }

	/* fd-right 기본: 480px 고정, 우측 정렬 */
	.fd-right {
		width: 480px;
		flex: none;
		margin-left: auto;
		border-left: 1px solid var(--hd-drawer-border);
	}

	/* 미디어 있을 때: fd-left 표시, fd-right margin-left 제거 */
	#feed-detail.has-media .fd-left {
		display: flex;
		flex-direction: column;
		flex: 1;
		min-width: 0;
		background: #000;
		overflow: hidden;
		position: relative;
	}
	#feed-detail.has-media .fd-right {
		margin-left: 0;
	}

	/* 미디어 없을 때: fd-left 숨김 유지, fd-right 우측 */
	#feed-detail:not(.has-media) .fd-left { display: none; }

	/* PC 우측 헤더 — 미디어 있을 때 숨김 (좌측 헤더가 대신) */
	.fd-header--pc-hidden { display: none !important; }

	/* PC 좌측 헤더 */
	.feed-detail-header--left {
		position: relative;
		z-index: 5;
		background: var(--bg);
		border-bottom: 1px solid var(--hd-drawer-border);
		flex-shrink: 0;
	}
	.feed-detail-header--left .feed-detail-back     { color: var(--text); }
	.feed-detail-header--left .feed-detail-back:hover { background: var(--bladeL); }
	.feed-detail-header--left .feed-detail-header-nick { color: var(--text); }
	.feed-detail-header--left .feed-detail-header-date { color: var(--muted); }
	.feed-detail-header--left .feed-detail-more    { color: var(--muted); }
	.feed-detail-header--left .feed-detail-more:hover { background: var(--bladeL); color: var(--blade); }

	/* fd-left 미디어 영역 — 전체 높이 */
	.feed-detail-media-area {
		flex: 1;
		min-height: 0;
		display: flex;
		flex-direction: column;
	}
	.fd-left .feed-media-wrap {
		flex: 1;
		min-height: 0;
		margin-bottom: 0;
		aspect-ratio: unset;
	}
	.fd-left .feed-media-wrap .feed-media-track {
		height: 100%;
	}
	.fd-left .feed-media-slide {
		aspect-ratio: unset;
		height: 100%;
	}
}

/* feed-detail-media-area: 모바일에서는 숨김 (미디어는 feed-detail-sticky로 이동) */
.feed-detail-media-area { display: none; }
@media (min-width: 768px) {
	.feed-detail-media-area {
		display: flex;
		flex-direction: column;
		flex: 1;
		min-height: 0;
	}
}

.feed-detail-header {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 2px 10px;
	border-bottom: 1px solid var(--hd-drawer-border);
	flex-shrink: 0;
	position: relative;
	z-index: 2;
}
.feed-detail-back {
	width: 32px; height: 32px;
	border-radius: 50%;
	border: none;
	background: transparent;
	color: var(--text);
	font-size: 16px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background var(--transition);
}
.feed-detail-back:hover { background: var(--bladeL); }
.feed-detail-header-user {
	display: flex;
	align-items: center;
	gap: 10px;
	min-width: 0;
	flex: 1;
}
.feed-detail-header-avatar {
	width: 36px; height: 36px;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
	background: var(--bladeL);
}
.feed-detail-header-nick {
	font-size: 12px;
	font-weight: 700;
	color: var(--text);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.feed-detail-header-date {
	flex-shrink: 0;
	font-size: 11px;
	color: var(--muted);
	margin-left: auto;
}
.feed-detail-more {
	width: 32px; height: 32px;
	border-radius: 50%;
	border: none;
	background: transparent;
	color: var(--muted);
	font-size: 16px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background var(--transition), color var(--transition);
}
.feed-detail-more:hover { background: var(--bladeL); color: var(--blade); }

.feed-detail-sticky {
	flex-shrink: 0;
	background: var(--bg);
	max-height: 60vw;
	overflow: hidden;
}

.feed-detail-sticky.is-loading {
	pointer-events: none;
}

.feed-detail-body { flex-shrink: 0; padding-bottom: 0; }
.feed-detail-body.is-loading { opacity: .5; pointer-events: none; }

.feed-detail-scroll {
	flex: 1;
	overflow-y: auto;
	overscroll-behavior: contain;
	min-height: 0;
	display: flex;
	flex-direction: column;
}
.feed-detail-scroll::-webkit-scrollbar { display: none; }

.feed-detail-author {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 14px 16px 10px;
}
.feed-detail-avatar {
	width: 40px; height: 40px;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
	background: var(--bladeL);
}
.feed-detail-author-info { flex: 1; display: flex; flex-direction: column; gap: 1px; }
.feed-detail-nick { font-size: 14px; font-weight: 700; color: var(--text); }
.feed-detail-date { font-size: 11px; color: var(--muted); }

.feed-follow-btn {
	flex-shrink: 0;
	padding: 5px 14px;
	font-size: 12px;
	font-weight: 700;
	color: var(--blade);
	background: transparent;
	border: 1.5px solid var(--blade);
	border-radius: 20px;
	cursor: pointer;
	transition: background var(--transition), color var(--transition);
}
.feed-follow-btn:hover,
.feed-follow-btn.is-following { background: var(--blade); color: #fff; }

/* 미디어 슬라이더 */
.feed-media-wrap {
	position: relative;
	overflow: hidden;
	background: #000;
	margin-bottom: 4px;
	touch-action: pan-y;
	min-height: 0;
}

.feed-media-wrap.is-loading {
	display: block !important;
}

.feed-media-loading {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 9;
	background: #000;
	z-index: 1;
}

.feed-media-loading-box {
	width: 100%;
	height: 100%;
	border-radius: 0;
}

.feed-media-wrap.is-loading .feed-media-track,
.feed-media-wrap.is-loading .feed-media-dots,
.feed-media-wrap.is-loading .feed-media-sound-btn,
.feed-media-wrap.is-loading .feed-media-mini-ctrl,
.feed-media-wrap.is-loading .feed-slider-btn,
.feed-media-wrap.is-loading .feed-yt-fullscreen-btn,
.feed-media-wrap.is-loading .feed-rotate-btn {
	display: none !important;
}

.feed-media-track {
	display: flex;
	will-change: transform;
	transition: transform .3s cubic-bezier(.32,1,.6,1);
}

.feed-media-slide {
	flex: 0 0 100%;
	width: 100%;
	aspect-ratio: 16 / 9;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #000;
	overflow: hidden;
}

.feed-media-slide img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
	cursor: pointer;
}

.feed-media-slide iframe {
	width: 100%;
	height: 100%;
	border: none;
}

.feed-media-dots {
	position: absolute;
	bottom: 10px;
	left: 12px;
	z-index: 3;
	pointer-events: none;
}
.feed-media-counter {
	font-size: 12px;
	font-weight: 500;
	color: rgba(0,0,0,.2);
	letter-spacing: 0.03em;
}

.feed-media-sound-btn {
	position: absolute;
	top: 12px; right: 12px;
	z-index: 12;
	width: 36px; height: 36px;
	border: none;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0,0,0,.25);
	color: rgba(255,255,255,.75);
	font-size: 14px;
	cursor: pointer;
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	transition: background .18s, transform .18s, opacity .18s;
	opacity: .7;
}
.feed-media-sound-btn:hover { background: rgba(166,166,217,.8); opacity: 1; transform: scale(1.06); }

.feed-play-flash {
	position: absolute;
	top: 50%; left: 50%;
	transform: translate(-50%,-50%) scale(1);
	z-index: 20;
	pointer-events: none;
	width: 72px; height: 72px;
	border-radius: 50%;
	background: rgba(0,0,0,.45);
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-size: 32px;
	opacity: 0;
	transition: none;
}
.feed-play-flash.is-flash { animation: feedPlayFlash .6s cubic-bezier(.22,.61,.36,1) forwards; }
@keyframes feedPlayFlash {
	0%   { opacity: .9; transform: translate(-50%,-50%) scale(1); }
	60%  { opacity: .4; transform: translate(-50%,-50%) scale(1.35); }
	100% { opacity: 0;  transform: translate(-50%,-50%) scale(1.6); }
}

.feed-slider-btn {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 36px; height: 36px;
	border-radius: 50%;
	border: none;
	background: rgba(0,0,0,.4);
	color: #fff;
	font-size: 14px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 10;
	opacity: 0;
	transition: opacity .18s, background .18s;
	backdrop-filter: blur(4px);
	user-select: none;
	pointer-events: none;
}
.feed-media-wrap:hover .feed-slider-btn { opacity: 1; pointer-events: auto; }
.feed-slider-prev { left: 8px; }
.feed-slider-next { right: 8px; }
.feed-slider-btn:hover { background: rgba(0,0,0,.65); }

.feed-yt-overlay {
	position: absolute;
	inset: 0;
	z-index: 8;
	cursor: grab;
	background: transparent;
	touch-action: manipulation;
}
.feed-yt-overlay.is-dragging { cursor: grabbing; }

.feed-media-video-pending {
	position: absolute;
	bottom: 14px; left: 14px;
	display: inline-flex;
	align-items: center;
	gap: 7px;
	padding: 7px 12px;
	border-radius: 999px;
	background: rgba(10,10,18,.78);
	color: #fff;
	font-size: 12px;
	font-weight: 700;
	backdrop-filter: blur(8px);
	z-index: 5;
	pointer-events: none;
}
.feed-media-video-pending-empty {
	width: 100%; height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--surface);
	color: var(--muted);
	font-size: 40px;
}

.feed-yt-fullscreen-btn {
	position: absolute;
	bottom: 10px; right: 10px;
	z-index: 10;
	width: 32px; height: 32px;
	border-radius: 6px;
	border: none;
	background: rgba(0,0,0,.25);
	color: #fff;
	font-size: 14px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background .15s;
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
}
.feed-yt-fullscreen-btn:hover { background: rgba(166,166,217,.8); }


/* ── 상세 슬라이더 미니 제어 패널 ── */
.feed-media-mini-ctrl {
	display: none;
	position: absolute;
	right: 5px;
	bottom: 5px;
	z-index: 14;
	align-items: center;
	gap: 6px;
	padding: 5px;
	border-radius: 10px;
	background: rgba(255,255,255,.20);
	backdrop-filter: blur(3px);
	-webkit-backdrop-filter: blur(3px);
	pointer-events: auto;
	max-width: calc(100% - 24px);
	overflow: hidden;
}

.feed-media-mini-ctrl {
	will-change: right, bottom;
}

.feed-media-mini-ctrl.is-dragging {
	transition: none !important;
}

.feed-media-mini-ctrl.is-show {
	display: inline-flex;
}

.feed-media-mini-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 4px;
	height: 34px;
	min-width: 34px;
	padding: 0 10px;
	border: 1px solid rgba(255,255,255,.32);
	border-radius: 8px;
	background: rgba(0,0,0,.22);
	color: #fff;
	font-size: 12px;
	font-weight: 700;
	cursor: pointer;
	backdrop-filter: blur(3px);
	-webkit-backdrop-filter: blur(3px);
	touch-action: manipulation;
	flex-shrink: 0;
	transition: background .15s, border-color .15s, color .15s, opacity .18s, transform .15s;
}

.feed-media-mini-btn:hover,
.feed-media-mini-btn.is-open {
	background: rgba(30,167,255,.35);
	border-color: rgba(30,167,255,.6);
	color: #fff;
}

.feed-media-mini-btn--toggle {
	background: rgba(30,167,255,.34);
	border-color: rgba(30,167,255,.58);
	color: #fff;
	cursor: grab;
	touch-action: none;
}

.feed-media-mini-btn--toggle:hover {
	background: rgba(30,167,255,.42);
	border-color: rgba(30,167,255,.72);
	color: #fff;
}

.feed-media-mini-btn--toggle.is-open,
.feed-media-mini-btn--toggle:active {
	background: rgba(255,120,120,.24);
	border-color: rgba(255,120,120,.45);
	color: #fff;
}

.feed-media-mini-btn i {
	font-size: 12px;
	line-height: 1;
}

.feed-media-mini-btn span {
	line-height: 1;
	white-space: nowrap;
}

.feed-media-mini-extra {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	max-width: 0;
	opacity: 0;
	overflow: hidden;
	white-space: nowrap;
	pointer-events: none;
	transition: max-width .22s ease, opacity .18s ease;
}

.feed-media-mini-ctrl.is-open .feed-media-mini-extra {
	max-width: 420px;
	opacity: 1;
	pointer-events: auto;
}

.feed-media-mini-btn--rateview {
	min-width: 54px;
	padding: 0 11px;
	font-weight: 800;
	letter-spacing: -.2px;
}

.feed-media-wrap.has-mini-ctrl .feed-media-sound-btn,
.feed-media-wrap.has-mini-ctrl .feed-yt-fullscreen-btn {
	display: none !important;
}

@media (max-width: 767px) {
	.feed-media-mini-ctrl {
		gap: 4px;
		padding: 4px;
		right: 5px;
		bottom: 5px;
		max-width: calc(100% - 20px);
	}

	.feed-media-mini-btn {
		height: 30px;
		min-width: 30px;
		padding: 0 8px;
		font-size: 11px;
	}

	.feed-media-mini-btn i {
		font-size: 11px;
	}

	.feed-media-mini-btn--toggle span {
		display: none;
	}

	.feed-media-mini-ctrl.is-open .feed-media-mini-extra {
		max-width: 360px;
	}
}

.feed-rotate-btn {
	position: absolute;
	bottom: 10px; right: 10px;
	z-index: 10;
	width: 32px; height: 32px;
	border-radius: 6px;
	border: none;
	background: rgba(0,0,0,.45);
	color: #fff;
	font-size: 14px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	transition: background .15s;
}
.feed-rotate-btn:hover { background: rgba(0,0,0,.7); }
.feed-rotate-btn--viewer { position: fixed; bottom: 60px; right: 16px; z-index: 1020; background: rgba(255,255,255,.18); }

/* ══════════════════════════════════════════════
   CFS (크게보기) 레이어
══════════════════════════════════════════════ */
/* ══════════════════════════════════════════════
   CFS 레이어 (크게보기)
   PC: 우측 360px 사이드 패널 공간 제외
   모바일: 세로영상=전체화면, 가로영상=rotate90
══════════════════════════════════════════════ */
.feed-yt-cfs-layer {
	position: fixed;
	top: 0; left: 0; bottom: 0;
	right: 0;
	z-index: 9000;
	background: #000;
	display: flex;
	align-items: center;
	justify-content: center;
	animation: feedCfsIn .2s ease;
}
@keyframes feedCfsIn { from { opacity: 0; } to { opacity: 1; } }

/* 모바일: 기본은 전체화면 */
@media (max-width: 1023px) {
	.feed-yt-cfs-layer {
		right: 0;
		transition: right .25s cubic-bezier(.32,1,.6,1);
	}
	/* 세로 일반 영상: 패널 열림 → layer right 이동으로 영상 밀기 */
	.feed-yt-cfs-layer.panel-open {
		right: 220px;
	}
	/* 가로 영상: rotate(90deg) 전체화면 + flex로 iframe/패널 나란히 */
	.feed-yt-cfs-layer.is-landscape {
		width: 100dvh; height: 100dvw;
		top: 50%; left: 50%;
		right: auto; bottom: auto;
		transform: translate(-50%,-50%) rotate(90deg);
		transform-origin: center center;
		transition: none;
		display: flex;        /* iframe + 패널 나란히 배치 */
		flex-direction: row;
		align-items: stretch;
	}
	.feed-yt-cfs-layer.is-short { right: 0; max-width: 100vw; }
}

.feed-yt-cfs-iframe { width: 100%; height: 100%; border: none; display: block; }
/* 가로영상 flex 안에서 iframe이 남은 공간 차지 */
@media (max-width: 1023px) {
	.feed-yt-cfs-layer.is-landscape .feed-yt-cfs-iframe {
		flex: 1;
		width: auto;
		min-width: 0;
	}
}

/* ── CFS 색상 변수 — 영상 위 버튼은 라이트/다크 무관 단일 스타일 ── */
/* ── CFS 색상 변수 ── */
#feed-yt-cfs-layer,
.feed-yt-cfs-layer {
	--cfs-accent:       #36b3ff;
	--cfs-accent-dim:   rgba(54,179,255,.28);
	--cfs-accent-faint: rgba(54,179,255,.10);
	--cfs-text:         #f8fbff;
	--cfs-text-muted:   rgba(232,241,255,.68);
	--cfs-border:       rgba(161,192,255,.18);
	--cfs-surface:      rgba(10,18,32,.72);
	--cfs-bg-input:     rgba(255,255,255,.12);
}
/* 사이드패널은 테마 변수 사용 — 라이트/다크 자동 대응 */
.feed-yt-cfs-side {
	--cfs-text:         var(--text);
	--cfs-text-muted:   var(--muted);
	--cfs-border:       var(--hd-drawer-border);
	--cfs-surface:      var(--surface);
	--cfs-bg-input:     var(--surface-soft, var(--bladeL));
	--cfs-accent:       var(--blade);
	--cfs-accent-dim:   var(--bladeL);
	--cfs-accent-faint: var(--bladeL);
}

/* ── 사이드 패널 (PC) ── */
.feed-yt-cfs-side {
	position: fixed;
	top: 0; right: 0; bottom: 0;
	width: 360px;
	z-index: 9050;
	background: linear-gradient(180deg, rgba(14,22,38,.94) 0%, rgba(9,15,28,.96) 100%);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	display: flex;
	flex-direction: column;
	align-items: stretch;
	border-left: 1px solid rgba(161,192,255,.16);
	box-shadow: -12px 0 32px rgba(0,0,0,.22);
	overflow: clip;
}
.feed-yt-cfs-side[data-theme="light"] {
	background: linear-gradient(180deg, rgba(250,252,255,.96) 0%, rgba(239,244,251,.96) 100%);
	border-left: 1px solid rgba(86,110,138,.16);
	box-shadow: -12px 0 28px rgba(15,23,42,.08);
}

/* 모바일: 패널은 우측에서 슬라이드-인, 기본 숨김 */
@media (max-width: 1023px) {
	.feed-yt-cfs-side {
		top: 0; right: -220px; bottom: 0;
		width: 220px;
		transition: right .25s cubic-bezier(.32,1,.6,1);
		z-index: 9210;
	}
	.feed-yt-cfs-side.is-open { right: 0; }
	/* inlayer (가로영상): flex 자식으로 동작 — 닫힘=width:0, 열림=width:220px */
	.feed-yt-cfs-side--inlayer {
		position: relative;  /* flex 자식 */
		right: auto;
		top: auto; bottom: auto;
		width: 0;
		height: 100%;        /* layer 높이 전체 사용 */
		overflow: clip;
		flex-shrink: 0;
		transition: width .25s cubic-bezier(.32,1,.6,1);
		z-index: 9210;
	}
	.feed-yt-cfs-side--inlayer.is-open {
		width: 220px;
	}
}

/* side-header / side-close: 더 이상 사용 안 함 → 숨김 유지 */
.feed-yt-cfs-side-header { display: none; }
.feed-yt-cfs-side-close  { display: none; }
.feed-yt-cfs-side-inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	color: var(--cfs-text-muted);
	font-size: 11px;
	letter-spacing: .03em;
	width: 100%;
	padding: 24px 16px;
	flex: 1;
	justify-content: center;
}

/* ── 하단 버튼바 (PC 사이드 패널 내부 고정) ── */
/* ── bottomBar ── */
.feed-yt-cfs-bottom-bar {
	position: absolute;
	bottom: 0; left: 0; right: 0;
	z-index: 9100;
	height: 48px;
	display: flex;
	align-items: center;
	padding: 0 10px;
	background: rgba(9,15,28,.82);
	border-top: 1px solid rgba(161,192,255,.16);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	box-shadow: 0 -8px 24px rgba(0,0,0,.18);
}
[data-theme="light"] .feed-yt-cfs-bottom-bar {
	background: rgba(248,251,255,.88);
	border-top-color: rgba(86,110,138,.10);
	box-shadow: 0 -8px 24px rgba(15,23,42,.06);
}
/* bottom-bar: --cfs-surface/border 변수로 통일 */

/* 모바일: 하단 버튼바 숨김 */
@media (max-width: 1023px) {
	.feed-yt-cfs-bottom-bar { display: none !important; }
}

/* 스킵 그룹 — 왼쪽 고정 */
.feed-yt-cfs-btn-group--skip { margin-right: auto; }

/* 배속 그룹 — 중앙 고정 */
.feed-yt-cfs-btn-group--rate {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
}

/* ── 버튼 그룹 공통 — border 없음, 버튼이 외곽 담당 ── */
.feed-yt-cfs-btn-group {
	display: flex;
	align-items: center;
	gap: 0;
	border-radius: 7px;
}

/* ── 그룹 내 개별 버튼 — 상하좌우 border 모두 포함 ── */
.feed-yt-cfs-ctrl-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 4px;
	height: 32px;
	min-width: 42px;
	padding: 0 11px;
	background: rgba(255,255,255,.05);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	border: 1px solid rgba(161,192,255,.18);
	border-left: none;
	color: var(--cfs-text);
	font-size: 12px;
	font-weight: 700;
	line-height: 1;
	cursor: pointer;
	transition: background .15s, color .15s, border-color .15s, transform .15s;
}
[data-theme="light"] .feed-yt-cfs-ctrl-btn {
	background: rgba(255,255,255,.72);
	border-color: rgba(86,110,138,.14);
	color: #1d2c3c;
}
.feed-yt-cfs-ctrl-btn:hover {
	background: rgba(54,179,255,.18);
	color: #fff;
	border-color: rgba(54,179,255,.42);
}
[data-theme="light"] .feed-yt-cfs-ctrl-btn:hover {
	background: rgba(54,179,255,.12);
	color: #0f2f47;
	border-color: rgba(54,179,255,.30);
}
/* 첫 버튼: 왼쪽 border 포함 (외곽선 시작) */
.feed-yt-cfs-btn-group .feed-yt-cfs-ctrl-btn:first-child {
	border-left: 1px solid var(--cfs-border);
	border-radius: 6px 0 0 6px;
}
.feed-yt-cfs-btn-group .feed-yt-cfs-ctrl-btn:last-child  { border-radius: 0 6px 6px 0; }
.feed-yt-cfs-btn-group .feed-yt-cfs-ctrl-btn:only-child  { border-left: 1px solid var(--cfs-border); border-radius: 6px; }
.feed-yt-cfs-ctrl-btn i { font-size: 12px; line-height: 1; vertical-align: middle; }
.feed-yt-cfs-ctrl-btn span { line-height: 1; vertical-align: middle; }
.feed-yt-cfs-ctrl-btn:hover  { background: rgba(30,167,255,.35); color: #fff; border-color: rgba(30,167,255,.6); }
.feed-yt-cfs-ctrl-btn:active { background: rgba(30,167,255,.55); color: #fff; border-color: rgba(30,167,255,.8); }

/* 배속 표시 버튼 */
.feed-yt-cfs-ctrl-btn--rate { min-width: 42px; font-size: 12px; font-weight: 800; letter-spacing: -.3px; }
.feed-yt-cfs-ctrl-btn--rate.rate-active { background: rgba(30,167,255,.65); color: #fff; border-left-color: rgba(30,167,255,.5); }

/* ── 축소 버튼 ── */
.feed-yt-cfs-back {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	border-radius: 8px;
	border: 1px solid rgba(255,255,255,.22);
	background: rgba(255,255,255,.08);
	color: var(--cfs-text);
	font-size: 13px;
	cursor: pointer;
	transition: background .15s, color .15s, border-color .15s, transform .15s;
	flex-shrink: 0;
	margin-left: 0;
}
.feed-yt-cfs-back:hover {
	background: rgba(54,179,255,.22);
	color: #fff;
	border-color: rgba(54,179,255,.42);
	transform: translateY(-1px);
}

.feed-yt-cfs-back:active {
	background: rgba(54,179,255,.34);
	color: #fff;
	border-color: rgba(54,179,255,.55);
	transform: translateY(0);
}

[data-theme="light"] .feed-yt-cfs-back {
	background: rgba(255,255,255,.82);
	border-color: rgba(86,110,138,.16);
	color: #1d2c3c;
}

[data-theme="light"] .feed-yt-cfs-back:hover {
	background: rgba(54,179,255,.14);
	border-color: rgba(54,179,255,.30);
	color: #10324a;
}

.feed-yt-cfs-btn-group--right {
	margin-left: auto;
	margin-right: 15px;
	display: flex;
	align-items: center;
	gap: 0;
}

/* ── 모바일 컨트롤 바 (<<, >>, 축소) ── */
.feed-yt-cfs-mobile-ctrl { display: none; }

.feed-yt-cfs-mini-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 4px;
	height: 34px;
	min-width: 34px;
	padding: 0 10px;
	border: 1px solid rgba(255,255,255,.32);
	border-radius: 8px;
	background: rgba(0,0,0,.22);
	color: #fff;
	font-size: 12px;
	font-weight: 700;
	cursor: pointer;
	backdrop-filter: blur(3px);
	-webkit-backdrop-filter: blur(3px);
	touch-action: manipulation;
	flex-shrink: 0;
	transition: background .15s, border-color .15s, color .15s, opacity .18s, transform .15s;
}

.feed-yt-cfs-mini-btn i {
	font-size: 12px;
	line-height: 1;
}

.feed-yt-cfs-mini-btn span {
	line-height: 1;
	white-space: nowrap;
}

.feed-yt-cfs-mini-btn:hover,
.feed-yt-cfs-mini-btn.is-open {
	background: rgba(30,167,255,.35);
	border-color: rgba(30,167,255,.6);
	color: #fff;
}

.feed-yt-cfs-mini-btn--panel {
	background: rgba(30,167,255,.34);
	border-color: rgba(30,167,255,.58);
	color: #fff;
	cursor: grab;
}

.feed-yt-cfs-mini-btn--panel:active {
	cursor: grabbing;
}

.feed-yt-cfs-mini-btn--panel.is-open {
	background: rgba(255,120,120,.24);
	border-color: rgba(255,120,120,.45);
}

.feed-yt-cfs-mini-btn--rate {
	min-width: 54px;
	padding: 0 11px;
	font-weight: 800;
	letter-spacing: -.2px;
}

.feed-yt-cfs-mini-extra {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	max-width: 0;
	opacity: 0;
	overflow: hidden;
	white-space: nowrap;
	pointer-events: none;
	transition: max-width .22s ease, opacity .18s ease;
}

.feed-yt-cfs-mobile-ctrl.is-open .feed-yt-cfs-mini-extra {
	max-width: 320px;
	opacity: 1;
	pointer-events: auto;
}

/* 세로영상: layer 하단 고정 바 */
.feed-yt-cfs-mobile-ctrl--bar {
	position: absolute;
	bottom: 0; left: 0; right: 0;
	height: 44px;
	display: flex;
	align-items: center;
	padding: 0 10px;
	background: rgba(0,0,0,.72);
	border-top: 1px solid rgba(255,255,255,.22);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	z-index: 9300;
}
/* mobile-ctrl--bar: --cfs-surface/border 변수로 통일 */


/* ── 모바일 CFS 미니 제어 패널 ── */
.feed-yt-cfs-mini-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 4px;
	height: 34px;
	min-width: 34px;
	padding: 0 10px;
	border: 1px solid rgba(255,255,255,.32);
	border-radius: 8px;
	background: rgba(0,0,0,.22);
	color: #fff;
	font-size: 12px;
	font-weight: 700;
	cursor: pointer;
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	touch-action: manipulation;
	flex-shrink: 0;
	transition: background .15s, border-color .15s, color .15s, transform .15s;
}

.feed-yt-cfs-mini-btn i {
	font-size: 12px;
	line-height: 1;
}

.feed-yt-cfs-mini-btn span {
	line-height: 1;
	white-space: nowrap;
}

/* hover 기본 */
.feed-yt-cfs-mini-btn:hover {
	background: rgba(30,167,255,.35);
	border-color: rgba(30,167,255,.6);
}

/* 패널 버튼 (기본 파란색 강조) */
.feed-yt-cfs-mini-btn--panel {
	background: rgba(30,167,255,.34);
	border-color: rgba(30,167,255,.58);
}

/* 패널 버튼 hover */
.feed-yt-cfs-mini-btn--panel:hover {
	background: rgba(30,167,255,.42);
	border-color: rgba(30,167,255,.72);
}

/* 패널 열림 상태 → 연한 붉은색 */
.feed-yt-cfs-mini-btn--panel.is-open,
.feed-yt-cfs-mini-btn--panel:active {
	background: rgba(255,120,120,.24);
	border-color: rgba(255,120,120,.45);
}

.feed-yt-cfs-mini-btn--rate {
	min-width: 54px;
	padding: 0 11px;
	font-weight: 800;
	letter-spacing: -.2px;
}

.feed-yt-cfs-drag-handle {
	width: 22px;
	height: 32px;
	padding: 0 4px;
	border: none;
	border-radius: 7px;
	background: rgba(0,0,0,.22);
	color: rgba(255,255,255,.72);
	font-size: 11px;
	border-right: none;
	margin-right: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	touch-action: none;
	flex-shrink: 0;
}

.feed-yt-cfs-drag-handle:active {
	cursor: grabbing;
	color: rgba(255,255,255,.95);
}

@media (max-width: 1023px) {
	.feed-yt-cfs-layer.is-landscape .feed-yt-cfs-mobile-ctrl {
		display: inline-flex;
		align-items: center;
		gap: 6px;
		position: absolute;
		right: 5px;
		bottom: 5px;
		z-index: 9300;
		padding: 5px;
		border-radius: 10px;
		pointer-events: auto;
		background: rgba(255,255,255,.20);
		backdrop-filter: blur(3px);
		-webkit-backdrop-filter: blur(3px);
		max-width: calc(100% - 10px);
		overflow: hidden;
		will-change: right, bottom;
		transition: right .25s cubic-bezier(.32,1,.6,1);
	}

	.feed-yt-cfs-layer.is-landscape .feed-yt-cfs-mobile-ctrl.is-dragging {
		transition: none !important;
	}

	.feed-yt-cfs-layer.is-landscape .feed-yt-cfs-mini-btn--panel span {
		display: inline;
	}

	.feed-yt-cfs-layer.is-landscape.panel-open .feed-yt-cfs-mobile-ctrl {
		right: calc(220px + 12px);
	}

	.feed-yt-cfs-layer.is-landscape.panel-open .feed-yt-cfs-panel-toggle {
		right: calc(220px + 5px);
	}
}

@media (max-width: 767px) {
	.feed-yt-cfs-mini-btn {
		height: 28px;
		min-width: 28px;
		padding: 0 7px;
		font-size: 11px;
	}

	.feed-yt-cfs-mini-btn i {
		font-size: 11px;
	}

	.feed-yt-cfs-drag-handle {
		width: 20px;
		height: 28px;
		font-size: 10px;
	}
}

.feed-yt-cfs-mini-btn--side {
	background: rgba(30,167,255,.34);
	border-color: rgba(255,255,255,.22);
	color: #fff;
}

.feed-yt-cfs-mini-btn--side:hover {
	background: rgba(54,179,255,.22);
	border-color: rgba(54,179,255,.42);
	color: #fff;
}

.feed-yt-cfs-mini-btn--side.is-open {
	background: rgba(255,120,120,.24);
	border-color: rgba(255,120,120,.45);
	color: #fff;
}

/* ── 회전 힌트 제거 ── */
.feed-yt-cfs-rotate-hint { display: none !important; }

/* back--mobile-always: 더 이상 사용 안 함 (mobile-ctrl로 통합) */
.feed-yt-cfs-back--mobile-always { display: none !important; }

/* ── CFS 탭 바 ── */
.cfs-tab-bar {
	display: flex;
	border-bottom: 1px solid rgba(161,192,255,.14);
	background: rgba(255,255,255,.03);
	flex-shrink: 0;
	position: sticky;
	top: 0;
	z-index: 10;
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}
[data-theme="light"] .cfs-tab-bar {
	background: rgba(255,255,255,.72);
	border-bottom-color: rgba(86,110,138,.10);
}

.cfs-tab-btn {
	flex: 1;
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: center;
	gap: 5px;
	padding: 10px 4px;
	font-size: 10px;
	font-weight: 500;
	color: var(--cfs-text-muted);
	background: none;
	border: none;
	border-bottom: 2px solid transparent;
	cursor: pointer;
	transition: color .15s, border-color .15s;
	position: relative;
	line-height: 1;
}
/* 아이콘만 표시, 텍스트 + 카운트 배지 숨김 */
.cfs-tab-btn i         { font-size: 13px; }
.cfs-tab-btn span      { display: inline; font-size: 11px; font-weight: 600; }
.cfs-tab-count         { font-size: 10px; font-weight: 700; color: var(--cfs-accent); margin-left: 2px; }
.cfs-tab-btn.cfs-tab-btn--active { color: var(--cfs-accent); border-bottom-color: var(--cfs-accent); }
.cfs-tab-btn:hover:not(.cfs-tab-btn--active):not(.cfs-tab-btn--disabled) { color: var(--cfs-text); }
.cfs-tab-btn--disabled { opacity: .35; cursor: not-allowed; }
[data-theme="light"] .cfs-tab-btn { color: rgba(0,0,0,.5); }
[data-theme="light"] .cfs-tab-btn.cfs-tab-btn--active {
	color: var(--cfs-accent);
	border-bottom-color: var(--cfs-accent);
	background: rgba(255,255,255,.6);
}
[data-theme="light"] .cfs-tab-btn:not(.cfs-tab-btn--active):hover { background: rgba(0,0,0,.06); color: rgba(0,0,0,.75); }

/* ── CFS 탭 패널 컨테이너 ── */
.cfs-tab-body {
	flex: 1 1 0%;
	height: 0;          /* flex 계산 강제 — min-height:0만으론 부족한 경우 대비 */
	min-height: 0;
	overflow: clip;
	display: flex;
	flex-direction: column;
	padding-bottom: 44px;
	box-sizing: border-box;
}
@media (max-width: 1023px) {
	.cfs-tab-body { padding-bottom: 0; }
}
.cfs-tab-body::-webkit-scrollbar { width: 4px; }
.cfs-tab-body::-webkit-scrollbar-thumb { background: rgba(255,255,255,.12); border-radius: 2px; }
.cfs-pane { display: none; }
.cfs-pane.cfs-pane--active {
	display: flex;
	flex-direction: column;
	flex: 1 1 0%;
	height: 0;
	min-height: 0;
	overflow: clip;
}

/* ── CFS 공통 유틸 ── */
.cfs-loading {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px;
	color: var(--cfs-text-muted);
	font-size: 16px;
}
.cfs-empty {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 6px;
	padding: 28px 16px;
	color: var(--cfs-text-muted);
	font-size: 12px;
	text-align: center;
}
.cfs-empty i { font-size: 22px; opacity: .5; }
[data-theme="light"] .cfs-loading,
[data-theme="light"] .cfs-empty { color: rgba(0,0,0,.4); }

/* ── CFS 댓글 탭 ── */
.cfs-pane[data-cfs-pane="comments"] { display: none; overflow: hidden; }
.cfs-pane.cfs-pane--active[data-cfs-pane="comments"] {
	display: flex; flex-direction: column;
	flex: 1 1 0%; height: 0; min-height: 0; overflow: hidden;
}

.cfs-comments-list {
	flex: 1 1 0%;
	height: 0;
	overflow-y: auto;
	overflow-x: hidden;
	scrollbar-width: thin;
	scrollbar-color: rgba(255,255,255,.12) transparent;
	min-height: 0;
}
.cfs-comments-list::-webkit-scrollbar { width: 4px; }
.cfs-comments-list::-webkit-scrollbar-thumb { background: rgba(255,255,255,.12); border-radius: 2px; }

.cfs-cmt-item {
	display: flex;
	gap: 8px;
	padding: 10px 12px;
	border-bottom: 1px solid var(--cfs-border);
}
[data-theme="light"] .cfs-cmt-item { border-bottom-color: rgba(0,0,0,.07); }

.cfs-cmt-avatar {
	width: 26px; height: 26px;
	border-radius: 50%;
	background: var(--cfs-surface);
	flex-shrink: 0;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 11px;
	color: var(--cfs-text-muted);
	object-fit: cover;
}
.cfs-cmt-avatar--empty { background: var(--cfs-surface); }
[data-theme="light"] .cfs-cmt-avatar,
[data-theme="light"] .cfs-cmt-avatar--empty { background: rgba(0,0,0,.1); color: rgba(0,0,0,.4); }

.cfs-cmt-body { flex: 1; min-width: 0; }
.cfs-cmt-meta { display: flex; align-items: center; gap: 6px; margin-bottom: 2px; }
.cfs-cmt-nick  { font-size: 12px; font-weight: 600; color: var(--cfs-text); }
.cfs-cmt-time  { font-size: 11px; color: var(--cfs-text-muted); margin-left: auto; }
.cfs-cmt-text  { font-size: 13px; color: var(--cfs-text); line-height: 1.5; word-break: break-word; }
.cfs-cmt-blinded { font-size: 11px; color: var(--cfs-text-muted); font-style: italic; }
[data-theme="light"] .cfs-cmt-nick    { color: rgba(0,0,0,.85); }
[data-theme="light"] .cfs-cmt-time    { color: rgba(0,0,0,.4); }
[data-theme="light"] .cfs-cmt-text    { color: rgba(0,0,0,.8); }
[data-theme="light"] .cfs-cmt-blinded { color: rgba(0,0,0,.35); }

.cfs-cmt-input-wrap {
	flex-shrink: 0;
	display: flex;
	align-items: flex-end;
	gap: 5px;
	padding: 8px 10px;
	border-top: 1px solid var(--cfs-border);
	background: rgba(12,12,18,.97);
}
[data-theme="light"] .cfs-cmt-input-wrap { background: #e4e7ed; border-top-color: rgba(0,0,0,.1); }
.cfs-cmt-textarea {
	flex: 1;
	padding: 6px 8px;
	border: 1px solid var(--cfs-border);
	border-radius: 6px;
	background: var(--cfs-bg-input);
	color: var(--cfs-text);
	font-size: 13px;
	resize: none;
	line-height: 1.45;
	outline: none;
	transition: border-color .15s;
	font-family: inherit;
	min-height: 32px;
	max-height: 100px;
	overflow-y: auto;
	box-sizing: border-box;
}
.cfs-cmt-textarea::placeholder { color: var(--cfs-text-muted); }
.cfs-cmt-textarea:focus { border-color: var(--cfs-accent); }
[data-theme="light"] .cfs-cmt-textarea {
	background: #fff;
	border-color: rgba(0,0,0,.18);
	color: rgba(0,0,0,.85);
}
[data-theme="light"] .cfs-cmt-textarea::placeholder { color: rgba(0,0,0,.3); }

.cfs-cmt-submit {
	width: 32px; height: 32px;
	flex-shrink: 0;
	border-radius: 7px;
	background: var(--cfs-accent);
	color: #fff;
	border: none;
	cursor: pointer;
	font-size: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: opacity .15s;
}
.cfs-cmt-submit:disabled { opacity: .4; cursor: default; }

/* ── CFS 태깅 탭 ── */
/* ── CFS 태깅 탭 ── */
.cfs-tag-panel {
	padding: 12px;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.cfs-no-video {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	padding: 36px 16px;
	color: var(--cfs-text-muted);
	font-size: 12px;
	text-align: center;
}
.cfs-no-video i { font-size: 26px; opacity: .45; }

/* 필드 행 — create.php .fc-field 스타일 */
.cfs-field-row {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.cfs-label {
	font-size: 11px;
	font-weight: 600;
	color: var(--cfs-text-muted);
}

/* select — create.php .fc-input 스타일 */
.cfs-select {
	width: 100%;
	height: 36px;
	padding: 0 10px;
	border: 1px solid var(--cfs-border);
	border-radius: 8px;
	background: var(--cfs-bg-input);
	color: var(--cfs-text);
	font-size: 12px;
	outline: none;
	transition: border-color .15s, background .15s;
	box-sizing: border-box;
	cursor: pointer;
}
.cfs-select:focus { border-color: var(--cfs-accent); }
.cfs-select option { background: var(--bg, #0f172a); color: var(--text, #fff); }

/* 시간 행 */
.cfs-time-row {
	display: flex;
	align-items: center;
	gap: 6px;
}
.cfs-time-val {
	flex: 1;
	font-size: 11px;
	font-weight: 700;
	color: var(--cfs-accent);
	font-family: monospace;
	text-align: center;
	background: var(--cfs-accent-faint);
	border: 1px solid var(--cfs-accent-dim);
	border-radius: 6px;
	padding: 6px 4px;
	min-width: 0;
}
.cfs-time-btn {
	padding: 5px 10px;
	font-size: 11px;
	border: 1px solid var(--blade);
	border-radius: 5px;
	background: var(--cfs-bg-input);
	color: var(--blade);
	cursor: pointer;
	white-space: nowrap;
	transition: all .12s;
	flex-shrink: 0;
}
.cfs-time-btn:hover {  background: rgba(10,132,200,.08);border-color: var(--cfs-accent); color: var(--cfs-accent); }
.cfs-time-btn.is-set { background: var(--blade); color: #fff; border-color: var(--cfs-accent); }

/* 메모 textarea */
.cfs-memo-ta {
	width: 100%;
	padding: 8px 10px;
	border: 1px solid var(--cfs-border);
	border-radius: 8px;
	background: var(--cfs-bg-input);
	color: var(--cfs-text);
	font-size: 12px;
	resize: none;
	outline: none;
	font-family: inherit;
	line-height: 1.5;
	transition: border-color .15s;
	min-height: 48px;
	box-sizing: border-box;
}
.cfs-memo-ta::placeholder { color: var(--cfs-text-muted); font-size: 11px; }
.cfs-memo-ta:focus { border-color: var(--cfs-accent); }

/* 구간 추가 버튼 */
.cfs-btn-add {
	width: 100%;
	height: 38px;
	border-radius: 8px;
	font-size: 13px;
	font-weight: 700;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 5px;
	border: none;
	background: var(--cfs-accent);
	color: #fff;
	transition: opacity .15s;
}
.cfs-btn-add:hover { opacity: .88; }
.cfs-btn-add:disabled { opacity: .4; cursor: default; }

/* 저장 버튼 */
.cfs-btn-save {
	width: 100%;
	height: 36px;
	border-radius: 8px;
	font-size: 12px;
	font-weight: 700;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 5px;
	border: none;
	background: #10b981;
	color: #fff;
	transition: opacity .15s;
	margin-top: 2px;
}
.cfs-btn-save:hover { opacity: .88; }
.cfs-btn-save:disabled { opacity: .4; cursor: default; }
.cfs-save-cnt { font-size: 10px; background: rgba(255,255,255,.25); border-radius: 8px; padding: 1px 5px; }

/* ── CFS 버퍼 목록 ── */
.cfs-buffer-list { display: flex; flex-direction: column; gap: 4px; }
.cfs-buf-item {
	background: var(--cfs-accent-faint);
	border: 1px dashed var(--cfs-accent-dim);
	border-radius: 6px;
	padding: 7px 9px;
	font-size: 11px;
	color: var(--cfs-text);
	animation: cfsBufIn .16s ease;
}
@keyframes cfsBufIn {
	from { opacity: 0; transform: translateY(-3px); }
	to   { opacity: 1; transform: translateY(0); }
}
[data-theme="light"] .cfs-buf-item {
	background: rgba(10,132,200,.06);
	border-color: rgba(10,132,200,.2);
	color: rgba(0,0,0,.8);
}
.cfs-buf-main { display: flex; align-items: center; gap: 4px; margin-bottom: 3px; }
.cfs-buf-player {
	font-size: 12px;
	font-weight: 600;
	color: var(--cfs-text);
	flex: 1;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
[data-theme="light"] .cfs-buf-player { color: rgba(0,0,0,.85); }
.cfs-buf-tag {
	font-size: 10px;
	font-weight: 600;
	background: var(--cfs-accent-dim);
	color: var(--cfs-accent);
	border-radius: 3px;
	padding: 1px 5px;
	white-space: nowrap;
	flex-shrink: 0;
}
[data-theme="light"] .cfs-buf-tag { background: rgba(10,132,200,.12); }
.cfs-buf-del {
	background: none;
	border: none;
	color: var(--cfs-text-muted);
	cursor: pointer;
	font-size: 12px;
	padding: 1px;
	flex-shrink: 0;
	transition: color .12s;
}
.cfs-buf-del:hover { color: #ef4444; }
[data-theme="light"] .cfs-buf-del { color: rgba(0,0,0,.3); }
.cfs-buf-times {
	display: flex;
	align-items: center;
	gap: 4px;
	font-family: monospace;
	font-size: 10px;
	color: var(--cfs-accent);
}
[data-theme="light"] .cfs-buf-times { color: var(--cfs-accent); }
.cfs-buf-time-sep { color: var(--cfs-text-muted); }
[data-theme="light"] .cfs-buf-time-sep { color: rgba(0,0,0,.3); }
.cfs-buf-memo { font-size: 10px; color: var(--cfs-text-muted); font-style: italic; margin-top: 2px; }
[data-theme="light"] .cfs-buf-memo { color: rgba(0,0,0,.45); }

/* ── CFS 저장된 구간 탭 ── */
.cfs-loop-bar {
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 7px 12px;
	background: var(--cfs-surface);
	border-bottom: 1px solid var(--cfs-border);
}
[data-theme="light"] .cfs-loop-bar { background: rgba(0,0,0,.04); border-bottom-color: rgba(0,0,0,.07); }
.cfs-loop-label { flex: 1; font-size: 10px; font-family: monospace; color: var(--cfs-text-muted); }
[data-theme="light"] .cfs-loop-label { color: rgba(0,0,0,.5); }
.cfs-loop-btn {
	padding: 3px 8px;
	font-size: 10px;
	font-weight: 600;
	border: 1px solid var(--cfs-border);
	border-radius: 4px;
	background: none;
	color: var(--cfs-text-muted);
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: 3px;
	transition: all .12s;
	white-space: nowrap;
}
.cfs-loop-btn:hover { border-color: var(--cfs-accent); color: var(--cfs-accent); }
.cfs-loop-btn--active { background: var(--cfs-accent) !important; color: #fff !important; border-color: var(--cfs-accent) !important; }

.cfs-filter-bar {
	display: flex;
	gap: 6px;
	padding: 8px 10px 6px;
	border-bottom: 1px solid var(--cfs-border);
}
[data-theme="light"] .cfs-filter-bar { background: rgba(0,0,0,.04); border-bottom-color: rgba(0,0,0,.07); }
.cfs-filter-sel {
	flex: 1;
	height: 30px;
	padding: 0 7px;
	border: 1px solid var(--cfs-border);
	border-radius: 5px;
	background: var(--cfs-bg-input);
	color: var(--cfs-text);
	font-size: 11px;
	outline: none;
}
.cfs-filter-sel:focus { border-color: var(--cfs-accent); }
.cfs-filter-sel option { background: #1a1a2e; }
[data-theme="light"] .cfs-filter-sel {
	background: #fff;
	border-color: rgba(0,0,0,.18);
	color: rgba(0,0,0,.8);
}

.cfs-saved-list { display: flex; flex-direction: column; gap: 1px; padding: 4px 0 8px; }

/* ── saved 탭 레이아웃 ──
   구조: pane(flex col) > hd(고정) + scroll(flex:1) + open-btn(고정) + input-fixed(숨김→표시)
── */
.cfs-pane[data-cfs-pane="saved"]           { display: none; }
.cfs-pane.cfs-pane--active[data-cfs-pane="saved"] {
	display: flex;
	flex-direction: column;
	flex: 1 1 0%;
	height: 0;
	min-height: 0;
	overflow: clip;
}

/* 고정 헤더: 루프바 + 필터바 */
.cfs-saved-hd {
	flex-shrink: 0;
}

/* 스크롤 목록 영역 */
.cfs-saved-scroll {
	flex: 1 1 0%;
	height: 0;
	min-height: 0;
	overflow-y: auto;
	overflow-x: hidden;
	-webkit-overflow-scrolling: touch;
	overscroll-behavior: contain;
	scrollbar-width: thin;
	scrollbar-color: rgba(255,255,255,.12) transparent;
}
.cfs-saved-scroll::-webkit-scrollbar { width: 4px; }
.cfs-saved-scroll::-webkit-scrollbar-thumb { background: rgba(255,255,255,.12); border-radius: 2px; }

/* 하단 고정: "피드백 입력하기" 버튼 */
.cfs-fb-open-btn {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	width: 100%;
	padding: 11px 12px;
	background: var(--cfs-accent);
	border: none;
	border-top: 2px solid rgba(10,132,200,.4);
	color: #fff;
	font-size: 13px;
	font-weight: 700;
	cursor: pointer;
	transition: opacity .15s;
	letter-spacing: .02em;
}
.cfs-fb-open-btn:hover  { opacity: .88; }
.cfs-fb-open-btn:active { opacity: .75; }
[data-theme="light"] .cfs-fb-open-btn {
	background: var(--blade);
	border-top-color: rgba(52,180,255,.3);
	color: #fff;
}

/* 닫기 버튼 */
.cfs-fb-input-close {
	background: none;
	border: none;
	color: var(--cfs-text-muted);
	font-size: 14px;
	cursor: pointer;
	padding: 2px 4px;
	border-radius: 4px;
	transition: color .12s, background .12s;
	flex-shrink: 0;
}
.cfs-fb-input-close:hover { color: var(--cfs-text); background: rgba(255,255,255,.08); }

.cfs-seg-item {
	display: flex;
	flex-direction: column;
	padding: 8px;
	border-radius: 0;
	border-bottom: 1px solid var(--cfs-border);
	cursor: pointer;
	transition: background .12s;
	gap: 3px;
}
[data-theme="light"] .cfs-seg-item { border-bottom-color: rgba(0,0,0,.06); }

.cfs-seg-item:hover { background: var(--cfs-surface); }
.cfs-seg-item.cfs-seg-item--active {
	background: var(--cfs-accent-faint);
	outline: 1px solid var(--cfs-accent-dim);
}
[data-theme="light"] .cfs-seg-item:hover { background: rgba(0,0,0,.04); }
[data-theme="light"] .cfs-seg-item--active { background: rgba(10,132,200,.08); outline-color: rgba(10,132,200,.25); }

.cfs-seg-line1 {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 4px;
	width: 100%;
	min-width: 0;
}
/* 좌측: 번호+이름 + 태그 */
.cfs-seg-left {
	display: flex;
	align-items: center;
	gap: 5px;
	min-width: 0;
	flex: 1;
	overflow: hidden;
}
.cfs-seg-player {
	font-size: 12px;
	font-weight: 600;
	color: var(--cfs-text);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	max-width: 90px;
	flex-shrink: 1;
}
.cfs-seg-player--team { color: var(--cfs-accent); }
[data-theme="light"] .cfs-seg-player { color: rgba(0,0,0,.85); }
[data-theme="light"] .cfs-seg-player--team { color: var(--cfs-accent); }

.cfs-seg-tag {
	font-size: 10px;
	font-weight: 600;
	background: var(--cfs-accent-dim);
	color: #3aabdf;
	border-radius: 3px;
	padding: 2px 5px;
	white-space: nowrap;
	flex-shrink: 0;
}
[data-theme="light"] .cfs-seg-tag { color: var(--cfs-accent); background: rgba(10,132,200,.12); }

.cfs-seg-memo {
	font-size: 11px;
	color: var(--cfs-text-muted);
	font-style: italic;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
[data-theme="light"] .cfs-seg-memo { color: rgba(0,0,0,.45); }

/* 우측: 댓글뱃지 + 삭제버튼 */
.cfs-seg-actions {
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: 4px;
	flex-shrink: 0;
}
.cfs-seg-fb-count { font-size: 10px; color: var(--cfs-text-muted); display: flex; align-items: center; gap: 2px; white-space: nowrap; }
.cfs-seg-fb-count--has { color: var(--cfs-accent); font-weight: 600; }
[data-theme="light"] .cfs-seg-fb-count     { color: rgba(0,0,0,.4); }
[data-theme="light"] .cfs-seg-fb-count--has { color: var(--cfs-accent); }

.cfs-seg-del-btn {
	background: none;
	border: none;
	color: var(--cfs-text-muted);
	cursor: pointer;
	font-size: 12px;
	padding: 2px;
	border-radius: 3px;
	transition: color .12s;
	display: flex;
	align-items: center;
}
.cfs-seg-del-btn:hover { color: #ef4444; }
[data-theme="light"] .cfs-seg-del-btn       { color: rgba(0,0,0,.25); }
[data-theme="light"] .cfs-seg-del-btn:hover { color: #ef4444; }

/* 구간 수정 버튼 */
.cfs-seg-edit-btn {
	background: none;
	border: none;
	color: var(--cfs-text-muted);
	cursor: pointer;
	font-size: 11px;
	padding: 2px 4px;
	border-radius: 3px;
	transition: color .12s;
	display: flex;
	align-items: center;
}
.cfs-seg-edit-btn:hover { color: var(--cfs-accent); }
[data-theme="light"] .cfs-seg-edit-btn       { color: rgba(0,0,0,.25); }
[data-theme="light"] .cfs-seg-edit-btn:hover { color: var(--cfs-accent); }

/* 구간 인라인 수정 폼 */
.cfs-seg-edit-form {
	margin-top: 6px;
	padding: 8px;
	background: rgba(255,255,255,.05);
	border-radius: 6px;
	display: flex;
	flex-direction: column;
	gap: 6px;
}
[data-theme="light"] .cfs-seg-edit-form { background: rgba(0,0,0,.04); }
.cfs-seg-edit-tag,
.cfs-seg-edit-memo {
	width: 100%;
	padding: 5px 8px;
	border: 1px solid var(--cfs-border);
	border-radius: 6px;
	background: var(--cfs-bg-input);
	color: var(--cfs-text);
	font-size: 12px;
	box-sizing: border-box;
}
.cfs-seg-edit-btns { display: flex; gap: 6px; }
.cfs-seg-edit-save,
.cfs-seg-edit-cancel {
	flex: 1;
	padding: 5px 0;
	border-radius: 6px;
	border: none;
	font-size: 12px;
	font-weight: 600;
	cursor: pointer;
}
.cfs-seg-edit-save   { background: var(--cfs-accent); color: #fff; }
.cfs-seg-edit-cancel { background: rgba(255,255,255,.08); color: var(--cfs-text); }
[data-theme="light"] .cfs-seg-edit-cancel { background: rgba(0,0,0,.07); }

.cfs-seg-edit-btn {
	background: none;
	border: none;
	color: var(--cfs-text-muted);
	cursor: pointer;
	font-size: 11px;
	padding: 2px 4px;
	border-radius: 3px;
	transition: color .12s;
	display: flex;
	align-items: center;
}
.cfs-seg-edit-btn:hover { color: var(--cfs-accent); }
[data-theme="light"] .cfs-seg-edit-btn       { color: rgba(0,0,0,.25); }
[data-theme="light"] .cfs-seg-edit-btn:hover { color: var(--cfs-accent); }

.cfs-seg-edit-form {
	margin-top: 6px;
	padding: 8px;
	background: rgba(255,255,255,.05);
	border-radius: 6px;
	display: flex;
	flex-direction: column;
	gap: 6px;
}
[data-theme="light"] .cfs-seg-edit-form {
	background: rgba(0,0,0,.04);
}
.cfs-seg-edit-tag,
.cfs-seg-edit-memo {
	width: 100%;
	padding: 5px 8px;
	border: 1px solid var(--cfs-border);
	border-radius: 6px;
	background: var(--cfs-bg-input);
	color: var(--cfs-text);
	font-size: 12px;
	box-sizing: border-box;
}
.cfs-seg-edit-btns {
	display: flex;
	gap: 6px;
}
.cfs-seg-edit-save,
.cfs-seg-edit-cancel {
	flex: 1;
	padding: 5px 0;
	border-radius: 6px;
	border: none;
	font-size: 12px;
	font-weight: 600;
	cursor: pointer;
}
.cfs-seg-edit-save   { background: var(--cfs-accent); color: #fff; }
.cfs-seg-edit-cancel { background: rgba(255,255,255,.08); color: var(--cfs-text); }
[data-theme="light"] .cfs-seg-edit-cancel { background: rgba(0,0,0,.07); }

/* CFS 전체 피드백 섹션 */
.cfs-post-fb-section {
	border-top: 6px solid rgba(255,255,255,.06);
	margin-top: 8px;
}
[data-theme="light"] .cfs-post-fb-section {
	border-top: 6px solid rgba(0,0,0,.07);
}

.cfs-post-fb-header {
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 10px 12px 8px;
	font-size: 12px;
	font-weight: 700;
	color: var(--cfs-text);
	letter-spacing: .02em;
	background: rgba(255,255,255,.04);
	border-bottom: 1px solid var(--cfs-border);
}
.cfs-post-fb-header i { color: var(--cfs-accent); }
[data-theme="light"] .cfs-post-fb-header {
	color: rgba(0,0,0,.65);
	background: rgba(0,0,0,.04);
	border-bottom-color: rgba(0,0,0,.08);
}

.cfs-post-fb-count {
	font-size: 10px;
	background: var(--cfs-accent-dim);
	color: var(--cfs-accent);
	border-radius: 8px;
	padding: 1px 6px;
	font-weight: 700;
}
[data-theme="light"] .cfs-post-fb-count { background: rgba(10,132,200,.15); }

.cfs-post-fb-list { display: flex; flex-direction: column; }
.cfs-post-fb-item {
	display: flex;
	gap: 8px;
	padding: 7px 12px;
	border-top: 1px solid var(--cfs-border);
}
[data-theme="light"] .cfs-post-fb-item { border-top-color: rgba(0,0,0,.06); }

.cfs-post-fb-meta {
	display: flex;
	align-items: center;
	gap: 4px;
	flex-wrap: nowrap;
	margin-bottom: 3px;
}
.cfs-post-fb-right { display: flex; align-items: center; gap: 3px; margin-left: auto; flex-shrink: 0; }
.cfs-post-fb-del-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 18px; height: 18px;
	background: none;
	border: none;
	cursor: pointer;
	color: var(--cfs-text-muted);
	font-size: 10px;
	border-radius: 3px;
	padding: 0;
	transition: color .12s, background .12s;
}
.cfs-post-fb-del-btn:hover { color: #ef4444; background: rgba(239,68,68,.1); }
[data-theme="light"] .cfs-post-fb-del-btn       { color: rgba(0,0,0,.2); }
[data-theme="light"] .cfs-post-fb-del-btn:hover { color: #ef4444; background: rgba(239,68,68,.08); }

/* 구간 피드백 인라인 패널 */
.cfs-seg-fb-panel {
	background: var(--cfs-accent-faint);
	border-left: 2px solid rgba(10,132,200,.4);
	margin: 1px 8px 4px 5px;
	border-radius: 0 6px 6px 0;
	padding: 8px 10px;
	animation: cfsFbIn .2s ease-out;
}
@keyframes cfsFbIn {
	from { opacity: 0; transform: translateY(-4px); }
	to   { opacity: 1; transform: translateY(0); }
}
[data-theme="light"] .cfs-seg-fb-panel { background: rgba(10,132,200,.04); border-left-color: rgba(10,132,200,.3); }

.cfs-seg-fb-list { display: flex; flex-direction: column; gap: 8px; }

/* ── CFS 피드백 아이템 ── */
.cfs-fb-item { display: flex; gap: 6px; }
.cfs-fb-avatar {
	width: 22px; height: 22px;
	border-radius: 50%;
	background: var(--cfs-surface);
	flex-shrink: 0;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 10px;
	color: var(--cfs-text-muted);
}
.cfs-fb-avatar img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
[data-theme="light"] .cfs-fb-avatar { background: rgba(0,0,0,.08); color: rgba(0,0,0,.4); }

.cfs-fb-body { flex: 1; min-width: 0; }
.cfs-fb-meta {
	display: flex;
	align-items: center;
	gap: 4px;
	flex-wrap: nowrap;
	margin-bottom: 2px;
}
.cfs-fb-meta-right { display: flex; align-items: center; gap: 3px; margin-left: auto; flex-shrink: 0; }
.cfs-fb-nick { font-size: 11px; font-weight: 600; color: var(--cfs-text); flex-shrink: 0; }
.cfs-fb-role { font-size: 10px; padding: 1px 4px; border-radius: 2px; font-weight: 600; flex-shrink: 0; }
.cfs-fb-role--director { background: rgba(109,40,217,.25); color: #c4b5fd; }
.cfs-fb-role--coach    { background: rgba(29,78,216,.25);  color: #93c5fd; }
.cfs-fb-role--player   { background: rgba(6,95,70,.25);    color: #6ee7b7; }
.cfs-fb-role--self     { background: rgba(146,64,14,.25);  color: #fde68a; }
.cfs-fb-scope {
	font-size: 10px;
	color: var(--cfs-text-muted);
	background: var(--cfs-surface);
	border: 1px solid var(--cfs-border);
	border-radius: 3px;
	padding: 0 4px;
	flex-shrink: 0;
}
.cfs-fb-time { font-size: 10px; color: var(--cfs-text-muted); margin-left: auto; flex-shrink: 0; }
.cfs-fb-text { font-size: 12px; color: var(--cfs-text-muted); line-height: 1.5; word-break: break-word; }
.cfs-fb-empty { padding: 10px 0; text-align: center; font-size: 11px; color: var(--cfs-text-muted); }

[data-theme="light"] .cfs-fb-nick  { color: rgba(0,0,0,.85); }
[data-theme="light"] .cfs-fb-time  { color: rgba(0,0,0,.4); }
[data-theme="light"] .cfs-fb-text  { color: rgba(0,0,0,.7); }
[data-theme="light"] .cfs-fb-scope { color: rgba(0,0,0,.45); background: rgba(0,0,0,.06); border-color: rgba(0,0,0,.1); }
[data-theme="light"] .cfs-fb-empty { color: rgba(0,0,0,.4); }

.cfs-fb-del-btn {
	flex-shrink: 0;
	align-self: flex-start;
	background: none;
	border: none;
	color: var(--cfs-text-muted);
	cursor: pointer;
	font-size: 10px;
	padding: 2px 3px;
	border-radius: 3px;
	transition: color .12s, background .12s;
	line-height: 1;
	margin-left: 4px;
}
.cfs-fb-del-btn:hover { color: #ef4444; background: rgba(239,68,68,.12); }
[data-theme="light"] .cfs-fb-del-btn       { color: rgba(0,0,0,.22); }
[data-theme="light"] .cfs-fb-del-btn:hover { color: #ef4444; background: rgba(239,68,68,.08); }

.cfs-fb-text-row { display: flex; align-items: flex-start; gap: 2px; }
.cfs-fb-text-row .cfs-fb-text { flex: 1; min-width: 0; }

/* ── CFS 피드백 입력폼 ── */
.cfs-fb-input-fixed {
	display: none;
	flex-shrink: 0;
	flex-direction: column;
	gap: 10px;
	background: var(--surface, rgba(10,15,28,.98));
	border-top: 2px solid var(--cfs-accent);
	padding: 12px 14px 14px;
	z-index: 20;
}
.cfs-fb-input-fixed.is-visible { display: flex; }

.cfs-fb-input-fixed--disabled .cfs-fb-textarea,
.cfs-fb-input-fixed--disabled .cfs-fb-scope-sel,
.cfs-fb-input-fixed--disabled .cfs-fb-submit { opacity: .35; pointer-events: none; }

/* 헤더: 피드백 레이블 + 구간/전체 토글 */
.cfs-fb-input-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
	padding-bottom: 10px;
	border-bottom: 1px solid var(--cfs-border);
}
.cfs-fb-input-label {
	font-size: 12px;
	font-weight: 700;
	color: var(--cfs-text);
	display: flex;
	align-items: center;
	gap: 5px;
	white-space: nowrap;
	flex-shrink: 0;
}
.cfs-fb-input-label i { color: var(--cfs-accent); }

/* 구간/전체 토글 — create.php .fc-type-toggle 동일 스타일 */
.cfs-fb-type-toggle {
	display: flex;
	gap: 0;
	border: 1px solid var(--cfs-border);
	border-radius: 10px;
	overflow: hidden;
	flex-shrink: 0;
}
.cfs-fb-type-btn {
	flex: 1;
	padding: 6px 16px;
	font-size: 12px;
	font-weight: 600;
	border: none;
	background: var(--cfs-surface);
	color: var(--cfs-text-muted);
	cursor: pointer;
	transition: background .15s, color .15s;
	white-space: nowrap;
	text-align: center;
}
.cfs-fb-type-btn--active { background: var(--cfs-accent); color: #fff; }
.cfs-fb-type-btn:not(.cfs-fb-type-btn--active):hover { opacity: .85; }

/* 닫기 버튼 (헤더 오른쪽) */
.cfs-fb-input-close {
	background: none;
	border: none;
	color: var(--cfs-text-muted);
	font-size: 14px;
	cursor: pointer;
	padding: 3px 6px;
	border-radius: 6px;
	transition: color .12s, background .12s;
	flex-shrink: 0;
}
.cfs-fb-input-close:hover { color: var(--cfs-text); background: var(--cfs-surface); }

/* 구간 정보 표시 */
.cfs-fb-seg-info {
	font-size: 11px;
	color: var(--cfs-accent);
	background: var(--cfs-accent-faint);
	border: 1px solid var(--cfs-accent-dim);
	border-radius: 6px;
	padding: 5px 10px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* 공개범위 셀렉트 */
.cfs-fb-scope-sel {
	height: 36px;
	padding: 0 10px;
	border: 1px solid var(--cfs-border);
	border-radius: 8px;
	background: var(--cfs-bg-input);
	color: var(--cfs-text);
	font-size: 12px;
	font-weight: 500;
	outline: none;
	width: 100%;
	box-sizing: border-box;
	cursor: pointer;
	transition: border-color .15s;
}
.cfs-fb-scope-sel:focus { border-color: var(--cfs-accent); }
.cfs-fb-scope-sel option { background: var(--bg, #0f172a); color: var(--text, #fff); }

/* 입력행 */
.cfs-fb-input-row { display: flex; align-items: flex-end; gap: 8px; }

/* textarea */
.cfs-fb-textarea {
	flex: 1;
	padding: 9px 11px;
	border: 1px solid var(--cfs-border);
	border-radius: 8px;
	background: var(--cfs-bg-input);
	color: var(--cfs-text);
	font-size: 13px;
	resize: none;
	line-height: 1.5;
	outline: none;
	transition: border-color .15s, background .15s;
	font-family: inherit;
	min-height: 64px;
	max-height: 120px;
	overflow-y: auto;
	box-sizing: border-box;
}
.cfs-fb-textarea::placeholder { color: var(--cfs-text-muted); font-size: 12px; }
.cfs-fb-textarea:focus { border-color: var(--cfs-accent); }

/* 제출 버튼 */
.cfs-fb-submit {
	width: 38px;
	min-height: 64px;
	align-self: stretch;
	flex-shrink: 0;
	border-radius: 8px;
	background: var(--cfs-accent);
	color: #fff;
	border: none;
	cursor: pointer;
	font-size: 14px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: opacity .15s;
}
.cfs-fb-submit:hover { opacity: .88; }
.cfs-fb-submit:disabled { opacity: .4; cursor: default; }


/* ══════════════════════════════════════════════
   이미지 뷰어 (전체화면)
══════════════════════════════════════════════ */
#feed-img-viewer {
	position: fixed;
	inset: 0;
	z-index: 500;
	background: rgba(0,0,0,.96);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	transform: translateY(100%);
	visibility: hidden;
	transition: transform .3s cubic-bezier(.32,1,.6,1), visibility 0s linear .3s;
	touch-action: none;
}
#feed-img-viewer.is-open {
	transform: translateY(0);
	visibility: visible;
	transition: transform .3s cubic-bezier(.32,1,.6,1), visibility 0s linear 0s;
}
.feed-img-viewer-close {
	position: absolute;
	top: max(16px, env(safe-area-inset-top));
	right: 16px;
	width: 36px; height: 36px;
	border-radius: 50%;
	border: none;
	background: rgba(255,255,255,.15);
	color: #fff;
	font-size: 16px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 10;
	transition: background var(--transition);
}
.feed-img-viewer-close:hover { background: rgba(255,255,255,.28); }
.feed-img-viewer-track {
	display: flex;
	width: 100%; height: 100%;
	transition: transform .3s cubic-bezier(.32,1,.6,1);
	cursor: default;
}
.feed-img-viewer-slide {
	flex: 0 0 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 48px 16px;
	overflow: hidden;
	touch-action: pinch-zoom;
}
.feed-img-viewer-zoom-wrap {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%; height: 100%;
	overflow: hidden;
}
.feed-img-viewer-image {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
	border-radius: 4px;
	touch-action: pinch-zoom;
	user-select: none;
	transform-origin: center center;
	will-change: transform;
}
.feed-img-viewer-dots {
	position: absolute;
	bottom: max(24px, env(safe-area-inset-bottom));
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	gap: 6px;
}
.feed-img-viewer-dot {
	width: 7px; height: 7px;
	border-radius: 50%;
	border: none;
	background: rgba(255,255,255,.4);
	cursor: pointer;
	padding: 0;
	transition: background .2s, transform .2s;
}
.feed-img-viewer-dot.is-active { background: #fff; transform: scale(1.35); }

.feed-viewer-btn {
	position: fixed;
	top: 50%;
	transform: translateY(-50%);
	width: 44px; height: 44px;
	border-radius: 50%;
	border: none;
	background: rgba(255,255,255,.18);
	color: #fff;
	font-size: 18px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 1010;
	transition: background .18s;
	backdrop-filter: blur(6px);
	user-select: none;
}
.feed-viewer-prev { left: 14px; }
.feed-viewer-next { right: 14px; }
.feed-viewer-btn:hover { background: rgba(255,255,255,.32); }

/* ══════════════════════════════════════════════
   토스트
══════════════════════════════════════════════ */
#feed-toast {
	position: fixed;
	bottom: 80px;
	left: 50%;
	transform: translateX(-50%) translateY(8px);
	background: var(--dark);
	color: #fff;
	font-size: 13px;
	padding: 9px 18px;
	border-radius: 20px;
	pointer-events: none;
	opacity: 0;
	transition: opacity .22s, transform .22s;
	z-index: 600;
	white-space: nowrap;
}
#feed-toast.is-show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ══════════════════════════════════════════════
   스켈레톤
══════════════════════════════════════════════ */
@keyframes skel-shine {
	0%   { background-position: -800px 0; }
	100% { background-position:  800px 0; }
}

/* ── 공용 shimmer 베이스 ── */
.feed-skel {
	background: linear-gradient(
		90deg,
		var(--surface-soft) 25%,
		rgba(255,255,255,.55) 50%,
		var(--surface-soft) 75%
	);
	background-size: 1600px 100%;
	animation: skel-shine 1.4s infinite linear;
	border-radius: 6px;
	flex-shrink: 0;
}
[data-theme="dark"] .feed-skel {
	background: linear-gradient(
		90deg,
		rgba(17,34,58,.8)  25%,
		rgba(35,58,90,.5)  50%,
		rgba(17,34,58,.8)  75%
	);
	background-size: 1600px 100%;
}

/* ── 목록 카드 스켈레톤 ── */
.feed-card--skel { pointer-events: none; cursor: default; }
.feed-skel--avatar  { width: 36px; height: 36px; border-radius: 50%; flex-shrink: 0; }
.feed-skel--nick    { width: 90px;  height: 13px; margin-top: 2px; }
.feed-skel--date    { width: 44px;  height: 11px; }
.feed-skel--thumb   { width: 100%; aspect-ratio: 16/9; border-radius: 10px; margin: 8px 0; }
.feed-skel--body    { width: 78%;   height: 13px; margin-bottom: 6px; }
.feed-card-footer--skel { display: flex; gap: 12px; }
.feed-skel--action  { width: 52px;  height: 13px; }

/* ── 상세 레이어 본문 스켈레톤 ── */
.feed-detail-body-skel {
	padding: 12px 16px 8px;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.feed-skel--match-card        { width: 100%; height: 76px; border-radius: 10px; }
.feed-skel--detail-text       { width: 92%;  height: 14px; }
.feed-skel--detail-text-short { width: 60%;  height: 14px; }
.feed-detail-action-skel      { display: flex; gap: 16px; margin-top: 4px; }
.feed-skel--action-btn        { width: 48px; height: 18px; }

/* ── CFS / 댓글 / 구간 스켈레톤 행 ── */
.cfs-skel-row {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 10px 12px;
	border-bottom: 1px solid var(--hd-drawer-border);
}
.cfs-skel-avatar {
	width: 30px; height: 30px;
	border-radius: 50%;
	flex-shrink: 0;
}
.cfs-skel-lines {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 7px;
	padding-top: 2px;
}
.cfs-skel-line         { height: 12px; border-radius: 5px; }
.cfs-skel-line--name   { width: 55%; }
.cfs-skel-line--text   { width: 85%; }

/* ══════════════════════════════════════════════
   오버레이 (상세 레이어 딤)
══════════════════════════════════════════════ */
.feed-overlay {
	display: none;
	position: fixed;
	inset: 0;
	background: rgba(0,0,0,.4);
	backdrop-filter: blur(3px);
	z-index: 299;
	opacity: 0;
	transition: opacity .2s;
}
.feed-overlay.is-open { display: block; opacity: 1; }
@media (min-width: 768px) {
	.feed-overlay { display: block; pointer-events: none; opacity: 0; }
	.feed-overlay.is-open { pointer-events: auto; opacity: 1; }
}

/* ══════════════════════════════════════════════
   더보기 컨텍스트 메뉴
══════════════════════════════════════════════ */
.feed-ctx-menu {
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: min(360px, calc(100vw - 32px));
	background: var(--surface-strong, #fff);
	border-top: none;
	border-radius: 16px;
	padding: 8px;
	z-index: 400;
	display: flex;
	flex-direction: column;
	box-shadow: 0 8px 32px rgba(0,0,0,.18);
}
[data-theme="dark"] .feed-ctx-menu { background: rgba(9,19,33,.98); }
.feed-ctx-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.3); backdrop-filter: blur(6px);  -webkit-backdrop-filter: blur(6px); z-index: 399; }
.feed-ctx-item {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 14px 16px;
	font-size: 14px;
	font-weight: 500;
	color: var(--text);
	background: transparent;
	border: none;
	border-radius: 12px;
	cursor: pointer;
	transition: background var(--transition), color var(--transition);
	text-align: left;
}
.feed-ctx-item:hover { background: var(--bladeL); }
.feed-ctx-edit i   { color: var(--blade); }
.feed-ctx-delete   { color: #ef4444; }
.feed-ctx-delete i { color: #ef4444; }
.feed-ctx-report   { color: var(--muted); }

/* ══════════════════════════════════════════════
   상세 레이어 공통
══════════════════════════════════════════════ */
.feed-detail-avatar--empty {
	width: 25px; height: 25px;
	border-radius: 50%;
	background: var(--border);
	color: var(--muted);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.feed-detail-text {
	padding: 12px 16px;
	font-size: 15px;
	color: var(--text);
	line-height: 1.7;
	white-space: pre-wrap;
	word-break: break-word;
}

/* 액션 바 */
.feed-action-bar {
	display: flex;
	align-items: center;
	gap: 4px;
	padding: 6px 12px 10px;
	border-bottom: 1px solid var(--hd-drawer-border);
}
.feed-action-btn {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 6px 10px;
	font-size: 14px;
	color: var(--muted);
	background: transparent;
	border: none;
	cursor: pointer;
	border-radius: 8px;
	transition: color var(--transition), background var(--transition), transform .15s;
}
.feed-action-btn:hover { background: var(--bladeL); color: var(--blade); }
.feed-action-btn.is-liked      { color: #ef4444; }
.feed-action-btn.is-bookmarked { color: var(--blade); }
.feed-action-btn--share { margin-left: auto; }
.feed-action-btn i { transition: transform .15s; }
.feed-action-btn:hover i { transform: scale(1.15); }

/* ══════════════════════════════════════════════
   댓글
══════════════════════════════════════════════ */
.feed-comments-wrap { padding: 8px 0; }
.feed-comments-list { display: flex; flex-direction: column; }
.feed-comments-empty { padding: 24px 16px; font-size: 13px; color: var(--muted); text-align: center; }

.feed-comment {
	padding: 10px 16px;
	border-bottom: 1px solid var(--hd-drawer-border);
}
.feed-comment-header { display: flex; align-items: center; gap: 8px; margin-bottom: 4px; }
.feed-comment-avatar {
	width: 28px; height: 28px;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
}
.feed-comment-avatar--empty {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--bladeL);
	color: var(--blade);
	font-size: 12px;
}
.feed-comment-nick   { font-size: 12px; font-weight: 700; color: var(--text); }
.feed-comment-date   { font-size: 11px; color: var(--muted); margin-left: 4px; }
.feed-comment-edited { font-size: 10px; color: var(--muted); margin-left: 2px; }
.feed-comment-content { padding-left: 36px; }
.feed-comment-body {
	font-size: 13px;
	color: var(--text);
	line-height: 1.6;
	white-space: pre-wrap;
	word-break: break-word;
}
.feed-comment-blinded { font-size: 13px; color: var(--muted); font-style: italic; }
.feed-comment-actions { display: flex; gap: 4px; margin-left: auto; flex-shrink: 0; }
.feed-comment-edit-btn,
.feed-comment-delete-btn {
	font-size: 11px;
	color: var(--muted);
	background: transparent;
	border: none;
	cursor: pointer;
	padding: 2px 4px;
	transition: color var(--transition);
}
.feed-comment-edit-btn:hover   { color: var(--blade); }
.feed-comment-delete-btn:hover { color: #ef4444; }

.feed-comment-edit-ta {
	width: 100%;
	padding: 6px 10px;
	font-size: 13px;
	color: var(--text);
	background: var(--surface-strong, #fff);
	border: 1.5px solid var(--blade);
	border-radius: 8px;
	resize: none;
	line-height: 1.5;
	font-family: inherit;
}
[data-theme="dark"] .feed-comment-edit-ta { background: rgba(7,17,29,.85); }

.feed-comment-edit-actions { display: flex; gap: 6px; margin-top: 6px; }
.feed-comment-save-btn,
.feed-comment-cancel-btn {
	padding: 4px 12px;
	font-size: 12px;
	font-weight: 600;
	border-radius: 16px;
	border: none;
	cursor: pointer;
	transition: background var(--transition), color var(--transition);
}
.feed-comment-save-btn { background: var(--blade); color: #fff; }
.feed-comment-save-btn:hover { background: var(--hd-btn-login-hover, #0284c7); }
.feed-comment-cancel-btn { background: transparent; color: var(--muted); border: 1px solid var(--hd-drawer-border); }
.feed-comment-cancel-btn:hover { background: var(--bladeL); color: var(--blade); }

.feed-comments-more-wrap { padding: 10px 16px; }
.feed-comments-more-btn {
	width: 100%;
	padding: 8px;
	font-size: 13px;
	color: var(--muted);
	background: transparent;
	border: 1px solid var(--hd-drawer-border);
	border-radius: 8px;
	cursor: pointer;
	transition: color var(--transition), border-color var(--transition);
}
.feed-comments-more-btn:hover { color: var(--blade); border-color: var(--blade); }

/* ══════════════════════════════════════════════
   댓글 입력창
══════════════════════════════════════════════ */
.feed-comment-input-wrap {
	flex-shrink: 0;
	border-top: 1px solid var(--hd-drawer-border);
	background: var(--bg);
	padding: 8px 12px max(8px, env(safe-area-inset-bottom));
}
.feed-comment-input-inner { display: flex; align-items: flex-end; gap: 8px; }
.feed-comment-textarea {
	flex: 1;
	padding: 9px 12px;
	font-size: 14px;
	color: var(--text);
	background: var(--surface-soft, rgba(230,241,250,.7));
	border: 1.5px solid var(--hd-drawer-border);
	border-radius: 20px;
	resize: none;
	line-height: 1.5;
	min-height: 38px;
	max-height: 120px;
	font-family: inherit;
	transition: border-color var(--transition);
}
.feed-comment-textarea:focus { outline: none; border-color: var(--blade); }
[data-theme="dark"] .feed-comment-textarea { background: rgba(17,34,58,.72); }

.feed-comment-submit {
	flex-shrink: 0;
	width: 36px; height: 36px;
	border-radius: 50%;
	border: none;
	background: var(--blade);
	color: #fff;
	font-size: 14px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background var(--transition), transform .15s;
}
.feed-comment-submit:hover { background: var(--hd-btn-login-hover, #0284c7); transform: scale(1.08); }

.feed-comment-options { padding: 4px 4px 0; }
.feed-anon-label {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-size: 12px;
	color: var(--muted);
	cursor: pointer;
}
.feed-anon-label input { accent-color: var(--blade); }
.feed-comment-login { text-align: center; padding: 8px; font-size: 13px; color: var(--muted); }
.feed-comment-login a { color: var(--blade); }

/* ══════════════════════════════════════════════
/* ══════════════════════════════════════════════
   댓글/구간 탭 (상세 레이어)
══════════════════════════════════════════════ */
.fd-tab-bar {
	display: flex;
	border-bottom: 1px solid var(--border);
	background: var(--surface);
	flex-shrink: 0;
	position: sticky;
	top: 0;
	z-index: 10;
}
.fd-tab-body { flex: 1; min-height: 0; }
.fd-tab-body::-webkit-scrollbar { display: none; }
.fd-tab-btn {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 11px 8px;
	font-size: 13px;
	font-weight: 500;
	color: var(--muted);
	background: none;
	border: none;
	border-bottom: 2px solid transparent;
	cursor: pointer;
	transition: color .15s, border-color .15s;
	position: relative;
}
.fd-tab-btn i { font-size: 14px; }
.fd-tab-btn .fd-tab-count {
	font-size: 10px;
	font-weight: 700;
	font-style: normal;
	background: var(--border);
	color: var(--muted);
	border-radius: 10px;
	padding: 1px 6px;
	line-height: 1.5;
	min-width: 18px;
	text-align: center;
}
.fd-tab-btn.fd-tab-btn--active { color: var(--blade); border-bottom-color: var(--blade); }
.fd-tab-btn.fd-tab-btn--active .fd-tab-count { background: rgba(10,132,200,.12); color: var(--blade); }
.fd-tab-btn:hover:not(.fd-tab-btn--active) { color: var(--text); }
.fd-tab-btn--disabled { opacity: .4; cursor: not-allowed; }
.fd-tab-pane { display: none; }
.fd-tab-pane.fd-tab-pane--active { display: block; }

/* ══════════════════════════════════════════════
   영상 태깅 패널 (상세 레이어)
══════════════════════════════════════════════ */
.seg-no-video {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
	padding: 40px 20px;
	color: var(--muted);
	text-align: center;
}
.seg-no-video i { font-size: 28px; opacity: .45; }
.seg-no-video p { font-size: 13px; line-height: 1.65; margin: 0; }

.seg-tag-panel {
	padding: 14px 16px;
	border-bottom: 1px solid var(--border);
	background: var(--surface);
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.seg-field-row { display: flex; align-items: center; gap: 10px; }
.seg-label {
	font-size: 12px;
	font-weight: 600;
	color: var(--muted);
	width: 36px;
	flex-shrink: 0;
}
.seg-select,
.seg-input {
	flex: 1;
	height: 36px;
	padding: 0 10px;
	border: 1px solid var(--border);
	border-radius: 6px;
	background: var(--bg);
	color: var(--text);
	font-size: 13px;
	outline: none;
	transition: border-color .15s;
}
.seg-select:focus,
.seg-input:focus { border-color: var(--blade); }

.seg-time-inner { flex: 1; display: flex; align-items: center; gap: 8px; }
.seg-time-val {
	flex: 1;
	font-size: 12px;
	font-weight: 700;
	color: var(--blade);
	font-family: monospace;
	text-align: center;
	background: var(--bg);
	border: 1px solid var(--border);
	border-radius: 6px;
	padding: 5px 8px;
	min-width: 0;
}
.seg-time-btn {
	padding: 5px 10px;
	font-size: 11px;
	border: 1px solid var(--blade);
	border-radius: 5px;
	background: none;
	color: var(--blade);
	cursor: pointer;
	white-space: nowrap;
	transition: background .12s;
	flex-shrink: 0;
}
.seg-time-btn:hover { background: rgba(10,132,200,.08); }
.seg-time-btn.is-set { background: var(--blade); color: #fff; }
.seg-time-sep { font-size: 13px; color: var(--muted); flex-shrink: 0; }

.seg-btn-row { display: flex; gap: 8px; }
.seg-btn-add,
.seg-btn-save {
	flex: 1;
	height: 38px;
	border-radius: 7px;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 5px;
	border: none;
	transition: opacity .15s;
}
.seg-btn-add { background: var(--blade); color: #fff; }
.seg-btn-add:disabled { opacity: .4; cursor: default; }
.seg-btn-save { background: #10b981; color: #fff; }
.seg-btn-save:disabled { opacity: .4; cursor: default; }
.seg-save-cnt { font-size: 11px; background: rgba(255,255,255,.25); border-radius: 10px; padding: 1px 6px; }



@media (max-width: 1023px) {
	.feed-yt-cfs-side--inlayer .cfs-time-row {
		display: flex;
		align-items: center;
		gap: 6px;
		width: 100%;
	}

	.feed-yt-cfs-side--inlayer .cfs-time-row .cfs-label {
		width: auto !important;
		flex: 0 0 28px;   /* 시작/종료 글자영역만 */
		min-width: 28px;
	}

	.feed-yt-cfs-side--inlayer .cfs-time-row .cfs-time-val {
		flex: 1 1 auto;
		width: auto !important;
		min-width: 0;
	}

	.feed-yt-cfs-side--inlayer .cfs-time-row .cfs-time-btn {
		flex: 0 0 auto;
		width: auto !important;
		white-space: nowrap;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		gap: 4px;
	}
}

/* 버퍼 목록 */
.seg-buffer-list { display: flex; flex-direction: column; gap: 4px; }
.seg-buffer-item {
	display: grid;
	grid-template-columns: 28px 1fr 20px;
	grid-template-rows: auto auto;
	column-gap: 8px;
	padding: 7px 10px;
	background: rgba(10,132,200,.06);
	border: 1px dashed rgba(10,132,200,.3);
	border-radius: 7px;
	font-size: 12px;
	color: var(--text);
	animation: segBufIn .18s ease;
	align-items: start;
}
@keyframes segBufIn {
	from { opacity: 0; transform: translateY(-4px); }
	to   { opacity: 1; transform: translateY(0); }
}
.seg-buf-play {
	grid-row: 1 / 3; grid-column: 1;
	background: var(--border) !important;
	color: var(--muted) !important;
	font-size: 10px !important;
	align-self: start;
	margin-top: 2px;
}
.seg-buf-del {
	grid-row: 1 / 3; grid-column: 3;
	background: none;
	border: none;
	color: var(--muted);
	cursor: pointer;
	font-size: 14px;
	padding: 2px;
	align-self: start;
	margin-top: 3px;
	transition: color .12s;
}
.seg-buf-del:hover { color: #ef4444; }

/* 저장된 구간 목록 */
.seg-saved-wrap { padding: 0 0 12px; }
.seg-saved-hd {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 10px 16px 6px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .8px;
	text-transform: uppercase;
	color: var(--muted);
}
.seg-saved-list { display: flex; flex-direction: column; gap: 2px; padding: 0 3px 0 5px; }

.seg-item {
	display: grid;
	grid-template-columns: 28px 1fr auto;
	grid-template-rows: auto auto;
	column-gap: 5px;
	padding: 8px 5px;
	border-radius: 8px;
	cursor: pointer;
	transition: background .12s;
	align-items: start;
}
.seg-item:hover { background: var(--bg); }
.seg-item.seg-item--active { background: rgba(10,132,200,.07); outline: 1px solid rgba(10,132,200,.2); }

.seg-item-play {
	grid-row: 1 / 3; grid-column: 1;
	width: 22px; height: 22px;
	border-radius: 50%;
	background: var(--blade);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 9px;
	flex-shrink: 0;
	margin-top: 2px;
	transition: transform .12s;
	align-self: start;
}
.seg-item:hover .seg-item-play { transform: scale(1.1); }
.seg-item-body { grid-row: 1; grid-column: 2; min-width: 0; }
.seg-item-actions {
	grid-row: 1; grid-column: 3;
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: 8px;
	align-self: start;
	margin-top: 4px;
	flex-shrink: 0;
	white-space: nowrap;
}
.seg-item-line1 {
	display: flex;
	align-items: center;
	gap: 6px;
	margin-bottom: 2px;
	flex-wrap: nowrap;
	overflow: hidden;
	justify-content: flex-start;
}
.seg-item-time {
	font-size: 11px;
	font-weight: 700;
	color: var(--blade);
	font-family: monospace;
	white-space: nowrap;
	flex-shrink: 0;
}
.seg-item-tag {
	font-size: 10px;
	font-weight: 600;
	background: rgba(10,132,200,.12);
	color: var(--blade);
	border-radius: 4px;
	padding: 2px 0;
	white-space: nowrap;
	flex-shrink: 0;
	width: 52px;
	text-align: center;
	display: inline-block;
}
.seg-item-player {
	font-size: 12px;
	color: var(--text);
	font-weight: 500;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	width: 70px;
	flex-shrink: 0;
}
.seg-item-player--team { color: var(--blade); font-weight: 600; font-size: 12px; }
.seg-item-jersey { font-size: 11px; color: var(--blade); font-weight: 600; margin-right: 2px; }
.seg-item-memo {
	grid-row: 2; grid-column: 2;
	font-size: 11px;
	color: var(--muted);
	font-style: italic;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	padding-bottom: 2px;
}
.seg-item-fb-count {
	font-size: 10px;
	color: var(--muted);
	display: flex;
	align-items: center;
	gap: 2px;
	white-space: nowrap;
}
.seg-item-fb-count--has { color: var(--blade); font-weight: 600; }

.seg-item-del-x {
	background: none;
	border: none;
	color: var(--muted);
	cursor: pointer;
	font-size: 13px;
	padding: 2px 4px;
	border-radius: 4px;
	transition: color .12s;
	display: flex;
	align-items: center;
}
.seg-item-del-x:hover { color: #ef4444; }

/* 상세 레이어 구간 수정 버튼 */
.seg-item-edit-btn {
	background: none;
	border: none;
	color: var(--muted);
	cursor: pointer;
	font-size: 11px;
	padding: 2px 4px;
	border-radius: 4px;
	transition: color .12s;
	display: flex;
	align-items: center;
}
.seg-item-edit-btn:hover { color: var(--accent, #3b82f6); }

/* 상세 레이어 구간 인라인 수정 폼 */
.seg-item-edit-form {
	display: flex;
	flex-direction: column;
	gap: 6px;
	padding: 8px 10px;
	background: rgba(255,255,255,.06);
	border-radius: 6px;
	margin: 6px 0 2px;
}
[data-theme="light"] .seg-item-edit-form { background: rgba(0,0,0,.04); }
.seg-item-edit-tag,
.seg-item-edit-memo {
	width: 100%;
	padding: 5px 8px;
	border-radius: 5px;
	border: 1px solid rgba(255,255,255,.12);
	background: rgba(255,255,255,.07);
	color: inherit;
	font-size: 13px;
}
[data-theme="light"] .seg-item-edit-tag,
[data-theme="light"] .seg-item-edit-memo {
	background: #fff;
	border-color: rgba(0,0,0,.15);
}
.seg-item-edit-btns { display: flex; gap: 6px; }
.seg-item-edit-save,
.seg-item-edit-cancel {
	flex: 1;
	padding: 5px 0;
	border: none;
	border-radius: 5px;
	font-size: 13px;
	cursor: pointer;
	fonT-weight: 600;
}
.seg-item-edit-save   { background: var(--accent, #3b82f6); color: #fff; }
.seg-item-edit-cancel { background: rgba(255,255,255,.08); color: inherit; }
[data-theme="light"] .seg-item-edit-cancel { background: rgba(0,0,0,.07); }

.seg-empty {
	padding: 30px 16px;
	text-align: center;
	color: var(--muted);
	font-size: 13px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
}
.seg-empty i { font-size: 24px; opacity: .4; }

/* 필터 바 */
.seg-filter-bar {
	display: flex;
	gap: 8px;
	padding: 10px 14px 8px;
	border-bottom: 1px solid var(--border);
	background: var(--surface);
}
.seg-filter-sel {
	flex: 1;
	height: 34px;
	padding: 0 8px;
	border: 1px solid var(--border);
	border-radius: 6px;
	background: var(--bg);
	color: var(--text);
	font-size: 12px;
	outline: none;
}
.seg-filter-sel:focus { border-color: var(--blade); }

/* 반복 재생 바 */
.seg-loop-bar {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 8px 14px;
	background: var(--surface);
	border-bottom: 1px solid var(--border);
}
.seg-loop-label { flex: 1; font-size: 11px; font-family: monospace; color: var(--muted); }
.seg-loop-btn {
	padding: 4px 10px;
	font-size: 11px;
	font-weight: 600;
	border: 1px solid var(--border);
	border-radius: 5px;
	background: none;
	color: var(--muted);
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: 4px;
	transition: all .12s;
	white-space: nowrap;
}
.seg-loop-btn:hover { border-color: var(--blade); color: var(--blade); }
.seg-loop-btn--active { background: var(--blade) !important; color: #fff !important; border-color: var(--blade) !important; }

/* 피드백 패널 */
.seg-feedback-wrap { border-top: 2px solid var(--border); background: var(--surface); padding-top: 4px; }
.seg-feedback-close {
	position: absolute;
	top: 8px; right: 10px;
	background: none;
	border: none;
	color: var(--muted);
	font-size: 15px;
	cursor: pointer;
	padding: 2px 4px;
	border-radius: 4px;
	z-index: 1;
	transition: color .12s;
}
.seg-feedback-close:hover { color: var(--text); }

.seg-feedback-list { padding: 10px 14px 6px; display: flex; flex-direction: column; gap: 10px; }

.seg-fb-item { display: flex; gap: 8px; }
.seg-fb-avatar {
	width: 28px; height: 28px;
	border-radius: 50%;
	background: var(--border);
	object-fit: cover;
	flex-shrink: 0;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 12px;
	color: var(--muted);
}
.seg-fb-avatar img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.seg-fb-body { flex: 1; min-width: 0; }
.seg-fb-meta { display: flex; align-items: center; gap: 4px; margin-bottom: 3px; flex-wrap: nowrap; }
.seg-fb-nick   { font-size: 12px; font-weight: 600; color: var(--text); flex-shrink: 0; }
.seg-fb-role   { font-size: 10px; padding: 1px 5px; border-radius: 3px; font-weight: 600; flex-shrink: 0; }
.seg-fb-role--director { background: #ede9fe; color: #6d28d9; }
.seg-fb-role--coach    { background: #dbeafe; color: #1d4ed8; }
.seg-fb-role--player   { background: #d1fae5; color: #065f46; }
.seg-fb-role--self     { background: #fef3c7; color: #92400e; }

.seg-fb-scope--badge {
	font-size: 10px;
	color: var(--muted);
	background: var(--bg);
	border: 1px solid var(--border);
	border-radius: 3px;
	padding: 1px 5px;
	flex-shrink: 0;
}
.seg-fb-meta-right { display: flex; align-items: center; gap: 2px; margin-left: auto; flex-shrink: 0; }
.seg-fb-time { font-size: 10px; color: var(--muted); white-space: nowrap; padding: 0 2px; }
.seg-fb-text { font-size: 13px; color: var(--text); line-height: 1.55; word-break: break-word; }

.seg-fb-edit-btn,
.seg-fb-del-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 22px; height: 22px;
	background: none;
	border: none;
	cursor: pointer;
	padding: 0;
	border-radius: 4px;
	font-size: 11px;
	transition: color .12s, background .12s;
	flex-shrink: 0;
	color: var(--muted);
}
.seg-fb-edit-btn:hover { color: var(--blade); background: var(--bladeL); }
.seg-fb-del-btn:hover  { color: #ef4444; background: rgba(239,68,68,.08); }
.seg-fb-empty { padding: 16px 0; text-align: center; font-size: 12px; color: var(--muted); }

.seg-fb-actions { display: flex; gap: 4px; margin-top: 4px; }
.seg-fb-edit,
.seg-fb-del {
	background: none;
	border: none;
	font-size: 11px;
	color: var(--muted);
	cursor: pointer;
	padding: 2px 4px;
	border-radius: 3px;
	transition: color .12s;
}
.seg-fb-edit:hover { color: var(--blade); }
.seg-fb-del:hover  { color: #ef4444; }

/* 인라인 피드백 패널 */
.seg-inline-fb {
	background: rgba(10,132,200,.04);
	border-left: 2px solid rgba(10,132,200,.3);
	margin: 2px 12px 4px 15px;
	border-radius: 0 6px 6px 0;
	padding: 8px 10px;
	animation: segBufIn .18s ease;
}
.seg-inline-fb-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 8px; }
.seg-inline-fb-input { display: flex; flex-direction: column; gap: 5px; }
.seg-inline-scope {
	height: 30px;
	padding: 0 8px;
	border: 1px solid var(--border);
	border-radius: 6px;
	background: var(--bg);
	color: var(--text);
	font-size: 12px;
	outline: none;
	width: 100%;
}
.seg-inline-scope:focus { border-color: var(--blade); }
.seg-inline-input-row { display: flex; align-items: flex-end; gap: 6px; }
.seg-inline-textarea {
	flex: 1;
	padding: 7px 10px;
	border: 1px solid var(--border);
	border-radius: 7px;
	background: var(--bg);
	color: var(--text);
	font-size: 13px;
	resize: none;
	line-height: 1.5;
	outline: none;
	transition: border-color .15s;
	font-family: inherit;
	min-height: 38px;
	max-height: 120px;
	overflow-y: auto;
	box-sizing: border-box;
}
.seg-inline-textarea:focus { border-color: var(--blade); }
.seg-inline-submit {
	width: 34px; height: 34px;
	flex-shrink: 0;
	border-radius: 7px;
	background: var(--blade);
	color: #fff;
	border: none;
	cursor: pointer;
	font-size: 14px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: opacity .15s;
}
.seg-inline-submit:disabled { opacity: .4; cursor: default; }

/* seg-fb-scope-sel (구버전 피드백 입력폼 공유) */
.seg-fb-scope-sel {
	height: 30px;
	padding: 0 8px;
	border: 1px solid var(--border);
	border-radius: 6px;
	background: var(--bg);
	color: var(--text);
	font-size: 12px;
	outline: none;
	width: 100%;
}
.seg-fb-scope-sel:focus { border-color: var(--blade); }
.seg-fb-textarea {
	flex: 1;
	padding: 7px 10px;
	border: 1px solid var(--border);
	border-radius: 7px;
	background: var(--bg);
	color: var(--text);
	font-size: 13px;
	resize: none;
	line-height: 1.5;
	outline: none;
	transition: border-color .15s;
	font-family: inherit;
	min-height: 56px;
	max-height: 100px;
	overflow-y: auto;
	width: 100%;
	box-sizing: border-box;
}
.seg-fb-textarea:focus { border-color: var(--blade); }
.seg-fb-submit {
	width: 38px;
	flex-shrink: 0;
	border-radius: 8px;
	background: var(--blade);
	color: #fff;
	border: none;
	cursor: pointer;
	font-size: 14px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: opacity .15s;
	align-self: stretch;
}
.seg-fb-submit:disabled { opacity: .4; cursor: default; }
.seg-fb-input-row { display: flex; align-items: stretch; gap: 8px; }
.seg-fb-left { flex: 1; display: flex; flex-direction: column; gap: 5px; min-width: 0; }
.seg-feedback-input-wrap { padding: 10px 14px 16px; border-top: 1px solid var(--border); }

/* 영상 전체 피드백 섹션 */
.seg-post-fb-section { margin-top: 16px; border-top: 2px solid var(--border); padding-top: 4px; }
.seg-post-fb-header {
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 10px 16px 8px;
	font-size: 12px;
	font-weight: 700;
	color: var(--muted);
	letter-spacing: .5px;
}
.seg-post-fb-header i { font-size: 13px; }
.seg-post-fb-count {
	font-size: 11px;
	font-weight: 600;
	color: var(--blade);
	background: rgba(10,132,200,.1);
	border-radius: 10px;
	padding: 1px 6px;
	min-width: 18px;
	text-align: center;
}
.seg-post-fb-list { padding: 0 14px 8px; display: flex; flex-direction: column; gap: 10px; }
.seg-post-fb-input-wrap {
	padding: 10px 14px 20px;
	display: flex;
	flex-direction: column;
	gap: 6px;
	border-top: 1px solid var(--border);
}
.seg-post-fb-scope-sel {
	height: 30px;
	padding: 0 8px;
	border: 1px solid var(--border);
	border-radius: 6px;
	background: var(--bg);
	color: var(--text);
	font-size: 12px;
	outline: none;
	width: 100%;
	box-sizing: border-box;
}
.seg-post-fb-scope-sel:focus { border-color: var(--blade); }
.seg-post-fb-input-row { display: flex; align-items: flex-end; gap: 6px; }
.seg-post-fb-textarea {
	flex: 1;
	padding: 8px 12px;
	border: 1px solid var(--border);
	border-radius: 8px;
	background: var(--bg);
	color: var(--text);
	font-size: 13px;
	resize: none;
	line-height: 1.5;
	outline: none;
	transition: border-color .15s;
	font-family: inherit;
	min-height: 38px;
	max-height: 120px;
	overflow-y: auto;
	box-sizing: border-box;
}
.seg-post-fb-textarea:focus { border-color: var(--blade); }
.seg-post-fb-submit {
	width: 38px; height: 38px;
	flex-shrink: 0;
	border-radius: 8px;
	background: var(--blade);
	color: #fff;
	border: none;
	cursor: pointer;
	font-size: 14px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: opacity .15s;
}
.seg-post-fb-submit:disabled { opacity: .4; cursor: default; }

/* 로딩 스피너 */
.seg-loading {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px;
	color: var(--muted);
	gap: 8px;
	font-size: 13px;
}

/* 피드백 타입 셀렉트 */
.seg-fb-selects { display: flex; gap: 6px; }
.seg-fb-type-sel {
	flex: 0 0 auto;
	height: 30px;
	padding: 0 8px;
	border: 1px solid var(--border);
	border-radius: 6px;
	background: var(--bg);
	color: var(--text);
	font-size: 12px;
	font-weight: 600;
	outline: none;
	cursor: pointer;
}
.seg-fb-type-sel:focus { border-color: var(--blade); }
.seg-fb-type-sel option[value="segment"] { color: var(--blade); }

.seg-item-more-wrap { position: relative; }
.seg-item-more-btn {
	background: none;
	border: none;
	color: var(--muted);
	cursor: pointer;
	font-size: 13px;
	padding: 2px 4px;
	border-radius: 3px;
	transition: color .12s;
	display: none;
}
.seg-item:hover .seg-item-more-btn { display: flex; }
.seg-item-more-btn:hover { color: var(--text); }
.seg-item-more-menu {
	position: absolute;
	right: 0; top: 100%;
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: 6px;
	box-shadow: 0 4px 12px rgba(0,0,0,.15);
	z-index: 20;
	min-width: 70px;
	overflow: hidden;
}

.seg-buf-memo-inline { font-size: 11px; color: var(--muted); font-style: italic; }

@media (max-width: 680px) {
	.seg-tag-panel { padding: 12px 14px; }
	.seg-feedback-list { max-height: 180px; }
}
/* ★ 모바일 스크롤 강제 — CSS 직접 적용 */

/* 일반(세로) 패널: Y방향 스크롤 */
.feed-yt-cfs-side:not(.feed-yt-cfs-side--inlayer) .cfs-saved-scroll {
	overflow-y: scroll;
	overflow-x: hidden;
	touch-action: pan-y;
}
.feed-yt-cfs-side:not(.feed-yt-cfs-side--inlayer) .cfs-comments-list {
	overflow-y: scroll;
	overflow-x: hidden;
	touch-action: pan-y;
}

/* inlayer(rotate90): 콘텐츠는 세로 쌓임(scrollTop) 유지
   손가락 Y 동작을 브라우저가 차단 못하도록 touch-action: none */
.feed-yt-cfs-side--inlayer .cfs-saved-scroll {
	overflow-y: scroll;
	overflow-x: hidden;
	touch-action: none;
	-webkit-overflow-scrolling: touch;
}
.feed-yt-cfs-side--inlayer .cfs-comments-list {
	overflow-y: scroll;
	overflow-x: hidden;
	touch-action: none;
	-webkit-overflow-scrolling: touch;
}

/* tab-bar sticky → rotate90 환경에서 오작동, relative로 변경 */
.feed-yt-cfs-side--inlayer .cfs-tab-bar {
	position: relative;
	top: auto;
}

/* ══════════════════════════════════════════════
   가로모드(rotate90) 태킹 패널 전용
   left:100% + rotate(-90deg) 로 기준점 고정
   → --cfs-panel-h 의존 없이 안정적으로 역회전
══════════════════════════════════════════════ */

/* ① tagging pane: overflow 해제, 절대 배치 기준 */
.feed-yt-cfs-side--inlayer .cfs-pane[data-cfs-pane="tagging"] {
	display: none;
}

.feed-yt-cfs-side--inlayer .cfs-pane.cfs-pane--active[data-cfs-pane="tagging"] {
	display: flex;
	flex-direction: column;
	flex: 1 1 0%;
	width: 100%;
	height: 100%;
	min-height: 0;
	overflow: visible;   /* hidden → visible */
}

.feed-yt-cfs-side--inlayer .cfs-tag-panel {
	position: relative;
	width: 100%;
	height: 100%;
	min-height: 0;
	max-width: 100%;
	transform: none;
	transform-origin: center center;
	overflow-y: auto;
	overflow-x: hidden;
	-webkit-overflow-scrolling: touch;
	touch-action: pan-y;
	padding: 12px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	box-sizing: border-box;
	background: inherit;
}

/* ③ 입력 요소 폭 100% 유지 */
.feed-yt-cfs-side--inlayer .cfs-tag-panel .cfs-field-row,
.feed-yt-cfs-side--inlayer .cfs-tag-panel .cfs-select,
.feed-yt-cfs-side--inlayer .cfs-tag-panel .cfs-time-row,
.feed-yt-cfs-side--inlayer .cfs-tag-panel .cfs-memo-ta,
.feed-yt-cfs-side--inlayer .cfs-tag-panel .cfs-btn-add,
.feed-yt-cfs-side--inlayer .cfs-tag-panel .cfs-btn-save,
.feed-yt-cfs-side--inlayer .cfs-tag-panel .cfs-buffer-list,
.feed-yt-cfs-side--inlayer .cfs-tag-panel .cfs-label {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

/* ④ 시간행 내부 비율 */
.feed-yt-cfs-side--inlayer .cfs-tag-panel .cfs-time-row {
	align-items: center;
}
.feed-yt-cfs-side--inlayer .cfs-tag-panel .cfs-time-val {
	flex: 1 1 auto;
	min-width: 0;
}
.feed-yt-cfs-side--inlayer .cfs-tag-panel .cfs-time-btn {
	flex: 0 0 auto;
}

/* ⑤ select 드롭다운 잘림 방지 */
.feed-yt-cfs-side--inlayer .cfs-tag-panel .cfs-select {
	appearance: auto;
	-webkit-appearance: menulist;
}

/* ⑥ 메모 유지 (접기 해제) */
.feed-yt-cfs-side--inlayer .cfs-field-row:has(.cfs-memo-ta) {
	display: flex;
}


/* ══════════════════════════════════════════════
   CFS 가로모드 커스텀 셀렉트
══════════════════════════════════════════════ */
.cfs-custom-select { display: none; }

@media (max-width: 1023px) {
	.feed-yt-cfs-side--inlayer .cfs-select.is-customized,
	.feed-yt-cfs-side--inlayer .cfs-filter-sel.is-customized {
		position: absolute !important;
		left: -99999px !important;
		width: 1px !important;
		height: 1px !important;
		opacity: 0 !important;
		pointer-events: none !important;
	}

	.feed-yt-cfs-side--inlayer .cfs-custom-select {
		position: relative;
		display: block;
		width: 100%;
	}

	.feed-yt-cfs-side--inlayer .cfs-custom-select__btn {
		width: 100%;
		height: 36px;
		padding: 0 34px 0 10px;
		border: 1px solid var(--cfs-border);
		border-radius: 8px;
		background: var(--surface-strong, #fff);
		color: var(--cfs-text);
		font-size: 12px;
		line-height: 34px;
		text-align: left;
		box-sizing: border-box;
		cursor: pointer;
		position: relative;
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	}

	.feed-yt-cfs-side--inlayer .cfs-custom-select__btn::after {
		content: "\f078";
		font-family: "Font Awesome 6 Free";
		font-weight: 900;
		position: absolute;
		right: 10px;
		top: 50%;
		transform: translateY(-50%);
		font-size: 10px;
		color: var(--cfs-text-muted);
	}

	.feed-yt-cfs-side--inlayer .cfs-custom-select.is-open .cfs-custom-select__btn {
		border-color: var(--cfs-accent);
	}

	.feed-yt-cfs-side--inlayer .cfs-custom-select {
		position: relative;  /* 이미 있음, 확인만 */
		display: block;
		width: 100%;
	}

	.feed-yt-cfs-side--inlayer .cfs-custom-select__menu {
		display: none;
		position: absolute;
		top: calc(100% + 4px);
		left: 0;
		width: 100%;
		max-height: 220px;
		overflow-y: auto;
		overflow-x: hidden;
		-webkit-overflow-scrolling: touch;
		overscroll-behavior: contain;
		background: var(--surface-strong, #fff);
		border: 1px solid var(--cfs-border);
		border-radius: 8px;
		box-shadow: 0 12px 28px rgba(0,0,0,.28);
		z-index: 9999;
		padding: 4px;
		touch-action: none;
		box-sizing: border-box;
	}

	.feed-yt-cfs-side--inlayer .cfs-custom-select.is-open .cfs-custom-select__menu {
		display: block;
	}

	.feed-yt-cfs-side--inlayer .cfs-custom-select__option {
		display: block;
		width: 100%;
		padding: 8px 10px;
		border: 0;
		border-radius: 6px;
		background: transparent;
		color: var(--cfs-text);
		font-size: 12px;
		line-height: 1.35;
		text-align: left;
		cursor: pointer;
		box-sizing: border-box;
	}

	.feed-yt-cfs-side--inlayer .cfs-custom-select__option:hover,
	.feed-yt-cfs-side--inlayer .cfs-custom-select__option.is-selected {
		background: var(--cfs-accent-faint, rgba(30,167,255,.18));
		color: var(--cfs-text);
	}
}
/* =========================================================
   모바일에서만 메모 입력 숨김
========================================================= */
@media (max-width: 1023px) {
	/* 상세 태깅 탭 메모 숨김 */
	.seg-tag-panel .seg-field-row:has(#segMemo) {
		display: none !important;
	}

	/* CFS 태깅 탭 메모 숨김 */
	.cfs-tag-panel .cfs-field-row:has(#cfsMemo) {
		display: none !important;
	}

	/* rotate90 / inlayer 포함 강제 숨김 */
	.feed-yt-cfs-side--inlayer .cfs-field-row:has(.cfs-memo-ta) {
		display: none !important;
	}
}

.fd-pdf-pending-notice {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 14px 16px;
	font-size: 13px;
	color: var(--muted);
	background: var(--bg3);
	border-bottom: 1px solid var(--border);
	flex-shrink: 0;
}
/* ── 공용 미디어 버튼 그룹 (회전/다운로드) ── */
.feed-media-action-group {
	position: absolute;
	bottom: 40px;
	right: 10px;
	display: flex;
	flex-direction: column;
	gap: 6px;
	z-index: 10;
}
.feed-media-action-btn {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	border: none;
	background: rgba(0,0,0,.45);
	color: #fff;
	font-size: 14px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	transition: background .15s;
}
.feed-media-action-btn:hover {
	background: rgba(0,0,0,.7);
}